v4.0
Creates and adds a UserDataBlob or CustomProperty to a Source object.
oReturn = Source.AddProperty( Preset, [BranchFlag], [Name] ); |
CustomProperty, UserDataBlob or UserDataMap, depending on the preset that was used.
Parameter | Type | Description |
---|---|---|
Preset | String | This argument contains either the name of a Property Preset or a string with
the filename or full path to a Preset file. Note: Only CustomProperty Presets, UserDataBlob Presets, and UserDataMap Presets are valid for sources. The type of property that is created is determined by this argument. For example, "CustomProperty" creates an empty CustomProperty and "UserDataBlob" creates a UserDataBlob. |
BranchFlag | Boolean | False is the only supported value
Default Value: false |
Name | String | Represents the name of the new property (see SIObject.Name). If not specified the object is named based on the Preset argument. |
/* This example shows how to add user data to a shape source */ // First build a simple scene NewScene( null, false ); var oCone = ActiveSceneRoot.AddGeometry( "Cone", "MeshSurface" ); // Set up the time in seconds var oPlayCtrl = GetValue("PlayControl"); var dFrameRate = oPlayCtrl.Parameters("Rate").Value; var dTime = 1.0 * dFrameRate; // start at the beginning // Using SaveShapeKey stores the source and applies the clip simultaneously var aIndices = new Array( 1,4,7,10,13,16,19,22,25 ); var aPositions = new Array( /* X, Y, Z */ 0, 1.6667, 0, // point 1 -0.5, -0.5, 0, // point 4 -0.3536, -0.5, -0.3536, // point 7 0, -0.5, 0.5, // point 10 0.3536, -0.5, 0.3536, // point 13 0.5, -0.5, 0, // point 16 0.3536, -0.5, -0.3536, // point 19 0, -0.5, -0.5, // point 22 -0.3536, -0.5, -0.3536 // point 25 ); var oShapeClip = oCone.ActivePrimitive.Geometry.SaveShapeKey( dTime, // Time (when to evaluate) -1, // ClipDuration siShapeObjectReferenceMode, // RefMode (shape ref. mode) siShapeMixedWeightMode, // InstMode (shape inst. mode) "MyNewShape", // Name for shape aIndices, // IndexArray (point indices) aPositions // PositionArray (key positions) ); // Add a CustomProperty nested under the Source of the 1st clip var oShapeSource = oShapeClip.Source; var oShapePSet = oShapeSource.AddProperty( "CustomProperty",false, "ShapePSet" ); oShapePSet.AddParameter3( "Foo", siString ) ; // Add a UserDataBlob nested under the ShapeSource var oShapeUserDataBlob = oShapeSource.AddProperty( "UserDataBlob" ); LogMessage( "There are " + oShapeSource.Properties.Count + " Properties under this Shape Source" ) ; // Expected result: //INFO : There are 2 Properties under this Shape Source |