amiibo drops

From ZeldaMods (Breath of the Wild)
Revision as of 15:46, 26 October 2018 by imported>Leoetlino (→‎Logic)
Jump to navigation Jump to search

Drop tables

Idx Name Description
0 Normal
1 Normal2 Unused.
2 SmallHit
3 SmallHit2 Unused.
4 BigHit
5 BigHit2 Unused.
6 GreatHit
7 GreatHit2 Unused.

Notes on AmiiboMgr

amiibo code call AmiiboMgr::registerAmiibo[unofficial name][1] every time an amiibo is used.

registerAmiibo

  • First, AmiiboMgr determines if it should reset its daily amiibo use history (stored in the AmiiboTouchHistory flag)[2].
    • If less than 86400 seconds (1 day) have elapsed since the game was launched, don't do anything.[check]
    • AmiiboMgr then computes 10000 * now.year + 100 * now.month + now.day. If the value is different from AmiiboLastTouchDate (which would mean that a day has elapsed), the AmiiboTouchHistory array is cleared.
  • The amiibo UID is inserted into AmiiboTouchHistory. Only the last 100 entries are kept.
  • It is also inserted into AmiiboTouchHistoryTotal. Only the last 200 entries are kept.
  • Finally, AmiiboLastTouchDate is set to 10000 * now.year + 100 * now.month + now.day.

Logic[3]

A SmallHit will happen 20% of the time.

If the amiibo has been scanned 0, 1, 2, 3 or 4 times, you'll get a GreatHit 20% of the time. If you didn't get a GreatHit, the game will ensure you get a BigHit.

If the amiibo has been scanned 5 times or more, you'll always get a GreatHit. In this case, the BigHit table is ignored.

For BigHits and GreatHits, the game uses the 'Remain' tables if Find_4Relic_1stClear is set, 'Parasail' if IsGet_PlayerStole2, and 'Normal' otherwise.

Final drop nums after RNG (note: negative values are set to 0)
Normal SmallHit BigHit GreatHit
GreatHit, no BigHit N - GH SH 0 GH
No GreatHit, BigHit N - BH SH BH 0

References

  1. 0x710064B564 on Switch 1.5.0
  2. 0x710064B3C8
  3. AIDef:Action/ItemAmiiboCreateFromDropTable