diff options
author | camthesaxman <cameronghall@cox.net> | 2017-11-26 23:33:31 -0600 |
---|---|---|
committer | camthesaxman <cameronghall@cox.net> | 2017-11-26 23:33:31 -0600 |
commit | 5d74d11d3e3047b4b53153365325db9e6999c627 (patch) | |
tree | f15fe9425296d4f95d0cd7190d6f19f852fbfe93 /src/battle/anim/seed.c | |
parent | 48ec0941b4ebbe78fe70ef93d205ce52d2de89b2 (diff) | |
parent | e6500d12a21e9833e08ad25cc6a76b075cff42dd (diff) |
fix merge conflicts
Diffstat (limited to 'src/battle/anim/seed.c')
-rwxr-xr-x | src/battle/anim/seed.c | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/src/battle/anim/seed.c b/src/battle/anim/seed.c new file mode 100755 index 000000000..bd072849a --- /dev/null +++ b/src/battle/anim/seed.c @@ -0,0 +1,50 @@ +#include "global.h" +#include "rom_8077ABC.h" +#include "trig.h" +#include "battle_anim.h" + +extern s16 gBattleAnimArgs[]; +extern u8 gBattleAnimBankAttacker; +extern u8 gBattleAnimBankTarget; + +static void sub_80CAB88(struct Sprite* sprite); +static void sub_80CABC0(struct Sprite* sprite); + +// seed (sprouts a sapling from a seed.) +// Used by Leech Seed. + +void sub_80CAB18(struct Sprite* sprite) +{ + sub_80787B0(sprite, 1); + if (GetBankSide(gBattleAnimBankAttacker)) + { + gBattleAnimArgs[2] = -gBattleAnimArgs[2]; + } + + sprite->data[0] = gBattleAnimArgs[4]; + sprite->data[2] = sub_8077ABC(gBattleAnimBankTarget, 0) + gBattleAnimArgs[2]; + sprite->data[4] = sub_8077ABC(gBattleAnimBankTarget, 1) + gBattleAnimArgs[3]; + sprite->data[5] = gBattleAnimArgs[5]; + sub_80786EC(sprite); + sprite->callback = sub_80CAB88; +} + +void sub_80CAB88(struct Sprite* sprite) +{ + if (sub_8078718(sprite)) + { + sprite->invisible = 1; + sprite->data[0] = 10; + sprite->callback = sub_80782D8; + StoreSpriteCallbackInData(sprite, sub_80CABC0); + } +} + +void sub_80CABC0(struct Sprite* sprite) +{ + sprite->invisible = 0; + StartSpriteAnim(sprite, 1); + sprite->data[0] = 60; + sprite->callback = sub_80782D8; + StoreSpriteCallbackInData(sprite, move_anim_8072740); +} |