Argument

Object Hierarchy | Related C++ Class: Argument

Inheritance

SIObject

Argument

Introduced

v2.0

Description

The Argument object represents an argument (or "parameter") of a Softimage Command. For example the DeleteObj command takes 1 argument ("InputObj"). You add arguments to custom commands using the ArgumentCollection.Add, ArgumentCollection.AddWithHandler or ArgumentCollection.AddObjectArgument method.

Argument objects are used in three circumstances in Softimage:

- For defining command arguments at creation time When a command is created, arguments are added to the Command object and the Argument.Value is set to define the default value for that argument. This default value is persisted and is used as the argument value in the case that no value is specified at invocation time.

- For specifying argument values when invoking a command. When a command is invoked, Argument.Value is used to specify the value of the argument that will be passed to the command. You may also define an ArgumentHandler to get a default value based on the selection or the scene content. You can create an argument with a handler using the ArgumentCollection.AddWithHandler method.

-In the third case it is possible to change the definition of a custom command after it has been installed. In this case Argument.Value is used to specify new default values for the command, and it is possible to add and remove arguments. Then Command.Update is called to commit the changes.

For a detailed description of the workflow for creating custom commands, see the Command object.

Methods

IsClassOf operator IsEqualTo operator    
       

Properties

Application Categories Flags FullName operator
Handler Help Name operator NestedObjects
Origin OriginPath Parent Type operator
Value      
       

Examples

1. JScript Example

/* ------------------------------------------------------------------------------

	This JScript example demonstrates how to create a command with

	arguments and then how to pass values to the command when executing it.

------------------------------------------------------------------------------ */

//  Start off with a clean slate

Application.RemoveCommand( "SillyPutty" );

//  Get the user path and use it to build the filename + path

sFileName = InstallationPath( siUserPath ) + "\\Data\\Scripts\\MySillyPutty.js";

//  Create the script on disk

var fso = new ActiveXObject( "Scripting.FileSystemObject" );

var fHWFile = fso.CreateTextFile( sFileName );

fHWFile.WriteLine( "function OnSillyPutty( gooey, mute )" );

fHWFile.WriteLine( "{" );

fHWFile.WriteLine( "\tLogMessage( \"SillyPutty is working!\" );" );

fHWFile.WriteLine( "\tLogMessage( gooey );" );

fHWFile.WriteLine( "\tLogMessage( mute );" );

fHWFile.WriteLine( "}" );

fHWFile.Close();

//  Create the custom command

var oCmd = CreateCommand( "SillyPutty", siNoCategory );

oCmd.Description = "Stretches and bends until it reaches the breaking point.";

oCmd.ScriptingName = "SillyPutty";

oCmd.Handler = "OnSillyPutty";

oCmd.FileName = sFileName;

oCmd.Language = "JScript";

//  Add some arguments

var oArgs = oCmd.Arguments;

oArgs.Add( "Gooeyness", siArgumentInput, 24.0, siDouble );

oArgs.Add( "Mute", siArgumentInput, false, siBool );

//  Register the new command

AddCommand( oCmd );

//  Populate the arguments and run the command

var oRunCmd = Application.Commands( "SillyPutty" );

oRunCmd.Arguments(0).Value = 50.0;

oRunCmd.Arguments(1).Value = true;

oRunCmd.Execute();

/* ------------------------------------------------------------------------------

	Output of above command:

	INFO : "SillyPutty is working!"

	INFO : "50"

	INFO : "True"

	SillyPutty(50, true, null);

------------------------------------------------------------------------------ */

2. VBScript Example

'vbscript Custom Command Demo

'

'This script demontrates the Softimage support for creating a custom command and handling its

'arguments.

'

'This example uses an embedded command.

'When you run this script the following results will be logged in the script history:

'	INFO : "Installing example command found in c:/temp/CmdDemo.vbs"

'	INFO : "Default arguments for command are : DefaultString 2.2"

'	INFO : "ExampleCommand is now installed"

'	INFO : "ExampleCommand called - DefaultString 2.2"

'	INFO : "ExampleCommand called - Another string 1.1"

dim cmd

'Remove any existing earlier registrations of this command

if ( typename( Application.Commands( "ExampleCommand" ) ) = "Command" ) then

	Application.RemoveCommand "ExampleCommand"

end if

set cmd = Application.CreateCommand("ExampleCommand", siNoCategory)

cmd.Description = "Example custom command"

cmd.ScriptingName = "ExampleCommand"

cmd.Handler = "OnExampleCommand"

cmd.Code = _

	"function OnExampleCommand( StringArg, DblArg ) " & vbCrLf & _

	"     'Show the arguments we recieved" & vbCrLf & _

	"     LogMessage ""ExampleCommand called - "" & StringArg & "" "" & DblArg" & vtCrLf & _

	"     'Return this value" & vbCrLf & _

	"     OnExampleCommand = 55 " & vbCrLf & _

	"end function"

cmd.Language = "VBScript"

'Command is function, not a sub

cmd.ReturnValue = true									

cmd.Arguments.Add "StringArg", siArgumentInput, "DefaultString"

cmd.Arguments.Add "DblArg", siArgumentInput, 2.2

logmessage "Default arguments for command are : " & cmd.Arguments(0).Value & " " & cmd.Arguments(1).Value

Application.AddCommand cmd

logmessage "ExampleCommand is now installed"

'Now that the command is installed we can look it up and execute it

set cmdlookup = Application.Commands("ExampleCommand")

'This will execute it with default values

cmdlookup.execute

'Use these specific values

cmdlookup.arguments(0).Value = "Another string"

cmdlookup.arguments(1).Value = 1.1

cmdlookup.execute

3. VBScript Example

'VBScript example

set args = Application.Commands("Twist").Arguments

for each a in args

	LogString = a.Name & ":"

	if a.Flags = siArgumentInput or a.Flags = siArgumentInputOutput then

		LogString = LogString & CStr(a.Value)

	end if

	LogMessage LogString

next