SMBX NPC AI

SMBX stores its AI values in special fields in the SMBX struct.

Paragoomba (ID: 3)

 * 0x+F0 (ai1) Increments 1 per tick, at 32 the jumps are starting and it only increments one per jump until 35.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Shell (ID: 5, 7, 24, 73, 113, 114, 115, 116, 172, 174)

 * 0x+F0 (ai1)/8 (ai2)/100 (ai3) Unused
 * 0x+108 (ai4) Timer counts up from 0 to 3 when changing direction and spawning hit effect.
 * 0x+110 (ai5) Unused

Piranha Plant (Green) (ID: 8)

 * 0x+F0 (ai1) Timer
 * 0x+F8 (ai2) Current AI phase (1=showing up [Tick 0-32; Then reset to 0], 2=showing [Tick 0-49; Then reset to 0], 3=hiding down [Tick 0-32], 4=hiding [Tick 33-74; Then reset to 0])
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

SMB3 Coin (ID: 10)

 * 0x+F0 (ai1) Set to 1 when affected by gravity (e.g. when Luigi hits a block containing coins), 0 otherwise

Lava Bubbles (ID: 12)

 * 0x+F0 (ai1) Timer
 * 0x+F8 (ai2) Current AI phase (1=jumping up, 2=fall down)
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Player Fireball (ID: 13)

 * 0x+F0 (ai1) Player-character logic to use for the fireball (1=Mario, 2=Luigi, 3=Peach, 4=Toad, 5=Link)
 * 0x+F8 (ai2) 1 if Peach's fireball bounced off a block.

Boom Boom (ID: 15)

 * 0x+F0 (ai1) Current AI phase (0=running/walking, 1=spike mode, 2=transforming to spike mode, 3=jumping up, 4=hurt)
 * 0x+F8 (ai2) Decimal Timer
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Bill Blaster (ID: 21)

 * 0x+F0 (ai1) Timer: Increments 1 per tick, at 200 one bullet bill is fired unless the player is over or underneath the blaster. (incremeting will not be paused!)
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Billy Gun (ID: 22)

 * 0x+F0 (ai1) Timer: Increments 10 per tick when the player is holding the billy gun, at 200 one bullet bill is fired.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Ninji (Violet) (ID: 25)

 * 0x+F0 (ai1) Timer: When touching the ground then a timer decrements from 5 to 0. When the value is back to 0 then the ninji is jumping again.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Cheep-Cheep (Red) (ID: 28)

 * 0x+F0 (ai1) The selected Cheep-Cheep AI (From 0...)
 * 0x+F8 (ai2) Unknown
 * 0x+100 (ai3) Unknown
 * 0x+108 (ai4) 0 = Swim up, 1 = Swin down
 * 0x+110 (ai5) Unused

Hammer Bros. (ID: 29)

 * 0x+F0 (ai1) Timer: Direction Timer, if <0 then moving left, else moving right. Will reset about ~100 ticks (unknown)
 * 0x+F8 (ai2) Timer: Increments 1 per tick (while not shooting), if reaches 250 then super-jump is executed ==> Timer resets to 0
 * 0x+100 (ai3) Throwing releated. High number = more throws
 * 0x+108 (ai4)/110 (ai5) Unused

Super Leaf (ID: 34)

 * 0x+F0 (ai1) Timer: From 1 to 6. Controls the "swing"-effect for correct speed. When the value 6 is reached the direction of this swing is switched.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Thwomp (ID: 37, 180)

 * 0x+F0 (ai1) Current AI phase (0=idle, 1=going down, 2=staying down, 3=going up)
 * 0x+F8 (ai2) Timer: For state 2 => from 0 to 100; When hit value 100 then state is switched to 3.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Boo (ID: 38, 43, 44)

 * 0x+F0 (ai1) Current AI phase (0=idle, 1=following player)
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Birdo (ID: 39)

 * 0x+F0 (ai1) Current AI phase (0=movement, 1=fire, or -30 to 0 if got hit)
 * 0x+F8 (ai2) Timer: Increments 1 per tick; if reaches 125 then jump, if reaches 250 then shoot, at 280 resets to 0
 * 0x+100 (ai3) Movement timer: Increments 1 per tick, when reached 500 ==> Direction changed
 * 0x+108 (ai4)/110 (ai5) Unused

Grab Block (ID: 45)

 * 0x+F0 (ai1) Current AI phase (0=untoched, 1=touched)
 * 0x+F8 (ai2) Timer: (Only in touched mode), 1 to 450; If reaches 450 then the block dissapears; If value is 0 in touched mode then the block is thrown and destroys itself on collision.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Donut Block (ID: 46, 212)

 * 0x+F0 (ai1) Current AI phase (0=idle, 1=falling)
 * 0x+F8 (ai2) 1 if someone is standing ==> Increments timer
 * 0x+100 (ai3) Timer: From 0 to 5 ticks for red version; 0 to 30 ticks for brown version
 * 0x+108 (ai4)/110 (ai5) Unused

Lakitu (SMB3) (ID: 47)

 * 0x+F0 (ai1) Movement related?
 * 0x+F8 (ai2) Unknown
 * 0x+100 (ai3) Current AI phase (0=???, 1=???, 2=normal movement?, 3=throwing)
 * 0x+108 (ai4) Direction Timer: Start from 100 decrementing 1 per tick. When reached 0 then Lakitu is changing direction. It only starts again counting when Lakitu reached the same position as the player.
 * 0x+110 (ai5) Timer: When timer starts (unknown?). Increments 1 per 6 ticks from 0 to 20. When 20 is reached one Spiky Egg is thrown.

Toothy Pipe (ID: 49)

 * 0x+F0 (ai1) Current AI phase (0=not holding, 1=holding)
 * 0x+F8 (ai2) NPC Array Index to find Toothy NPC Struct (NOTE: At high index experience laggs)
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Toothy (ID: 50)

 * 0x+F0 (ai1) Stays 1, if set to 0 then Toothy despawns
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Piranha Plant (Red, Upside-Down) (ID: 51)

 * 0x+F0 (ai1) Timer
 * 0x+F8 (ai2) Current AI phase (1=showing up [Tick 0-42; Then reset to 0], 2=showing [Tick 0-49; Then reset to 0], 3=hiding down [Tick 0-42], 4=hiding [Tick 43-109; Then reset to 0])
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Piranha Plant (Red Horizontal) (ID: 52)

 * 0x+F0 (ai1) Timer
 * 0x+F8 (ai2) Current AI phase (1=showing up [Tick 0-32; Then reset to 0], 2=showing [Tick 0-49; Then reset to 0], 3=hiding down [Tick 0-32], 4=hiding [Tick 33-109; Then reset to 0])
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Fighter Fly (ID: 54)

 * 0x+F0 (ai1) Timer: From 0 to 29. When reached value 29 then the jump is beeing made.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Platform (ID: 60, 62, 64, 66)

 * 0x+F0 (ai1) Speed X
 * 0x+F8 (ai2) Speed Y
 * 0x+100 (ai3) Unused/Unknown?
 * 0x+108 (ai4) Unused/Unknown?
 * 0x+110 (ai5) ID of Path riding on, if 0 then platform is using no path

Piranhacus Giganticus (ID: 74)

 * 0x+F0 (ai1) Timer
 * 0x+F8 (ai2) Current AI phase (1=showing up [Tick 0-42; Then reset to 0], 2=showing [Tick 0-49; Then reset to 0], 3=hiding down [Tick 0-42], 4=hiding [Tick 43-74; Then reset to 0])
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Toad (Jumping) (ID: 75)

 * 0x+F0 (ai1) Timer: [Tick 0-9 "Charging" Jump], [Tick 0-9 Jumping], When falling down timer stays at value 100... (strange algorithm)
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Parakoopa (Green) (ID: 76, 121, 122, 123, 124)

 * 0x+F0 (ai1) Para-Koopa Movement Mechanism (0: Follow, 1: Jump, 2: Hover Left/Right, 3: Hover Up/Down, Any Other Number: Stay in Place)
 * 0x+F8 (ai2) Unused/Unknown?
 * 0x+100 (ai3) For AI-State 2 (Hover left/right): Direction Flag for slightly going up/down.
 * 0x+108 (ai4)/110 (ai5) Unused

SMW Bowser Statue (ID: 84)

 * 0x+F0 (ai1) Increments 1 per tick, resetting when it shoots (shooting about Tick ~220 [Not fixed])
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

SMB3 Bowser (ID: 86)

 * 0x+F0 (ai1) Resets to 9 when starting to jump high and decrements 1 per tick. Not sure but may start arcing after it hits 0
 * 0x+F8 (ai2) Increments by a seemingly random number between 0.0 and 1.0 each tick. Resets from time to time but I don't can't tell exactly why.
 * 0x+100 (ai3) Increments by 1 per tick. Sometimes it gets reset to 0, but other times it gets reset to a negative number and counts back up to 0 to trigger something.
 * 0x+108 (ai4) Current AI phase (2=hopping, 3=jumping high+falling, 4=shooting fireballs, 10=turning right after hitting ground, -10=turning left after hitting ground)
 * 0x+110 (ai5) Other? (0=just after hitting ground, 1=other)

Herb (ID: 91)

 * 0x+F0 (ai1) The NPC ID of the content in the herb.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Piranha Plant SMB1 (ID: 93)

 * 0x+F0 (ai1) Timer
 * 0x+F8 (ai2) Current AI phase (1=showing up [Tick 0-32; Then reset to 0], 2=showing [Tick 0-49; Then reset to 0], 3=hiding down [Tick 0-32], 4=hiding [Tick 33-74; Then reset to 0])
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Colored egg (ID: 96)

 * 0x+F0 (ai1) The NPC ID of the content in the egg.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Star SMB3 (ID: 97)

 * 0x+F0 (ai1) Whether the star has already been collected (1 when true)
 * 0x+F8 (ai2) Direction Flag (0 = fly up; 1 = fly down)
 * 0x+100 (ai3) Unused/Unknown?
 * 0x+108 (ai4) Direction Flag Timer (From 0 to 4; When 4 reset to 0 and toggle the Direction Flag)
 * 0x+110 (ai5) Unused

Wood platform (ID: 104)
(ai3) (ai4) (ai5) Unused
 * 0x+F0 (ai1) The current Y-Speed
 * 0x+F8 (ai2) The current X-Speed

Thin platform (ID: 105)

 * 0x+F0 (ai1) If the player stands on the platform, then this value is 1, else it is 0
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Bit (ID: 126, 127, 128)

 * 0x+F0 (ai1) AI-State (2 = Moving [Tick 0-119], 1 = Charging [Tick 0-89 or 29], -1 = Jumping [Tick stays at 0 until reaching the floor]). Note: The AI States are quite random.
 * 0x+F8 (ai2) Timer
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Tweeter (ID: 129)

 * 0x+F0 (ai1) Jump Timer: 0 to 3, on every jump this timer increases by 1 until it reaches value 3. Then the next jump is a high jump and the timer resets to 0.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Snifit (Red/Blue) (ID: 130, 131)

 * 0x+F0 (ai1) Timer: From 0 to 120 = Movement, from 121 to 149 = Init Fire, after that fire and the timer reset to 0
 * 0x+F8 (ai2) Quickly changes between 0 and 1 when shaking.
 * 100 (ai3)/108 (ai4)/110 (ai5) Unused

Snifit (Gray) (ID: 132)

 * 0x+F0 (ai1) Timer: Unknown
 * 0x+F8 (ai2) Jump Timer: 0-99 to Jump with 0x+100 (ai3) is 0, 0-40; 91-99 with 0x+100 (ai3) is 2.
 * 0x+100 (ai3) Shoot related, 0 = (shoot nothing?); 2 = Shoot twice?, [Note: very unclear!]
 * 0x+108 (ai4)/110 (ai5) Unused

Mouser's Bomb (ID: 134)

 * 0x+F0 (ai1) Timer (until explode): 0-349 until explode; When 250 reached then AI-State is 1.
 * 0x+F8 (ai2) AI-State: 0 = Idle, 1 = Short before exploding
 * 0x+100 (ai3) Bomb animation state: 0-14 repeating when AI-State is 1.
 * 0x+108 (ai4)/110 (ai5) Unused

Bob-Omb (SMB2) (ID: 135)

 * 0x+F0 (ai1) Timer (until explode): 0-549 until explode; When 450 reached then AI-State is 1.
 * 0x+F8 (ai2) AI-State: 0 = Idle, 1 = Short before exploding
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Bob-Omb kicked (SMB3) (ID: 137)

 * 0x+F0 (ai1) Timer (until explode): 0-349 until explode; When 250 reached then AI-State is 1.
 * 0x+F8 (ai2) AI-State: 0 = Idle, 1 = Short before exploding
 * 0x+100 (ai3) Bomb animation state: 0-10 repeating when AI-State is 1.
 * 0x+108 (ai4)/110 (ai5) Unused

Galoomba Kicked (SMW) (ID: 166)

 * 0x+F0 (ai1) Timer (until standing back up): 0-399 until standing back up.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Para-Galoomba (SMW) (ID: 167)

 * 0x+F0 (ai1) Timer/AI-State: 0-61 Simple Movement; 62 First Jump and lock on to the Jump-Timer; 63 Second Jump; 64 Third Jump; 65 Fifth Jump;
 * 0x+F8 (ai2) Jump Timer: AI-State 62-64: Increment 1 per tick, from 0-15; AI-State 65: Increment 2 per tick; When reched 15, then jump if possible.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Bully (SM64) (ID: 168)

 * 0x+F0 (ai1) Unknown/Unused?
 * 0x+F8 (ai2) AI-State: 0 = following player, 1 = kicked off by player
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Grinder (Circular saw) (ID: 179)

 * 0x+F0 (ai1) Grinder Speed Y
 * 0x+F8 (ai2) Grinder Speed X
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Bowser's statue (ID: 181)

 * 0x+F0 (ai1) Timer: 0-230 until shoot.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Dry Bones (ID: 189)

 * 0x+F0 (ai1) 0=Up walking around, 1=Collapsed
 * 0x+F8 (ai2) When broken, increments by 1 per tick until 400 at which point it gets up
 * 0x+100 (ai3) Alternates between 1 and 0 when wiggling (0x+F8 (ai2) between 300 and 400)
 * 0x+108 (ai4)/110 (ai5) Unused

Skull Raft (ID: 190)

 * 0x+F0 (ai1) AI-State: 0 = Idle, 1 = Active Moving
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Kamikaze Koopa (ID: 194)

 * 0x+F0 (ai1) Unknown/Unused?
 * 0x+F8 (ai2) Unknown/Unused?
 * 0x+100 (ai3) Unknown/Unused?
 * 0x+108 (ai4) Unknown/Unused?
 * 0x+110 (ai5) Animation Timer 0-15: The current color of the shell.

Collectable Star (ID: 196)

 * 0x+F0 (ai1) Whether the star has already been collected (1 when true)
 * 0x+F8 (ai2) Direction Flag (0 = fly up; 1 = fly down; This flag gets toggled after running the animation timer 14 times (5 animation frames * 14 = 70 frames total per direction)
 * 0x+100 (ai3) Unused/Unknown?
 * 0x+108 (ai4) Animation Timer (From 0 to 4)
 * 0x+110 (ai5) Unused

SMW Exit point (ID: 197)

 * 0x+F0 (ai1) Direction Flag (1 = move up; 0 = move down)
 * 0x+F8 (ai2) The lower y coordinate. This y coordinate toggles the direction flag from moving down to moving up. Modifying this flag has no effect!
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Blargg (ID: 199)

 * 0x+F0 (ai1) AI-State (0 = idle; 1 = looking; 2 = moving)
 * 0x+F8 (ai2) Timer - AI-State 1: 0 to 89; AI-State 2: Stays at 90 until moving animation finished.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

SMB Bowser (ID: 200)

 * 0x+F0 (ai1) 0: Walking, 1: Pre-fire, 2: spitting fire
 * 0x+F8 (ai2) The direction Bowser is moving, not facing. 0 is left, 1 is right.
 * 0x+100 (ai3) Fire timer, after spitting fire increments up to around 60
 * 0x+108 (ai4) Some sort of Hammer related timer, noted below.
 * 0x+110 (ai5) Unknown, always 1 (SMBX forces it to be 1) [Related to 2-player mode]

0x+108 (ai4) Details
(where tableOfBowser is a table of the active SMB1 Bowsers returned by `NPC.get(200, -1)`)
 * The timer is mostly random
 * However, repeatedly setting the values based on a range can modify the rate at which hammers are thrown. For example:
 * The internal ai4 equals to this C++ pseudocode
 * Note that in the Lua code, we set the value to 15. In the C++ code, the random spawn rate is based on a modulus of 16. This is due to the fact that when setting the value in Lua, it is automatically incremented to 1 above of what is set.

Wart (ID: 201)

 * 0x+F0 (ai1) AI-State: 0 - Idle, 1 - Bubbles; 2 - Got hit; 3 - Death
 * 0x+F8 (ai2) Walking Direction: 1 - left; -1 - right
 * 0x+100 (ai3) Timer (Idle: 0 to 180; Bubbles: 0 to 130)
 * 0x+108 (ai4) Death timer (0 to 120)
 * 0x+110 (ai5) Unused

Zoomer (ID: 205), Spark (ID: 206), Spike Top (ID: 207)

 * 0x+F0 (ai1) Walking side: 0 - in air (falling down), 1 - Walking on top side, 2 - Walking on left side, 3 - Walking on bottom side, 4 - Walking on right side
 * 0x+F8 (ai2) Unknown: Is -1 on top and right side, is 1 on left and bottom side
 * 0x+100 (ai3) Unknown Timer
 * 0x+108 (ai4) Unused/Unknown?
 * 0x+110 (ai5) Edge Timer: If hitting an edge, then timer starts from 1 to 6. When reaching value 6 then the NPC is switching walking side.

Mother Brain (ID: 209)

 * 0x+F0 (ai1) Shaking Timer: 0 to 44 (0 = Idle, otherwise lower value means harder shake)
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Rinka (ID: 210)

 * 0x+F0 (ai1) AI-State: 0 = Waiting, 1 = Moving
 * 0x+F8 (ai2) Timer for AI-State 0: From 0 to 88; When reaching 88, then AI-State is switched to 1 (Moving)
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Rinka block (ID: 211)

 * 0x+F0 (ai1) Spawn Timer: 0 to ~200 (Increments about 1 to 2 per tick [i.e. 1,835...]); If the value reaches over 200 then a new Rinka NPC is spawned. Then is it switched back to 0.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Blooper (ID: 231)

 * 0x+F0 (ai1) When starting the level in water, set to 1 (else set to 0).
 * 0x+F8 (ai2) Vertical movement counter: increases when moving up, decreasing when moving down. Set to -60 when falling outside of the water or outside of water with no movement.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Venus Fire Trap (ID: 245)

 * 0x+F0 (ai1) State Timer, increases per tick (Initial state on activation: 42. While state 1, tick from 0 to 43 [equal to physical height] (until Fire Trap will finish warping up process). While state 2, tick from 0 to 100. On value 50 - shoot the fire. While state 3 - tick to 43 [equal to physical height] (Until Fire Trap will finish warping down process). On state 4, continue timer from recent value to 150. If player is arround, reset timer to 140)
 * 0x+F8 (ai2) Current state (1 - Showing up, 2 - Watch for a player and shoot, 3 - Hiding down, 4 [Initial] - Wait in the shelter)
 * 0x+100 (ai3) Unused
 * 0x+108 (ai4) Unknown, always 1
 * 0x+110 (ai5) Unused

Pokey (ID: 247)

 * 0x+F0 (ai1) -3 when a body segment.
 * 0x+F8 (ai2) 2 when the bottom segment.
 * 100 (ai3)/108 (ai4)/110 (ai5) Unused

Big Piranha Plant (ID: 256, 257)

 * 0x+F0 (ai1) Timer (Initial state 71, While state 1 - tick from 0 to 85 [Equal to NPC height, until it will be completely shown] and reset to 0, While state 2 - Do nothing until something will hurt NPC, then toggle state to 3 and timer value to 50. While state 3, tick from 0 to 85 [Equal to NPC height, until it will be completely hidden], then toggle state to 4 and tick timer from - to 75. Then toggle state to 1 and begin showing).
 * 0x+F8 (ai2) Current AI phase (1 - Showing up, 2 - Waiting be shown, 3 - Hiding down, 4 [Initial] - Wait in shelter)
 * 0x+100 (ai3) Unused
 * 0x+108 (ai4) Unused.
 * 0x+110 (ai5) Unused

Roto Disc (ID: 259)

 * 0x+F0 (ai1) Position on the circle, increments (when placed at top) from 0 to 3, or decrements (when placed at bottom). Value is always 0 at the start position and changes every quarter circle.
 * 0x+F8 (ai2) Unused/Unknown?
 * 0x+100 (ai3) Unused/Unknown?
 * 0x+108 (ai4) Frame Timer.
 * 0x+110 (ai5) Switches to 0 for a frame when ai1 changes. Checks for vertical/horizontal lines on the path?

Firebar (ID: 260)

 * 0x+F0 (ai1) Distance from the center of the circle (SMBX Advanced Tab "Position")
 * 0x+F8 (ai2) Position on the circle, increments (when placed at top) from 0 to 3, or decrements (when placed at bottom). Value is always 0 at the start position and changes every quarter circle.
 * 0x+100 (ai3) Unused/Unknown?
 * 0x+108 (ai4) Unused/Unknown?
 * 0x+110 (ai5) Switches to 0 for a frame when ai2 changes. Checks for vertical/horizontal lines on the path?

Nipper Plant (ID: 261)

 * 0x+F0 (ai1) AI-State: 0 = Moving, 1 = Jumping
 * 0x+F8 (ai2) Timer for standing without moving and hopping.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Ice Block (ID: 263)

 * 0x+F0 (ai1) Contained NPC ID
 * 0x+F8 (ai2) Displayed Frame?
 * 0x+100 (ai3) Nogravity flag. Set to 0 when grabbed.
 * 108 (ai4)/110 (ai5) Unused

Ice Ball (ID: 265)

 * 0x+F0 (ai1) AI State: 1 is bouncing, 5 is flying horizontally
 * 0x+F8 (ai2)/0x+100 (ai3)/0x+108 (ai4) Unused
 * 0x+110 (ai5) Number of bounces. After the 2nd bounce, the ice ball will be destroyed on impact with the ground.

Link's Laser (ID: 266)

 * 0x+F0 (ai1) Despawn Timer (increments from 0 to 40)
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Larry (ID: 267)

 * 0x+F0 (ai1) AI State: 0 is walking, 1 is preparing to fire, 2 is shooting
 * 0x+F8 (ai2) Movement direction (left is -1, right is 1)
 * 0x+100 (ai3) Jumping Timer: Increments from 0 to a random number between 40 and 60
 * 0x+108 (ai4) Shooting Timer: Increments from 0 to around 130 in AI State 0 (can be exceeded if he was jumping when the number passed 130), shows y-position to aim at in AI State 2
 * 0x+110 (ai5) Always 1.

Larry's Shell (ID: 268)

 * 0x+F0 (ai1) AI State: 0 is staying still, 1 is moving on the ground, 3 is jumping out of the shell
 * 0x+F8 (ai2) AI State Timer: 0: Increments from 0 to 60 before switching to State 1; 1: Increments from 0 to 300 before switching to State 3; 3: Increments from 0 to 20 before turning the NPC into ID 267
 * 0x+100 (ai3)/108 (ai4) Unused
 * 0x+110 (ai5) Always 1.

Larry's Beam (ID: 269)

 * 0x+F0 (ai1) Displayed Frame: 0 = Frame 1, 1 = Frame 2, 2 = Frame 3
 * 0x+F8 (ai2) Timer for displayed frame: Increments from 0 to 21. At 16: Switches to AI 1 state 1, at 21: Switches to AI 1 state 2.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

SMW Jumping Plant (ID: 270)

 * 0x+F0 (ai1) AI-State: 0 = Waiting, 1 = Moving upwards, 2 = Moving downwards
 * 0x+F8 (ai2) Timer for AI-State; 0: From 60 to -20; When reaching -20, then AI-State is switched to 1; 1: From 0 to 100; When reaching 100, then AI-State is switched to 2.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Swooper (ID: 271)

 * 0x+F0 (ai1) AI-State: 0 = Waiting, 1 = Flying
 * 0x+F8 (ai2) When in AI State 1: Fixated y-position the NPC is aiming at.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Hoopster (ID: 272)

 * 0x+F0 (ai1) Direction: Downwards: 1; Upwards: -1 (Rapidly switches between -1 and 2 when not fixed to something they can climb on)
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Volcano Lotus (ID: 275)

 * 0x+F0 (ai1) AI-State: 0 = Idle, 1 = Preparing for shot, 2 = After shot,
 * 0x+F8 (ai2) AI State Timer; 0: Increments from 0 to 170, then switches into AI1 State 1; 1: Increments from 0 to 70, then switches into AI1 State 2 and shoots 4 NPC ID 276's; 2: Increments from 0 to 50, then switches to AI1 State 0
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Volcano Lotus Fireball (ID: 276)

 * 0x+F0 (ai1) Direction: 0 = Upwards, 1 = Downwards
 * 0x+F8 (ai2) X-Movement, increments from 0 to 11 (0-5 frames movement to the left, 6-11 frames movement to the right)
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Propeller Block (ID: 268)

 * 0x+F0 (ai1) 0 while y-speed doesn't decrease while jumping with the block, else 1.
 * 0x+F8 (ai2)/100 (ai3)/108 (ai4)/110 (ai5) Unused

Fire Propeller Block (ID: 279)

 * 0x+F0 (ai1) 0 while y-speed doesn't decrease while jumping with the block, else 1.
 * 0x+F8 (ai2) Increments from 0 to 79, shoots a fireball every 20 frames. When spinjumping: Rapidly switches between 25 and 100. CAREFUL! Landing on the ground while this value is above 79 will stop the flamethrower from shooting.
 * 0x+100 (ai3) While spinjumping rapidly changes between -1 and 1, direction of the item while spinning (-1 is left).
 * 0x+108 (ai4) Always 0.
 * 0x+110 (ai5) Appears to be a random number. Does nothing? Known values: 12, 14.

Ludwig (ID: 280)

 * 0x+F0 (ai1) AI State: 0 = Standing, 1 = Preparing to fire, 2 = Firing, 3 = Jumping into the shell
 * 0x+F8 (ai2) Direction flag. Left: -1, Right: 1
 * 0x+100 (ai3) Fire Timer: Increments from 0 to 40. While this is 0, AI State is 0, while this is between 1 and 20, AI State is 1, while this is above 20, AI State is 2.
 * 0x+108 (ai4) Always 0.
 * 0x+110 (ai5) Always 1.

Ludwig's Shell (ID: 281)

 * 0x+F0 (ai1) AI State: 0 = Not moving, 1 = Moving, 3 = Jumping out of the shell
 * 0x+F8 (ai2) Timer: AI State 0: Increments to 60, then switches to AI State 1; AI State 1: Increments from 0 to 300, when it reaches 300, the NPC turns back into Ludwig.
 * 0x+100 (ai3) Jump Timer. Increments to a random number before jumping. Almost always jumps before this timer reaches 50. Set to 1 when AI State is 3.
 * 0x+108 (ai4) Unused.
 * 0x+110 (ai5) Always 1.

Bubble (ID: 283)

 * 0x+F0 (ai1) Contained NPC ID
 * 0x+F8 (ai2) Movement direction (-1 is upwards, 1 is downwards)
 * 0x+100 (ai3) 1 when popping.
 * 108 (ai4)/110 (ai5) Unused

Lakitu (SMW) (ID: 284)

 * 0x+F0 (ai1) Thrown NPC identity
 * 0x+F8 (ai2) Init to 1, set to 0 a little while after throwing
 * 0x+100 (ai3) 0=Haven't yet passed over player, 2=Getting ready to throw, 3=Like 0 but after having thrown before
 * 0x+108 (ai4) When getting ready to throw, resets to 100 and starts decrementing. Throws once 0 again.
 * 0x+110 (ai5) Always increments 1 per tick, resets to 0 after throw

Spiny Egg (SMW) (ID: 286)

 * 0x+F0 (ai1) Flag for colliding with the ground, when 1 transforms NPC into ID 285
 * 0x+F8 (ai2) Unknown, 0 when thrown by Lakitu, placed before testing or coming from a bubble, otherwise -1.
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

SMB2 Potion (ID: 288)

 * 0x+F0 (ai1) Unused
 * 0x+F8 (ai2) Target Section (-1 means no section, otherwise from 0 to 20)
 * 0x+100 (ai3) 1 when transforming into the door.
 * 108 (ai4)/110 (ai5) Unused

SMB2 Potion Door (ID: 289)

 * 0x+F0 (ai1) Unused
 * 0x+F8 (ai2) Target Section (-1 means no section, otherwise from 0 to 20)
 * 0x+100 (ai3)/108 (ai4)/110 (ai5) Unused

Rideable Airship Piece (ID: 290)

 * 0x+F0 (ai1) Unused
 * 0x+F8 (ai2) Always -1
 * 0x+100 (ai3) Unused
 * 0x+108 (ai4) Mounted Flag (1 if true)
 * 0x+110 (ai5) x-Direction

Peach's Bombs (ID: 291)

 * 0x+F0 (ai1)/F8 (ai2) Unused
 * 0x+100 (ai3) Frame timer.
 * 0x+108 (ai4) Explosion state
 * 110 (ai5) Unused

Toad's Boomerang (ID: 292)

 * 0x100 (ai1) (FIELD_DFLOAT) Unknown. Init to 1
 * 0x110 (ai5) (FIELD_DFLOAT) Follows player character (1 is follows)