fbx_material.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  1. /**************************************************************************/
  2. /* fbx_material.h */
  3. /**************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* https://godotengine.org */
  7. /**************************************************************************/
  8. /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
  9. /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
  10. /* */
  11. /* Permission is hereby granted, free of charge, to any person obtaining */
  12. /* a copy of this software and associated documentation files (the */
  13. /* "Software"), to deal in the Software without restriction, including */
  14. /* without limitation the rights to use, copy, modify, merge, publish, */
  15. /* distribute, sublicense, and/or sell copies of the Software, and to */
  16. /* permit persons to whom the Software is furnished to do so, subject to */
  17. /* the following conditions: */
  18. /* */
  19. /* The above copyright notice and this permission notice shall be */
  20. /* included in all copies or substantial portions of the Software. */
  21. /* */
  22. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  23. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  24. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
  25. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  26. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  27. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  28. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  29. /**************************************************************************/
  30. #ifndef FBX_MATERIAL_H
  31. #define FBX_MATERIAL_H
  32. #include "tools/import_utils.h"
  33. #include "core/reference.h"
  34. #include "core/ustring.h"
  35. struct FBXMaterial : public Reference {
  36. String material_name = String();
  37. bool warning_non_pbr_material = false;
  38. FBXDocParser::Material *material = nullptr;
  39. /* Godot materials
  40. *** Texture Maps:
  41. * Albedo - color, texture
  42. * Metallic - specular, metallic, texture
  43. * Roughness - roughness, texture
  44. * Emission - color, texture
  45. * Normal Map - scale, texture
  46. * Ambient Occlusion - texture
  47. * Refraction - scale, texture
  48. *** Has Settings for:
  49. * UV1 - SCALE, OFFSET
  50. * UV2 - SCALE, OFFSET
  51. *** Flags for
  52. * Transparent
  53. * Cull Mode
  54. */
  55. enum class MapMode {
  56. AlbedoM = 0,
  57. MetallicM,
  58. SpecularM,
  59. EmissionM,
  60. RoughnessM,
  61. NormalM,
  62. AmbientOcclusionM,
  63. RefractionM,
  64. ReflectionM,
  65. };
  66. /* Returns the string representation of the TextureParam enum */
  67. static String get_texture_param_name(SpatialMaterial::TextureParam param) {
  68. switch (param) {
  69. case SpatialMaterial::TEXTURE_ALBEDO:
  70. return "TEXTURE_ALBEDO";
  71. case SpatialMaterial::TEXTURE_METALLIC:
  72. return "TEXTURE_METALLIC";
  73. case SpatialMaterial::TEXTURE_ROUGHNESS:
  74. return "TEXTURE_ROUGHNESS";
  75. case SpatialMaterial::TEXTURE_EMISSION:
  76. return "TEXTURE_EMISSION";
  77. case SpatialMaterial::TEXTURE_NORMAL:
  78. return "TEXTURE_NORMAL";
  79. case SpatialMaterial::TEXTURE_RIM:
  80. return "TEXTURE_RIM";
  81. case SpatialMaterial::TEXTURE_CLEARCOAT:
  82. return "TEXTURE_CLEARCOAT";
  83. case SpatialMaterial::TEXTURE_FLOWMAP:
  84. return "TEXTURE_FLOWMAP";
  85. case SpatialMaterial::TEXTURE_AMBIENT_OCCLUSION:
  86. return "TEXTURE_AMBIENT_OCCLUSION";
  87. case SpatialMaterial::TEXTURE_DEPTH:
  88. return "TEXTURE_DEPTH";
  89. case SpatialMaterial::TEXTURE_SUBSURFACE_SCATTERING:
  90. return "TEXTURE_SUBSURFACE_SCATTERING";
  91. case SpatialMaterial::TEXTURE_TRANSMISSION:
  92. return "TEXTURE_TRANSMISSION";
  93. case SpatialMaterial::TEXTURE_REFRACTION:
  94. return "TEXTURE_REFRACTION";
  95. case SpatialMaterial::TEXTURE_DETAIL_MASK:
  96. return "TEXTURE_DETAIL_MASK";
  97. case SpatialMaterial::TEXTURE_DETAIL_ALBEDO:
  98. return "TEXTURE_DETAIL_ALBEDO";
  99. case SpatialMaterial::TEXTURE_DETAIL_NORMAL:
  100. return "TEXTURE_DETAIL_NORMAL";
  101. case SpatialMaterial::TEXTURE_MAX:
  102. return "TEXTURE_MAX";
  103. default:
  104. return "broken horribly";
  105. }
  106. };
  107. // TODO make this static?
  108. const std::map<std::string, SpatialMaterial::Feature> fbx_feature_mapping_desc = {
  109. /* Transparent */
  110. { "TransparentColor", SpatialMaterial::Feature::FEATURE_TRANSPARENT },
  111. { "Maya|opacity", SpatialMaterial::Feature::FEATURE_TRANSPARENT }
  112. };
  113. // TODO make this static?
  114. const std::map<std::string, SpatialMaterial::TextureParam> fbx_texture_mapping_desc = {
  115. /* Diffuse */
  116. { "Maya|base", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  117. { "DiffuseColor", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  118. { "Maya|DiffuseTexture", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  119. { "Maya|baseColor", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  120. { "Maya|baseColor|file", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  121. { "3dsMax|Parameters|base_color_map", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  122. { "Maya|TEX_color_map|file", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  123. { "Maya|TEX_color_map", SpatialMaterial::TextureParam::TEXTURE_ALBEDO },
  124. /* Emission */
  125. { "EmissiveColor", SpatialMaterial::TextureParam::TEXTURE_EMISSION },
  126. { "EmissiveFactor", SpatialMaterial::TextureParam::TEXTURE_EMISSION },
  127. { "Maya|emissionColor", SpatialMaterial::TextureParam::TEXTURE_EMISSION },
  128. { "Maya|emissionColor|file", SpatialMaterial::TextureParam::TEXTURE_EMISSION },
  129. { "3dsMax|Parameters|emission_map", SpatialMaterial::TextureParam::TEXTURE_EMISSION },
  130. { "Maya|TEX_emissive_map", SpatialMaterial::TextureParam::TEXTURE_EMISSION },
  131. { "Maya|TEX_emissive_map|file", SpatialMaterial::TextureParam::TEXTURE_EMISSION },
  132. /* Metallic */
  133. { "Maya|metalness", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  134. { "Maya|metalness|file", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  135. { "3dsMax|Parameters|metalness_map", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  136. { "Maya|TEX_metallic_map", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  137. { "Maya|TEX_metallic_map|file", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  138. { "SpecularColor", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  139. { "Maya|specularColor", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  140. { "Maya|SpecularTexture", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  141. { "Maya|SpecularTexture|file", SpatialMaterial::TextureParam::TEXTURE_METALLIC },
  142. /* Roughness */
  143. // Arnold Roughness Map
  144. { "Maya|specularRoughness", SpatialMaterial::TextureParam::TEXTURE_ROUGHNESS },
  145. { "3dsMax|Parameters|roughness_map", SpatialMaterial::TextureParam::TEXTURE_ROUGHNESS },
  146. { "Maya|TEX_roughness_map", SpatialMaterial::TextureParam::TEXTURE_ROUGHNESS },
  147. { "Maya|TEX_roughness_map|file", SpatialMaterial::TextureParam::TEXTURE_ROUGHNESS },
  148. /* Normal */
  149. { "NormalMap", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  150. //{ "Bump", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  151. //{ "3dsMax|Parameters|bump_map", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  152. { "Maya|NormalTexture", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  153. //{ "Maya|normalCamera", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  154. //{ "Maya|normalCamera|file", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  155. { "Maya|TEX_normal_map", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  156. { "Maya|TEX_normal_map|file", SpatialMaterial::TextureParam::TEXTURE_NORMAL },
  157. /* AO */
  158. { "Maya|TEX_ao_map", SpatialMaterial::TextureParam::TEXTURE_AMBIENT_OCCLUSION },
  159. { "Maya|TEX_ao_map|file", SpatialMaterial::TextureParam::TEXTURE_AMBIENT_OCCLUSION },
  160. //{ "Maya|diffuseRoughness", SpatialMaterial::TextureParam::UNSUPPORTED },
  161. //{ "Maya|diffuseRoughness|file", SpatialMaterial::TextureParam::UNSUPPORTED },
  162. //{ "ShininessExponent", SpatialMaterial::TextureParam::UNSUPPORTED },
  163. //{ "ReflectionFactor", SpatialMaterial::TextureParam::UNSUPPORTED },
  164. //{ "TransparentColor",SpatialMaterial::TextureParam::TEXTURE_CHANNEL_ALPHA },
  165. //{ "TransparencyFactor",SpatialMaterial::TextureParam::TEXTURE_CHANNEL_ALPHA }
  166. };
  167. // TODO make this static?
  168. enum PropertyDesc {
  169. PROPERTY_DESC_NOT_FOUND,
  170. PROPERTY_DESC_ALBEDO_COLOR,
  171. PROPERTY_DESC_TRANSPARENT,
  172. PROPERTY_DESC_METALLIC,
  173. PROPERTY_DESC_ROUGHNESS,
  174. PROPERTY_DESC_SPECULAR,
  175. PROPERTY_DESC_SPECULAR_COLOR,
  176. PROPERTY_DESC_SHINYNESS,
  177. PROPERTY_DESC_COAT,
  178. PROPERTY_DESC_COAT_ROUGHNESS,
  179. PROPERTY_DESC_EMISSIVE,
  180. PROPERTY_DESC_EMISSIVE_COLOR,
  181. PROPERTY_DESC_IGNORE
  182. };
  183. const std::map<std::string, PropertyDesc> fbx_properties_desc = {
  184. /* Albedo */
  185. { "DiffuseColor", PROPERTY_DESC_ALBEDO_COLOR },
  186. { "Maya|baseColor", PROPERTY_DESC_ALBEDO_COLOR },
  187. /* Specular */
  188. { "Maya|specular", PROPERTY_DESC_SPECULAR },
  189. { "Maya|specularColor", PROPERTY_DESC_SPECULAR_COLOR },
  190. /* Specular roughness - arnold roughness map */
  191. { "Maya|specularRoughness", PROPERTY_DESC_ROUGHNESS },
  192. /* Transparent */
  193. { "Opacity", PROPERTY_DESC_TRANSPARENT },
  194. { "TransparencyFactor", PROPERTY_DESC_TRANSPARENT },
  195. { "Maya|opacity", PROPERTY_DESC_TRANSPARENT },
  196. /* Metallic */
  197. { "Shininess", PROPERTY_DESC_METALLIC },
  198. { "Reflectivity", PROPERTY_DESC_METALLIC },
  199. { "Maya|metalness", PROPERTY_DESC_METALLIC },
  200. { "Maya|metallic", PROPERTY_DESC_METALLIC },
  201. /* Roughness */
  202. { "Maya|roughness", PROPERTY_DESC_ROUGHNESS },
  203. /* Coat */
  204. //{ "Maya|coat", PROPERTY_DESC_COAT },
  205. /* Coat roughness */
  206. //{ "Maya|coatRoughness", PROPERTY_DESC_COAT_ROUGHNESS },
  207. /* Emissive */
  208. { "Maya|emission", PROPERTY_DESC_EMISSIVE },
  209. { "Maya|emissive", PROPERTY_DESC_EMISSIVE },
  210. /* Emissive color */
  211. { "EmissiveColor", PROPERTY_DESC_EMISSIVE_COLOR },
  212. { "Maya|emissionColor", PROPERTY_DESC_EMISSIVE_COLOR },
  213. /* Ignore */
  214. { "Maya|diffuseRoughness", PROPERTY_DESC_IGNORE },
  215. { "Maya", PROPERTY_DESC_IGNORE },
  216. { "Diffuse", PROPERTY_DESC_ALBEDO_COLOR },
  217. { "Maya|TypeId", PROPERTY_DESC_IGNORE },
  218. { "Ambient", PROPERTY_DESC_IGNORE },
  219. { "AmbientColor", PROPERTY_DESC_IGNORE },
  220. { "ShininessExponent", PROPERTY_DESC_IGNORE },
  221. { "Specular", PROPERTY_DESC_IGNORE },
  222. { "SpecularColor", PROPERTY_DESC_IGNORE },
  223. { "SpecularFactor", PROPERTY_DESC_IGNORE },
  224. //{ "BumpFactor", PROPERTY_DESC_IGNORE },
  225. { "Maya|exitToBackground", PROPERTY_DESC_IGNORE },
  226. { "Maya|indirectDiffuse", PROPERTY_DESC_IGNORE },
  227. { "Maya|indirectSpecular", PROPERTY_DESC_IGNORE },
  228. { "Maya|internalReflections", PROPERTY_DESC_IGNORE },
  229. { "DiffuseFactor", PROPERTY_DESC_IGNORE },
  230. { "AmbientFactor", PROPERTY_DESC_IGNORE },
  231. { "ReflectionColor", PROPERTY_DESC_IGNORE },
  232. { "Emissive", PROPERTY_DESC_IGNORE },
  233. { "Maya|coatColor", PROPERTY_DESC_IGNORE },
  234. { "Maya|coatNormal", PROPERTY_DESC_IGNORE },
  235. { "Maya|coatIOR", PROPERTY_DESC_IGNORE },
  236. };
  237. struct TextureFileMapping {
  238. SpatialMaterial::TextureParam map_mode = SpatialMaterial::TEXTURE_ALBEDO;
  239. String name = String();
  240. const FBXDocParser::Texture *texture = nullptr;
  241. };
  242. /* storing the texture properties like color */
  243. template <class T>
  244. struct TexturePropertyMapping : Reference {
  245. SpatialMaterial::TextureParam map_mode = SpatialMaterial::TextureParam::TEXTURE_ALBEDO;
  246. const T property = T();
  247. };
  248. static void add_search_string(String p_filename, String p_current_directory, String search_directory, Vector<String> &texture_search_paths);
  249. static String find_texture_path_by_filename(const String p_filename, const String p_current_directory);
  250. String get_material_name() const;
  251. void set_imported_material(FBXDocParser::Material *p_material);
  252. struct MaterialInfo {
  253. Vector<TextureFileMapping> textures;
  254. Vector<SpatialMaterial::Feature> features;
  255. };
  256. /// Extracts the material information.
  257. MaterialInfo extract_material_info(const FBXDocParser::Material *material) const;
  258. Ref<SpatialMaterial> import_material(ImportState &state);
  259. };
  260. #endif // FBX_MATERIAL_H