Welcome to mirror list, hosted at ThFree Co, Russian Federation.

obj_export_mtl.hh « exporter « wavefront_obj « io « blender « source - git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 80e3127f69f74bbee3910b4ec59eac2db550bde7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/* SPDX-License-Identifier: GPL-2.0-or-later */

/** \file
 * \ingroup obj
 */

#pragma once

#include "BLI_map.hh"
#include "BLI_math_vec_types.hh"
#include "BLI_string_ref.hh"
#include "BLI_vector.hh"

#include "DNA_node_types.h"
#include "obj_export_io.hh"

namespace blender {
template<> struct DefaultHash<io::obj::eMTLSyntaxElement> {
  uint64_t operator()(const io::obj::eMTLSyntaxElement value) const
  {
    return static_cast<uint64_t>(value);
  }
};

}  // namespace blender

namespace blender::io::obj {
class OBJMesh;

/**
 * Generic container for texture node properties.
 */
struct tex_map_XX {
  tex_map_XX(StringRef to_socket_id) : dest_socket_id(to_socket_id){};

  /** Target socket which this texture node connects to. */
  const std::string dest_socket_id;
  float3 translation{0.0f};
  float3 scale{1.0f};
  /* Only Flat and Smooth projections are supported. */
  int projection_type = SHD_PROJ_FLAT;
  std::string image_path;
  std::string mtl_dir_path;
};

/**
 * Container suited for storing Material data for/from a .MTL file.
 */
struct MTLMaterial {
  MTLMaterial()
  {
    texture_maps.add(eMTLSyntaxElement::map_Kd, tex_map_XX("Base Color"));
    texture_maps.add(eMTLSyntaxElement::map_Ks, tex_map_XX("Specular"));
    texture_maps.add(eMTLSyntaxElement::map_Ns, tex_map_XX("Roughness"));
    texture_maps.add(eMTLSyntaxElement::map_d, tex_map_XX("Alpha"));
    texture_maps.add(eMTLSyntaxElement::map_refl, tex_map_XX("Metallic"));
    texture_maps.add(eMTLSyntaxElement::map_Ke, tex_map_XX("Emission"));
    texture_maps.add(eMTLSyntaxElement::map_Bump, tex_map_XX("Normal"));
  }

  /**
   * Caller must ensure that the given lookup key exists in the Map.
   * \return Texture map corresponding to the given ID.
   */
  tex_map_XX &tex_map_of_type(const eMTLSyntaxElement key)
  {
    {
      BLI_assert(texture_maps.contains_as(key));
      return texture_maps.lookup_as(key);
    }
  }

  std::string name;
  /* Always check for negative values while importing or exporting. Use defaults if
   * any value is negative. */
  float Ns{-1.0f};
  float3 Ka{-1.0f};
  float3 Kd{-1.0f};
  float3 Ks{-1.0f};
  float3 Ke{-1.0f};
  float Ni{-1.0f};
  float d{-1.0f};
  int illum{-1};
  Map<const eMTLSyntaxElement, tex_map_XX> texture_maps;
  /** Only used for Normal Map node: "map_Bump". */
  float map_Bump_strength{-1.0f};
};

MTLMaterial mtlmaterial_for_material(const Material *material);
}  // namespace blender::io::obj