llExecCharacterCmd

From Second Life Wiki
Revision as of 20:03, 16 February 2012 by Falcon Linden (talk | contribs)
Jump to navigation Jump to search

Summary

Function: llExecCharacterCmd( integer command, list options );

Send a command to the pathing system.

• integer command Command to be sent.
• list options No options currently used.

Currently only supports stopping the current pathfinding operation or causing the character to jump.

Command Value Description & Required Parameters
CHARACTER_CMD_JUMP 0x1 Makes the character jump.

The option list is required to start with a height parameter: [float height]

• float height height to jump, between 0.1m and 2.0m
CHARACTER_CMD_SMOOTH_STOP 0x2 Stops any current pathfinding operation in a smooth like fashion.
CHARACTER_CMD_STOP 0x0 Stops any current pathfinding operation.

Caveats

  • If another script in the same object issues CHARACTER_CMD_STOP then pathing in all scripts is cancelled.

Examples

<lsl> default {

   state_entry()
   {
       llCreateCharacter([CHARACTER_DESIRED_SPEED, 50.0]);
       state awake;
   }

}

state awake {

   state_entry()
   {
       llOwnerSay("entering guarding");
       list points = [llGetPos() + <5,0,0>, llGetPos() - <5,0,0>];
       llPatrolPoints(points, []);
   }
   
   touch_start(integer total_number)
   {
       state sleep;
   }

}

state sleep {

   state_entry()
   {
       llOwnerSay("entering sleeping");
       llExecCharacterCmd(CHARACTER_CMD_STOP, []);
   }
   
   touch_start(integer total_number)
   {
       state awake;
   }

}

</lsl>

Deep Notes

Signature

function void llExecCharacterCmd( integer command, list options );