Difference between revisions of "MoveTo"
Jump to navigation
Jump to search
imported>DragoonWraith (→Notes) |
imported>QQuix (Added a note) |
||
Line 15: | Line 15: | ||
* '''MoveTo''' and '''PositionCell''' perform the same function, but use different parameters ('''PositionCell''' uses coordinates while '''MoveTo''' uses a reference). | * '''MoveTo''' and '''PositionCell''' perform the same function, but use different parameters ('''PositionCell''' uses coordinates while '''MoveTo''' uses a reference). | ||
* If this function is used to move the player, it will also act as a [[Return]] function -- no following lines of the script will be processed. | * If this function is used to move the player, it will also act as a [[Return]] function -- no following lines of the script will be processed. | ||
:*One way to prevent this is creating a Function with just the MoveTo. the function script will stop after the MoveTo, but the calling script will continue. | |||
::Example: | |||
... | |||
PlayerRef.call MyMoveTo AnvilFocsleMarker | |||
... | |||
---------- | |||
scn MyMoveTo | |||
ref refTarget | |||
begin Function {refTarget} | |||
MoveTo refTarget | |||
end | |||
* This function works as expected for Actors. For most other object types, like containers and activators, the object's coordinates are updated but its world art is not. Additional scripting may be necessary to ensure the object moves properly: | * This function works as expected for Actors. For most other object types, like containers and activators, the object's coordinates are updated but its world art is not. Additional scripting may be necessary to ensure the object moves properly: | ||
<pre>myObject.disable | <pre>myObject.disable |
Revision as of 08:16, 2 September 2013
Syntax:
[reference].MoveTo TargetRef, x, y, z [reference].MoveToMarker TargetRef, x, y, z
Moves the object to the specified target location.
The x, y, z are optional offsets in units from the target reference.
Example:
MoveToMarker HiddenCaveMarker MoveTo player, 512, 0, 0
Notes
- MoveTo and PositionCell perform the same function, but use different parameters (PositionCell uses coordinates while MoveTo uses a reference).
- If this function is used to move the player, it will also act as a Return function -- no following lines of the script will be processed.
- One way to prevent this is creating a Function with just the MoveTo. the function script will stop after the MoveTo, but the calling script will continue.
- Example:
... PlayerRef.call MyMoveTo AnvilFocsleMarker ... ---------- scn MyMoveTo ref refTarget begin Function {refTarget} MoveTo refTarget end
- This function works as expected for Actors. For most other object types, like containers and activators, the object's coordinates are updated but its world art is not. Additional scripting may be necessary to ensure the object moves properly:
myObject.disable myObject.moveTo [location] myObject.enable set xp to myObject.getPos x myObject.setPos x xp
- Note however, that if the moved object is moved to a new cell, it may snap back to its original cell after quit/reload (while keeping the new x,y,z coordinates). This seems to not happen as much when moving between Tamriel subspaces, but definitly happens when moving to and between Shivering Isles and Oblivion worldspaces. If the object being moved is only supposed to be a marker, consider using a marker actor instead. (See Teleport Recall.) (Actors do not suffer from worldspace snapback, and should react correctly to closing of an Oblivion gate.)
- To adjust the object relative to the players heading (i.e. place it in front of the player), you'll need to offset it's position. See Summon Object for full code sample.
- Script functions that make one actor target another (like SayTo or StartCombat) will not work when MoveTo is used on the target in the same frame, even when the target is moved only by a few inches.
- MoveTo can be very problematic in some situations. See MoveTo Oddities.
See Also