Difference between revisions of "LlEvade"

From Second Life Wiki
Jump to navigation Jump to search
m
m
 
Line 14: Line 14:
*If the {{LSLP|target}} is an object, it must be unlinked or be the root prim of a linkset.
*If the {{LSLP|target}} is an object, it must be unlinked or be the root prim of a linkset.
|examples=
|examples=
<lsl>
<source lang="lsl2">
vector start_position;
vector start_position;


Line 47: Line 47:
     }
     }
}
}
</lsl>
</source>
|also_functions=
|also_functions=
* [[llCreateCharacter]]
* [[llCreateCharacter]]

Latest revision as of 00:21, 22 January 2015

Summary

Function: llEvade( key target, list options );

Characters will (roughly) try to hide from their pursuers if there is a good hiding spot along their fleeing path. Hiding means no direct line of sight from the head of the character (center of the top of its physics bounding box) to the head of its pursuer and no direct path between the two on the navmesh.

• key target group, avatar or object UUID to evade
• list options No options currently available

Caveats

  • Must use llCreateCharacter or script will not compile.
  • If the target is an object, it must be unlinked or be the root prim of a linkset.

Examples

vector start_position;

default
{
    on_rez(integer start_param)
    {
        llResetScript();
    }

    state_entry()
    {
        llDeleteCharacter();
        llCreateCharacter([CHARACTER_MAX_SPEED, 25, CHARACTER_DESIRED_SPEED, 15.0]);

        start_position = llGetPos();
        llWanderWithin(start_position, <10.0, 10.0, 2.0>, [] );
    }
 
    touch_start(integer num_detected)
    {
        llEvade(llDetectedKey(0), []);
        llSetTimerEvent(20.0);
    }

    timer()
    {
    //  do not keep running away...
        llSetTimerEvent(0.0);

        llWanderWithin(start_position, <10.0, 10.0, 2.0>, [] );
    }
}

Deep Notes

History

Date of Release 31/07/2012

Signature

function void llEvade( key target, list options );