diff options
author | Bastien Montagne <montagne29@wanadoo.fr> | 2019-05-15 21:58:18 +0300 |
---|---|---|
committer | Bastien Montagne <montagne29@wanadoo.fr> | 2019-05-15 21:59:58 +0300 |
commit | f9784ea6afa70d4105901af5c00e6da09e6f7f98 (patch) | |
tree | 13d6e642ea2f03f14ed557e7b938b570a1e8e277 /release/scripts/modules/bpy_extras/node_shader_utils.py | |
parent | 9baf669493cfd023c467a273482d0a1a2d6a767b (diff) |
Py NodeShader wrapper helper: add support for new Alpha setting of Principled BSDF.
Now that we have real alpha in BSDF, it's much better option for
transparency, than previously used Transmission value.
Related to T64609.
Diffstat (limited to 'release/scripts/modules/bpy_extras/node_shader_utils.py')
-rw-r--r-- | release/scripts/modules/bpy_extras/node_shader_utils.py | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/release/scripts/modules/bpy_extras/node_shader_utils.py b/release/scripts/modules/bpy_extras/node_shader_utils.py index 9a3900bd58b..390feba6ae4 100644 --- a/release/scripts/modules/bpy_extras/node_shader_utils.py +++ b/release/scripts/modules/bpy_extras/node_shader_utils.py @@ -446,8 +446,32 @@ class PrincipledBSDFWrapper(ShaderWrapper): transmission_texture = property(transmission_texture_get) - # TODO: Do we need more complex handling for alpha (allowing masking and such)? - # Would need extra mixing nodes onto Base Color maybe, or even its own shading chain... + def alpha_get(self): + if not self.use_nodes or self.node_principled_bsdf is None: + return 1.0 + return self.node_principled_bsdf.inputs["Alpha"].default_value + + @_set_check + def alpha_set(self, value): + if self.use_nodes and self.node_principled_bsdf is not None: + self.node_principled_bsdf.inputs["Alpha"].default_value = value + + alpha = property(alpha_get, alpha_set) + + + # Will only be used as gray-scale one... + def alpha_texture_get(self): + if not self.use_nodes or self.node_principled_bsdf is None: + return None + return ShaderImageTextureWrapper( + self, self.node_principled_bsdf, + self.node_principled_bsdf.inputs["Alpha"], + grid_row_diff=-1, + ) + + alpha_texture = property(alpha_texture_get) + + # -------------------------------------------------------------------- # Normal map. |