Envelope.GetWeights2

Introduced

v6.0

Description

Returns a ClusterElementCollection object containing the deformer weights for the envelope. The ClusterElementCollection.Array property provides access to a 2-dimensional array, where the first dimension maps to the Envelope.Deformers and the second dimension maps to the cluster elements.

Note: This is the Python-compliant version of the Envelope.Weights. Since Python does not support input parameters on properties, Envelope.Weights will fail in Python.

C# Syntax

ClusterElementCollection Envelope.GetWeights2( Object );

Scripting Syntax

oReturn = Envelope.GetWeights2( [Time] );

Return Value

ClusterElementCollection

Parameters

Parameter Type Description
Time Double Time (in frames) at which to get property

Default Value: Current time in frames

Examples

C# Example

/*
	C# version of the Envelope.Weights examples,
	demonstrating how to deform a sphere
	and access the weights on each vertex
*/
CXSIApplicationClass app = new CXSIApplicationClass();
// Set up some null objects to be used for passing default values
object dummy = null;
Object[] args = new Object[2];
args[1] = false;
app.ExecuteCommand("NewScene", args);
Model oRoot = app.ActiveSceneRoot;
Object[] aRootPos = new Object[3] { 0.254, 3.998, 0.045 };
Object[] aEffPos1 = new Object[3] { -0.01, -0.056, -2.972 };
Object[] aEffPos2 = new Object[3] { 0.183, -3.999, 0.115 };
// Create the Skeleton
ChainRoot oChain1 = oRoot.Add2DChain(aRootPos, aEffPos1, dummy, si2DChainAlignType.si2DChainTop, "");
ChainBone oChain2 = oChain1.AddBone(aEffPos2, siChainBoneType.siChainBonePin, "");
// Create the Envelope
X3DObject oSphere = oRoot.AddGeometry("Sphere", "MeshSurface", "");
oSphere.Parameters["subdivu"].PutValue2(dummy, 2);
oSphere.Parameters["subdivv"].PutValue2(dummy, 2);
Geometry oGeometry = oSphere.ActivePrimitive.GetGeometry2(dummy, siConstructionMode.siConstructionModeDefault);
// Apply the Envelope to the Skeleton
Envelope oEnvelope = oSphere.ApplyEnvelope(oChain1, siBranchFlag.siBranch, siBranchFlag.siBranch);
// Weights are represented as a 2-dimensional array, which are supported
// by the Array class in C#, just cast the returned object into an Array
// and use the Array class's access members (same idea as in VBScript)
ClusterElementCollection oWeights = oEnvelope.GetWeights2(dummy);
Array aWeightValues = (Array)oWeights.Array;
for (int iElement = aWeightValues.GetLowerBound(1); iElement < aWeightValues.GetLength(1); iElement++)
{
	string strElementWeights = "";
	for (int iDeformer = aWeightValues.GetLowerBound(0); iDeformer < aWeightValues.GetLength(0); iDeformer++)
	{
		double dCurrWeight = (double)aWeightValues.GetValue(iDeformer, iElement);
		double dRndWeight = Math.Round(dCurrWeight);
		strElementWeights = strElementWeights + dRndWeight.ToString() + ",";
	}
	// Trip the final comma from the string
	strElementWeights.Remove(strElementWeights.Length-1, 1);
	app.LogMessage("weight (" + iElement.ToString() + ") = " + strElementWeights, siSeverity.siInfo);
}
// Output of the script is this:
//INFO : "weight(0) = 0,0,100,0"
//INFO : "weight(1) = 0,100,0,0"
//INFO : "weight(2) = 0,50,50,0"
//INFO : "weight(3) = 0,50,50,0"
//INFO : "weight(4) = 0,50,50,0"

See Also

Envelope.Weights