Material.AddSharedTextureLayer

Introduced

v4.0

Description

Adds an existing texture layer to the container. The layer already belongs to at least one other texture layer container (either Shader or Material).

A texture layer is an object which simplifies layering of texture effects on top of shaders and materials. Each layer has a set of properties which describe its characteristics (such as color, mixing mode, weight) to specify how it will affect the shader ports it drives. The order that layers appear under a container indicates the order the layering is applied, similar to the way a "mix N colors" shader node works. Texture layer port objects (see TextureLayer.AddTextureLayerPort) are owned by layers, and are used to specify which shader ports the layer should affect.

A Shader can also be a texture layer container, and has the same set of related methods.

Scripting Syntax

Material.AddSharedTextureLayer( Layer, [After], [Reference] );

Parameters

Parameter Type Description
Layer TextureLayer or String Texture layer to add to this container.
After Boolean True to insert the new texture layer after the reference layer. False to insert it before. If no reference layer, then True will add at the end of the container's list, False will add it at the start.

Default Value: True

Reference TextureLayer or String Reference texture layer, to indicate where the newly-added layer should be located in the stack. The layer will be inserted adjacent to (before or after) the reference layer. If not specified, then the new layer will be added at the beginning or the end, depending on the value of the following argument.

Examples

1. JScript Example

/*
        This example shows how to create and share texture layers.  
        It also shows how both Shaders and Materials can be texture 
        layer containers, and the same layer can drive ports on 
        each of them (if desired).
*/
oRoot = ActiveProject.ActiveScene.Root;
oSph = oRoot.AddGeometry( "Sphere", "MeshSurface" );
oMat = oSph.AddMaterial( "Phong" );
oPhong = oMat.Shaders(0);
// Add a layer to the Phong.
oShared = oPhong.CreateTextureLayer( "SharedLayer" );
// Add an unshared layer to the Material.
oRough = oMat.CreateTextureLayer( "Rough" );
// Add the first layer to the material, thereby sharing it.
// We'll put it before the Rough layer.
oMat.AddSharedTextureLayer( oShared, false, oRough );
// Now for fun, let's create a Fractal, attach it to the
// color input of the shared layer, and make it drive
// both the Phong's diffuse and the Material's displacement.
oParam = Application.Dictionary.GetObject( oShared + ".color" );
oFractal = oParam.ConnectFromPreset( "Fractal", siTextureShaderFamily );
oDiffuse = oShared.AddTextureLayerPort( oPhong.Parameters( "diffuse" ) );
oDispl = oShared.AddTextureLayerPort( oMat.Parameters( "displacement" ) );
// Now let's explore what we have created...
DumpTextureLayerContainer( oMat );
function DumpTextureLayerContainer( in_cont )
{
        Application.LogMessage( "CONTAINER: " + in_cont.Name );
        for ( var i = 0; i < in_cont.TextureLayers.Count; i++ )
        {
                oTextureLayer = in_cont.TextureLayers(i);
                DumpTextureLayer( oTextureLayer, i+1 );
        }
}
function DumpTextureLayer( in_layer, in_index )
{
        Application.LogMessage( "   Layer " + in_index + ": " + in_layer.Name );
        oColorSrc = in_layer.color.source;
        var empty;
        if ( oColorSrc == empty )
        {
                Application.LogMessage( "     Color: (" + in_layer.Red.Value +
                                                "," + in_layer.Green.Value +
                                                "," + in_layer.Blue.Value + ")" );
        }
        else
        {
                Application.LogMessage( "     Color driven by: " + oColorSrc.Name );
        }
        oPorts = in_layer.TextureLayerPorts;
        count = oPorts.Count;
        Application.LogMessage( "     Layer drives:" );
        if ( count == 0 )
                Application.LogMessage( "       <nothing>" );
        else
        {
                for ( i = 0; i < count; i++ )
                {
                        Application.LogMessage( "       " + oPorts(i).Target.FullName );
                }
        }
}
// This example should log something like:
//INFO : "CONTAINER: Material"
//INFO : "   Layer 1: SharedLayer"
//INFO : "     Color driven by: Fractal"
//INFO : "     Layer drives:"
//INFO : "       sphere.Material.Phong.diffuse"
//INFO : "       sphere.Material.Color2scalar.input"
//INFO : "   Layer 2: Rough"
//INFO : "     Color: (0.7,0.7,0.7)"
//INFO : "     Layer drives:"
//INFO : "       <nothing>"

2. VBScript Example

'
' This example shows how to create and share texture layers.  
' It also shows how both Shaders and Materials can be texture 
' layer containers, and the same layer can drive ports on each 
' of them (if desired).
'
set oRoot = ActiveProject.ActiveScene.Root
set oSph = oRoot.AddGeometry( "Sphere", "MeshSurface" )
set oMat = oSph.AddMaterial( "Phong" )
set oPhong = oMat.Shaders(0)
' Add a layer to the Phong.
set oShared = oPhong.CreateTextureLayer( "SharedLayer" )
' Add an unshared layer to the Material.
set oRough = oMat.CreateTextureLayer( "Rough" )
' Add the first layer to the material, thereby sharing it.
' We'll put it before the Rough layer.
oMat.AddSharedTextureLayer oShared, False, oRough
' Now for fun, let's create a Fractal, attach it to the
' color input of the shared layer, and make it drive
' both the Phong's diffuse and the Material's displacement.
set oParam = Dictionary.GetObject( oShared & ".color" )
set oFractal = oParam.ConnectFromPreset( "Fractal", siTextureShaderFamily )
set oDiffuse = oShared.AddTextureLayerPort( oPhong.Parameters( "diffuse" ) )
set oDispl = oShared.AddTextureLayerPort( oMat.Parameters( "displacement" ) )
' Now let's explore what we have created...
DumpTextureLayerContainer oMat
sub DumpTextureLayerContainer( in_cont )
        Application.LogMessage "CONTAINER: " & in_cont.Name
        i = 1
        for each oTextureLayer in in_cont.TextureLayers
                DumpTextureLayer oTextureLayer, i
                i = i + 1
        next
end sub
sub DumpTextureLayer( in_layer, in_index )
        Application.LogMessage "   Layer " & in_index & ": " & in_layer.Name
        set oColorSrc = in_layer.color.source
        if TypeName( oColorSrc ) = "Nothing" then
                Application.LogMessage "     Color: (" & in_layer.Red.Value & _
                                                "," & in_layer.Green.Value & _
                                                "," & in_layer.Blue.Value & ")"
        else
                Application.LogMessage "     Color driven by: " & oColorSrc.Name
        end if
        set oPorts = in_layer.TextureLayerPorts
        count = oPorts.Count
        if count = 0 then
                Application.LogMessage "     <layer driving no ports>"
        else
                Application.LogMessage "     Layer drives:"
                for i = 0 to count - 1
                        Application.LogMessage "       " & oPorts(i).Target.FullName
                next                            
        end if
end sub
' This example should log something like:
'INFO : "CONTAINER: Material"
'INFO : "   Layer 1: SharedLayer"
'INFO : "     Color driven by: Fractal"
'INFO : "     Layer drives:"
'INFO : "       sphere.Material.Phong.diffuse"
'INFO : "       sphere.Material.Color2scalar.input"
'INFO : "   Layer 2: Rough"
'INFO : "     Color: (0.7,0.7,0.7)"
'INFO : "     <layer driving no ports>"

See Also

AddTextureLayer Material.CreateTextureLayer Shader.CreateTextureLayer Shader.AddSharedTextureLayer