CreateCommand (XSIApplication)
Description
Defines a new custom command in Softimage. A new Command object is returned and can be used to define the command. This definition includes the location of the implementation (Command.FileName), and the arguments that command takes (ArgumentCollection.Add). After the definition of the command has been completed the XSIApplication.AddCommand method must be called to actually register the command in Softimage.
Note: The recommended way to create custom commands is to define them as part of a self-installed plug-in. See PluginRegistrar.RegisterCommand.
Scripting Syntax
XSIApplication.CreateCommand( Name, [Category] )
C# Syntax
Command XSIApplication.CreateCommand( String in_name, siCommandCategory in_category );Parameters
|
Parameter |
Type |
Description |
|
Name |
The unique name identifying the new command. Note: The command is not created if one with this name already exists. |
|
|
Category |
Where (on which Softimage standard menu) the command will appear in the user interface. For more information, see the siCommandCategory enum documentation. |
Return Value
Examples
JScript Example
//------------------------------------------------------------------- // This example defines & runs a custom command examples // // // README: Copy and paste the example into the script editor // and run (F5). // // The command will be listed in the customize toolbar dialog in // the 'Custom Commands' group. //------------------------------------------------------------------- function ExCreateCommandDemo() { Application.RemoveCommand("XYZ"); var cmd = Application.CreateCommand("XYZ"); cmd.Description = "XYZ custom command."; cmd.ScriptingName = "XYZ"; cmd.Handler = "OnXYZCommand"; cmd.FileName = filename; cmd.Language = "JScript"; cmd.Arguments.Add( "argument0" ); Application.AddCommand( cmd ); // call command XYZ( "this is a string argument" ); } // This sample defines the XYZ command's function handler" function OnXYZCommand( in_arg ) { LogMessage( "Executing XYZ command with the argument: " + in_arg ); } //-------------------------------------------------------------------- // Code to bootstrap example into system //-------------------------------------------------------------------- function ExampleSourceCode() { return "//XSISDK Doc Example\n" + OnXYZCommand.toString(); } // if we are running from script editor save code to // examples addon folder in the user's directory. if (GetUserPref("ScriptingSessionActive")) { var ex_name = "ExXSIApplicationCreateCommand"; var ex_subfolder = "Scripts"; var ex_folder = "XSISDKDocExamples"; var ex_langsuffix = ".js"; CreateAddonDirectories( InstallationPath(siUserPath), ex_folder ); var fso = XSIFactory.CreateActiveXObject("Scripting.FileSystemObject"); var filename = XSIUtils.BuildPath( InstallationPath(siUserAddonPath), ex_folder, "Data", ex_subfolder, ex_name+ex_langsuffix ); if (!fso.FileExists(filename)) { var f = fso.CreateTextFile ( filename ); f.write( ExampleSourceCode() ); f.close(); } // run demo ExCreateCommandDemo(); }
See Also
Autodesk Softimage v7.5