User Tools

Site Tools


Callback - Renderer Property Map Changed, Update Element Property

Summary

The script on this page is included by a script embedded within, and executed by, a DzCallBack that is connected to the mapChanged() signal on a DzNumericProperty, which resides on a DzElement that provides access to controls for a DzRenderer. Several variables used in this script are assumed to be defined in the script that includes this script.

The purpose of this script is to find a (predefined) target property, compare the map value of that property with the map value of the property that invoked the callback, and either update the map value of the target property (if it does not already match) or break the infinite loop that is created by causing the mapChanged() signal to be emitted in sequential succession.

See Also: Element Post-Load Create Callbacks

API Areas of Interest

Example

Callback_mapChanged.dsa
// Define an anonymous function;
// limits the scope of variables
(function(){
 
	// 'CallBack' is a global transient variable, available when
	// this script is executed by a DzCallBack
 
	// If we did not find the 'CallBack' global transient;
	// this script was executed outside the context of a DzCallBack	
	if( typeof( CallBack ) == "undefined" ){
		// We are done...
		return;
	}
 
	// Get the object that prompted the callback
	var oSender = CallBack.getSender();
	// If we do not have a sender or the sender is not a property
	if( !oSender || !oSender.inherits( "DzNumericProperty" ) ){
		// We are done...
		return;
	}
 
	// oScript, sBasePath, and sProperty are assumed to be defined in the script
	// that includes this script; i.e., the CallBack
	// created in Callbacks_Element_Post_Load_Create.ds*
 
	// Get the path of the FindProperty script. Doing it this way, we can debug
	// with an ascii file and ship a binary [encrypted] file with the same
	// name... without having to update the contents of the script or manually
	// handle the file extensions.
	var sFindPropertyPath = oScript.getScriptFile( "%1/FindProperty".arg( sBasePath ) );
	// If the script was not found
	if( sFindPropertyPath.isEmpty() ){
		// We are done...
		return;
	}
 
	// Include the FindProperty script
	include( sFindPropertyPath );
 
	// If the element was not found
	if( !oElement ){
		// We are done...
		return;
	}
 
	// Find the property
	var oProperty = findElementProperty( oElement, sProperty, false );
	// If the property was not found
	if( !oProperty ){
		// We are done...
		return;
	}
 
	// Get the value of the sender
	var oTexture = oSender.getMapValue();
 
	// If the value of the target is the same as the source
	if( !pointersAreEqual( oProperty.getMapValue(), oTexture ) ){
		// Update the value of the target with the sender's value
		oProperty.setMap( oTexture );
	}
 
// Finalize the function and invoke
})();