Difference between revisions of "LlSetCameraAtOffset"
Jump to navigation
Jump to search
All Issues ~ Search JIRA for related Bugs
(How to Undo) |
Lady Sumoku (talk | contribs) m (Replaced old <LSL> block with <source lang="lsl2">) |
||
(3 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
{{LSL_Function | {{LSL_Function | ||
|inject-2={{LSL Function/offset|offset | |inject-2={{LSL Function/offset|offset}} | ||
|func_id=244|func_sleep=0.0|func_energy=10.0 | |func_id=244|func_sleep=0.0|func_energy=10.0 | ||
|func=llSetCameraAtOffset | |func=llSetCameraAtOffset | ||
Line 11: | Line 11: | ||
* Setting this will not update the cameras of seated avatars, it will only effect avatars that subsequently sit down. The camera settings have to be prepared in advance. | * Setting this will not update the cameras of seated avatars, it will only effect avatars that subsequently sit down. The camera settings have to be prepared in advance. | ||
* The {{LSLP|offset}} is [[Viewer_coordinate_frames#Local|locally relative]] to the object, if you want it relative to the seated [[Viewer_coordinate_frames#Agent|avatar]] (which likely has a custom sit rotation and offset) or the [[Viewer_coordinate_frames#Region|region]], you must do the computation yourself. | * The {{LSLP|offset}} is [[Viewer_coordinate_frames#Local|locally relative]] to the object, if you want it relative to the seated [[Viewer_coordinate_frames#Agent|avatar]] (which likely has a custom sit rotation and offset) or the [[Viewer_coordinate_frames#Region|region]], you must do the computation yourself. | ||
* ZERO_VECTOR offset will cancel any offset. | * [[ZERO_VECTOR]] {{LSLP|offset}} will cancel any offset. | ||
* Camera focus set by this function is a '''Prim Property'''. '''It will survive the script''' and it will survive prim taking and prim rezzing | |||
|constants | |constants | ||
|examples=< | |examples=<source lang="lsl2">// Set the seated avatar looking at an arbitrary direction | ||
// Look over the avatar's shoulders from behind once it sits down | // Look over the avatar's shoulders from behind once it sits down | ||
Line 33: | Line 34: | ||
llSay(0, "Please sit down"); | llSay(0, "Please sit down"); | ||
} | } | ||
}</ | }</source> | ||
|helpers | |helpers | ||
|also_functions= | |also_functions= |
Latest revision as of 15:02, 22 January 2015
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Summary
Function: llSetCameraAtOffset( vector offset );244 | Function ID |
0.0 | Forced Delay |
10.0 | Energy |
Sets the point the camera is looking at to offset for avatars that sit on the object.
• vector | offset | – | offset relative to the prim's position and expressed in local coordinates |
This is the point the camera looks at, not the position of the camera's eye.
Caveats
- Setting this will not update the cameras of seated avatars, it will only effect avatars that subsequently sit down. The camera settings have to be prepared in advance.
- The offset is locally relative to the object, if you want it relative to the seated avatar (which likely has a custom sit rotation and offset) or the region, you must do the computation yourself.
- ZERO_VECTOR offset will cancel any offset.
- Camera focus set by this function is a Prim Property. It will survive the script and it will survive prim taking and prim rezzing
Examples
// Set the seated avatar looking at an arbitrary direction
// Look over the avatar's shoulders from behind once it sits down
back_view(float degrees)
{
rotation sitRot = llAxisAngle2Rot(<0, 0, 1>, degrees * DEG_TO_RAD);
llSitTarget(<0, 0, 0.1>, sitRot);
llSetCameraEyeOffset(<-2, 0, 1> * sitRot);
llSetCameraAtOffset(<2, 0, 1> * sitRot);
}
default
{
state_entry()
{
back_view( 208 );
llSay(0, "Please sit down");
}
}
See Also
Functions
• | llSetLinkCamera | |||
• | llSetCameraEyeOffset | |||
• | llForceMouselook | |||
• | llSetCameraParams |