From 5588e859cbe21a990bde4770eb78596628a905c9 Mon Sep 17 00:00:00 2001 From: Kirill Vainer Date: Tue, 8 Mar 2016 19:32:19 -0500 Subject: [PATCH] MPO: clear param for null textures --- .../main/java/com/jme3/material/Material.java | 32 +++++++++++-------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/jme3-core/src/main/java/com/jme3/material/Material.java b/jme3-core/src/main/java/com/jme3/material/Material.java index 4be24fd29..180cdc544 100644 --- a/jme3-core/src/main/java/com/jme3/material/Material.java +++ b/jme3-core/src/main/java/com/jme3/material/Material.java @@ -788,21 +788,27 @@ public class Material implements CloneableSmartAsset, Cloneable, Savable { private void updateShaderMaterialParameters(Renderer renderer, Shader shader, List overrides) { int unit = 0; - for (MatParamOverride override : overrides) { - VarType type = override.getVarType(); + if (overrides != null) { + for (MatParamOverride override : overrides) { + VarType type = override.getVarType(); - MatParam paramDef = def.getMaterialParam(override.getName()); - if (paramDef == null || paramDef.getVarType() != type || !override.isEnabled()) { - continue; - } + MatParam paramDef = def.getMaterialParam(override.getName()); + if (paramDef == null || paramDef.getVarType() != type || !override.isEnabled()) { + continue; + } - Uniform uniform = shader.getUniform(override.getPrefixedName()); - if (type.isTextureType()) { - renderer.setTexture(unit, (Texture) override.getValue()); - uniform.setValue(VarType.Int, unit); - unit++; - } else { - uniform.setValue(type, override.getValue()); + Uniform uniform = shader.getUniform(override.getPrefixedName()); + if (override.getValue() != null) { + if (type.isTextureType()) { + renderer.setTexture(unit, (Texture) override.getValue()); + uniform.setValue(VarType.Int, unit); + unit++; + } else { + uniform.setValue(type, override.getValue()); + } + } else { + uniform.clearValue(); + } } }