ClusterElementCollection.ItemsByIndex operator

Description

Sets or returns cluster element values by index.

In the case of a Clusters this provides read-only access to a 1-dimensional Array of the associated geometry indices (Integers) for the requested cluster indices. The size of this array is the same as the number of requested indices.

In the case of a ClusterProperty, this allows you to get or set a 2-dimensional Array containing the data on the requested cluster indices (Doubles). The size of the first dimension depends on the ClusterProperty. For example for a weight map there is only 1 element but for an envelope weight map the size is equal to the number of deformers. The size of the second dimension is the same as the number of requested indices.

C# Syntax

// get accessor

Object ClusterElementCollection.get_ItemsByIndex( Object vIndices );

// set accessor

ClusterElementCollection.set_ItemsByIndex( Object vIndices, Object pVal );

Parameters

Parameter Type Description
Indices Array Array of element indicies

Examples

1. VBScript Example

'

' This example shows how to use ItemsByIndex on a Cluster

'

dim oRoot, oGrid, oCluster, aValues, iElement

set oRoot = Application.ActiveProject.ActiveScene.Root

set oGrid = oRoot.AddGeometry("Grid","MeshSurface")

set oCluster = oGrid.ActivePrimitive.Geometry.AddCluster( _

					siPolygonCluster, "PolygonClusterOnGrid", _

					array(59,60,61))

'Ask for items 0,1,2 of the cluster - which corresponds to

'pnt 59,60,61.  In fact this is the entire cluster.

aValues = oCluster.Elements.ItemsByIndex( Array(0,1,2) )

'Show the ranges of the returned 1-dimensional array

LogMessage "lbound(aValues,1) = " & lbound(aValues,1)

LogMessage "ubound(aValues,1) = " & ubound(aValues,1)

'Print out the geometry indices of the requested cluster

'elements

for iIndex=lbound(aValues,1) to ubound(aValues,1)

	iElement = aValues(iIndex)

	LogMessage "element(" & iIndex & ") = " & _

			oCluster.type & "(" & iElement & ") "

next

' Output of above script:

'INFO : "lbound(aValues,1) = 0"

'INFO : "ubound(aValues,1) = 2"

'INFO : "element(0) = poly(59) "

'INFO : "element(1) = poly(60) "

'INFO : "element(2) = poly(61) "

2. VBScript Example

'

' This example demonstrates how to use ClusterElementCollection.ItemsByIndex to read 

' and write values on a VertexColor ClusterProperty object

'

NewScene ,false

set oSphere = ActiveSceneRoot.AddGeometry("Sphere","MeshSurface")

SelectObj oSphere

'This command will create a complete sample cluster

'and a cluster property called MyVertexColor

CreateVertexColorSupport , "MyVertexColor"

set oClusters = oSphere.ActivePrimitive.Geometry.Clusters

set oVertexColors = oClusters(0).LocalProperties( "MyVertexColor" )

'Get the RGB values on sample point 2 and 3.

'This returns a 2-dimensional array, with the RGBA values

'for the two samples we request.

ElArray = oVertexColors.Elements.ItemsByIndex( Array( 2, 3 ) )

'Set the G value at Sample 2

ElArray( 1, 0 ) = 0.0

'Set the B value at Sample 2

ElArray( 2, 0 ) = 0.5

'Set the R value at Sample 3

ElArray( 0, 1 ) = 0.3

'Set the A value at Sample 3

ElArray( 3, 1 ) = 0.2

'Assign our changes back

oVertexColors.Elements.ItemsByIndex( Array( 2, 3 ) ) = ElArray

'Double check by looking at the entire array

AllRGBAValues = oVertexColors.Elements.Array

logmessage "G Value at Sample 2: " & Round( AllRGBAValues( 1, 2 ), 1 )

logmessage "B Value at Sample 2: " & Round( AllRGBAValues( 2, 2 ), 1 )

logmessage "R Value at Sample 3: " & Round( AllRGBAValues( 0, 3 ), 1 )

logmessage "A Value at Sample 3: " & Round( AllRGBAValues( 3, 3 ), 1 )

'Output of this script:

'INFO : "G Value at Sample 2: 0"

'INFO : "B Value at Sample 2: 0.5"

'INFO : "R Value at Sample 2: 0.3"

'INFO : "A Value at Sample 2: 0.2"