XML talk:StNA

From OniGalore

Unused types

If unused types are still recognized by engine we could try to apply new animations to them. For example additional throws with Thrown9, Thrown14, and Thrown17.

Console_Punch

  • KONOKOconsole_punch (35 frames) is a stretched KONCOMcomb_p clone (16 frames)
  • the game doesn't use this file so the type could be also considered as "unused"
  • the question remains what this animation was used for; Loser suggests that it was "probably meant to be used for pushbutton type of consoles"

Anim types bound to user input

Stages of type assignment:

User input detection

Visible with chr_debug_characters = 1
Action for pickups

Context check and processing

Logical context: Was previous type a combo type?
Temporal context: Was player's input within a valid timeframe?
Spatial context: What is the position and angle of nearest interactive CJBO?

Type assignment

E.g. PickupObjectMid


Since there are also some TRAM files for prone mode, sitting and hiding against a wall, we can assume some geometry awareness (edge detection) - at least during the game dev stage.

For sit animations the Action event was probably used in FURN context as it belongs to CJBO just like the other interactive objects CHAR, CONS, DOOR, PWRU and WEAP.


For anim types, the series of anims is hardcoded. This is usually important for combos.

Bindings:

fw - forward
p - punch input
k - kick input
...
input context type
p previous type within timeframe: Stand Punch
p (accumulated: p, p) previous type within timeframe: Punch Punch2
p (accumulated: p, p, p) previous type within timeframe: Punch2 Punch3
k (accumulated: p, p, k) previous type within timeframe: Punch2 PPK
k (accumulated: p, p, k, k) previous type within timeframe: PPK PPKK
k (accumulated: p, p, k, k, k) previous type within timeframe: PPKK PPKKK
k (accumulated: p, p, k, k, k, k) previous type within timeframe: PPKKK PPKKKK
k previous type within timeframe: Stand Kick
k (accumulated: k, k) previous type within timeframe: Kick Kick2
k (accumulated: k, k, k) previous type within timeframe: Kick2 Kick3
k + fw (accumulated: k, k, k + fw) previous type within timeframe: Kick2 Kick3Fw

[...]

Besides finishing this table, a further objective could be to create graphics with combo and state cycles, like running and walking cycles.

In theory visual representation of states cycles allows a modder to quickly digest most crucial information when he wants to create new animations and/or cycles.