From 9ae13052cce3390b4b96a0c595847f0ac4775f41 Mon Sep 17 00:00:00 2001 From: Benau Date: Sat, 1 Dec 2018 15:15:44 +0800 Subject: [PATCH] Use full path for default SP material if possible --- src/graphics/material_manager.cpp | 16 ++++++++++------ src/graphics/material_manager.hpp | 4 +++- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/src/graphics/material_manager.cpp b/src/graphics/material_manager.cpp index 421d86f61..6543c2833 100644 --- a/src/graphics/material_manager.cpp +++ b/src/graphics/material_manager.cpp @@ -90,16 +90,17 @@ Material* MaterialManager::getMaterialSPM(std::string lay_one_tex_lc, std::string lay_two_tex_lc, const std::string& def_shader_name) { - std::string orignal_layer_one = lay_one_tex_lc; + std::string original_layer_one = lay_one_tex_lc; core::stringc lc(lay_one_tex_lc.c_str()); lc.make_lower(); lay_one_tex_lc = lc.c_str(); lc = lay_two_tex_lc.c_str(); lc.make_lower(); lay_two_tex_lc = lc.c_str(); - if (!lay_one_tex_lc.empty() && + const bool is_full_path = !lay_one_tex_lc.empty() && (lay_one_tex_lc.find('/') != std::string::npos || - lay_one_tex_lc.find('\\') != std::string::npos)) + lay_one_tex_lc.find('\\') != std::string::npos); + if (is_full_path) { // Search backward so that temporary (track) textures are found first for (int i = (int)m_materials.size() - 1; i >= 0; i--) @@ -143,7 +144,9 @@ Material* MaterialManager::getMaterialSPM(std::string lay_one_tex_lc, } // for i } return getDefaultSPMaterial(def_shader_name, - StringUtils::getBasename(orignal_layer_one)); + is_full_path ? + original_layer_one : StringUtils::getBasename(original_layer_one), + is_full_path); } //----------------------------------------------------------------------------- @@ -211,7 +214,8 @@ void MaterialManager::setAllMaterialFlags(video::ITexture* t, //----------------------------------------------------------------------------- Material* MaterialManager::getDefaultSPMaterial(const std::string& shader_name, - const std::string& l1_lc) + const std::string& l1_lc, + bool full_path) { core::stringc lc(l1_lc.c_str()); lc.make_lower(); @@ -222,7 +226,7 @@ Material* MaterialManager::getDefaultSPMaterial(const std::string& shader_name, return ret->second; } Material* m = new Material(l1_lc.empty() ? "unicolor_white" : - l1_lc, false, false, false, shader_name); + l1_lc, full_path, false, false, shader_name); m_default_sp_materials[key] = m; return m; } // getDefaultSPMaterial diff --git a/src/graphics/material_manager.hpp b/src/graphics/material_manager.hpp index fbf8f6e6d..eaf8872d4 100644 --- a/src/graphics/material_manager.hpp +++ b/src/graphics/material_manager.hpp @@ -83,7 +83,9 @@ public: void unloadAllTextures(); - Material* getDefaultSPMaterial(const std::string& shader_name, const std::string& layer_one_lc = ""); + Material* getDefaultSPMaterial(const std::string& shader_name, + const std::string& layer_one_lc = "", + bool full_path = false); Material* getLatestMaterial() { return m_materials[m_materials.size()-1]; } }; // MaterialManager