vcTeachContext
vcTeachContext is the context of the application for robot programming.
Inherits: vcContext
Properties
| Name | Type | Access | Description | 
| ActiveRobot | vcComponent | RW | Defines the active robot in context. | 
| ActiveRoutine | vcRoutine | R | Gets the active routine in the ActiveRobot program. | 
| ActiveScope | vcScope | R | Gets the active routine or scope of statement in ActiveRobot program. | 
| ActiveStatement | <Type> | R | Gets the active statement in ActiveRobot program. | 
| ActiveStatementIndex | Integer | R | Gets the index of active statement in ActiveRobot program. | 
Methods
| Name | Return Type | Parameters | Description | 
| setActiveStatement | None | vcScope scope, Integer index | Sets the statement at the given index in the given scope to be ActiveStatement. | 
Events
| Name | Parameters | Description | 
| ActiveRobotChanged | None | Triggered when a different robot becomes the active robot in context. | 
Examples
Example. Get active robot and routine in 3D world
| from vcScript import * ##Option 1 def getActiveRoutine(): routine = getApplication().TeachContext.ActiveScope if routine: if routine.ParentStatement: routine = routine.ParentStatement.Routine return routine ##Option 2 app = getApplication() teach = app.TeachContext robot = teach.ActiveRobot if robot: executor = robot.findBehavioursByType( VC_ROBOTEXECUTOR )[0] main = executor.Program.MainRoutine scope = teach.ActiveScope if teach.ActiveStatementIndex < 0: print "No statements exist within the scope" else: print "Index of the currently selected statement in the scope is : ", teach.ActiveStatementIndex if type(scope) == type(main): print "Current Routine is: ", scope else: print "Current Routine is (read from scope statement): ", scope.ParentStatement.Routine |