Move: Difference between revisions

From EDukeWiki
Jump to navigation Jump to search
One (talk | contribs)
No edit summary
Sangman (talk | contribs)
m Link to movesprite
 
(6 intermediate revisions by 4 users not shown)
Line 7: Line 7:
<name> is the name of the move command.
<name> is the name of the move command.


Warning: You '''cannot''' use the same name from a [[define]], or the game will crashes.
Warning: You '''cannot''' use the same name from a [[define]], or the game will crash.


<horizontal> is the horizontal velocity of the [[actor]]. Negative values reverse direction.
<horizontal> is the horizontal velocity of the [[actor]]. Negative values reverse direction.
Line 16: Line 16:
Used inside an [[actor]], a move command is written as:
Used inside an [[actor]], a move command is written as:


'''move''' <name> <type>
'''move''' <name> <moveflags...>


<type> is a parameter set used for directional functions.
<moveflags...> is a (possibly empty) sequence of parameters that specify certain hardcoded movement behavior.


You '''cannot''' substitute <name> for a number, define, or gamevar. It has to be predefined with the first definition of move.
You '''cannot''' substitute <name> for a number, define, or gamevar. It has to be predefined with the first definition of move.


Values for <type> are:


faceplayer - [[actor]] faces the player.
If your case requires the actor moving clips through sprites and/or walls, you need to pass in a custom clipmask. This command does not support that, see [[movesprite]].


geth - use horizontal velocity.
==moveflags==


getv - use vertical velocity.
Values for each <moveflag> (defined in DEFS.CON) are:


randomangle - [[actor]] will face random direction.
{| {{prettytable}}
!moveflag!!description!!internal value!!
|-
|faceplayer
|[[actor]] faces the player.
|align="right"|'''1'''
|-
|geth
|use horizontal velocity.
|align="right"|'''2'''
|-
|getv
|use vertical velocity.
|align="right"|'''4'''
|-
|randomangle
|[[actor]] will face random direction.
|align="right"|'''8'''
|-
|faceplayerslow
|same as faceplayer, but done gradually.
|align="right"|'''16'''
|-
|spin
|spin in a clockwise circle.
|align="right"|'''32'''
|-
|faceplayersmart
|same as faceplayer, but with a slight "lead" on position.
|align="right"|'''64'''
|-
|fleeenemy
|[[actor]] faces away from the player.
|align="right"|'''128'''
|-
|jumptoplayer
|[[actor]] will move vertically and then fall as if jumping.
|align="right"|'''257'''*
|-
|seekplayer
|[[actor]] will try to find the best path to the nearest player.
|align="right"|'''512'''
|-
|furthestdir
|[[actor]] faces the furthest distance from the closest player.
|align="right"|'''1024'''
|-
|dodgebullet
|[[actor]] attempts to avoid all shots directed at him. The [[actor]] will not avoid GROWSPARK.
|align="right"|'''4096'''
|}


faceplayerslow - same as faceplayer, but done gradually.
==Making a Useractor move==
A [[useractor]] can be made to move as part of a given [[action]]. The type of the useractor (ie. Enemy/Notenemy) has an impact on how this functions.
Typically one might expect that we can apply the move on each tic of the action but it doesn't work that way for type Enemy. For that type, a move is started with a "momentum". If it is applied on each tic, the actor will not move at all. On each tic it must be checked if the actor is already moving, and only call the move if they aren't.  


spin - spin in a clockwise circle.
This behaviour does not occur for a Notenemy useractor type.


faceplayersmart - same as faceplayer, but with a slight "lead" on position.
In other words, for a Notenemy, this is sufficient:
<pre>
ifaction MYACTION
{
    move mymove // and apply whatever other flags, e.g. geth
}
</pre>


fleeenemy - [[actor]] faces away from the player.
For an Enemy, use this:
 
<pre>
jumptoplayer - [[actor]] will move vertically and then fall as if jumping.
ifaction MYACTION
 
{
seekplayer - [[actor]] will try to find the best path to the nearest player.
    ifmove mymove {} // alternatively: ifmove mymove nullop
 
    else
furthestdir - [[actor]] faces the furthest distance from the closest player.
        move mymove
 
}
dodgebullet - [[actor]] attempts to avoid all shots directed at him. The [[actor]] will not avoid GROWSPARK.
</pre>


[[Category:Duke3D 1.3/1.5 commands]]
[[Category:Duke3D 1.3/1.5 commands]]
[[Category:Sprite manipulation]]
[[Category:Sprite manipulation]]

Latest revision as of 16:49, 3 December 2020

A move command is used to give velocity to an actor.

Define outside an actor as so:

move <name> <horizontal> <vertical>

<name> is the name of the move command.

Warning: You cannot use the same name from a define, or the game will crash.

<horizontal> is the horizontal velocity of the actor. Negative values reverse direction.

<vertical> is the vertical veloctity of the actor. Negative values cause upward motion.


Used inside an actor, a move command is written as:

move <name> <moveflags...>

<moveflags...> is a (possibly empty) sequence of parameters that specify certain hardcoded movement behavior.

You cannot substitute <name> for a number, define, or gamevar. It has to be predefined with the first definition of move.


If your case requires the actor moving clips through sprites and/or walls, you need to pass in a custom clipmask. This command does not support that, see movesprite.

moveflags

Values for each <moveflag> (defined in DEFS.CON) are:

moveflag description internal value
faceplayer actor faces the player. 1
geth use horizontal velocity. 2
getv use vertical velocity. 4
randomangle actor will face random direction. 8
faceplayerslow same as faceplayer, but done gradually. 16
spin spin in a clockwise circle. 32
faceplayersmart same as faceplayer, but with a slight "lead" on position. 64
fleeenemy actor faces away from the player. 128
jumptoplayer actor will move vertically and then fall as if jumping. 257*
seekplayer actor will try to find the best path to the nearest player. 512
furthestdir actor faces the furthest distance from the closest player. 1024
dodgebullet actor attempts to avoid all shots directed at him. The actor will not avoid GROWSPARK. 4096

Making a Useractor move

A useractor can be made to move as part of a given action. The type of the useractor (ie. Enemy/Notenemy) has an impact on how this functions. Typically one might expect that we can apply the move on each tic of the action but it doesn't work that way for type Enemy. For that type, a move is started with a "momentum". If it is applied on each tic, the actor will not move at all. On each tic it must be checked if the actor is already moving, and only call the move if they aren't.

This behaviour does not occur for a Notenemy useractor type.

In other words, for a Notenemy, this is sufficient:

ifaction MYACTION
{
    move mymove // and apply whatever other flags, e.g. geth
}

For an Enemy, use this:

ifaction MYACTION
{
    ifmove mymove {} // alternatively: ifmove mymove nullop
    else 
        move mymove
}