summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2017-12-03 23:33:49 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2017-12-03 23:33:49 -0500
commitfeb0d13534c9fbd424091297e2510b2f0e206402 (patch)
tree02b2b5282206256f15121b25a71b6b0a16a28a0b /src
parent3dd7ec7526af6f49b77367d91cd1a9565847dc64 (diff)
sub_800E174
Diffstat (limited to 'src')
-rw-r--r--src/link_rfu.c80
1 files changed, 77 insertions, 3 deletions
diff --git a/src/link_rfu.c b/src/link_rfu.c
index eaf919bae..b663ec20e 100644
--- a/src/link_rfu.c
+++ b/src/link_rfu.c
@@ -45,6 +45,8 @@ static void sub_800D610(void);
void sub_800D630(void);
bool8 sub_800DAC8(struct UnkRfuStruct_2_Sub_c1c *q1, u8 *q2);
bool32 sub_8010454(u16 a0);
+u8 sub_8011A74(void);
+u8 sub_8012224(void);
// .rodata
@@ -2138,12 +2140,84 @@ u8 sub_800E124(void)
return 0;
}
-void sub_800E15C(struct Sprite *sprite, int val)
+void sub_800E15C(struct Sprite *sprite, int signalStrengthAnimNum)
{
- if (sprite->data2 != val)
+ if (sprite->data2 != signalStrengthAnimNum)
{
- sprite->data2 = val;
+ sprite->data2 = signalStrengthAnimNum;
sprite->data3 = 0;
sprite->data4 = 0;
}
}
+
+void sub_800E174(void)
+{
+ if (gWirelessStatusIndicatorSpriteId != 0xFF && gSprites[gWirelessStatusIndicatorSpriteId].data7 == 0x1234)
+ {
+ struct Sprite *sprite = &gSprites[gWirelessStatusIndicatorSpriteId];
+ u8 signalStrength = 255;
+ u8 i = 0;
+ if (gUnknown_03007890->unk_00 == 1)
+ {
+ for (i = 0; i < GetLinkPlayerCount() - 1; i++)
+ {
+ if (signalStrength >= sub_800DD1C(i + 1))
+ {
+ signalStrength = sub_800DD1C(i + 1);
+ }
+ }
+ }
+ else
+ {
+ signalStrength = sub_800E124();
+ }
+ if (sub_8012224() == TRUE)
+ {
+ sprite->data0 = 4;
+ }
+ else if (signalStrength < 25)
+ {
+ sprite->data0 = 3;
+ }
+ else if (signalStrength >= 25 && signalStrength < 127)
+ {
+ sprite->data0 = 2;
+ }
+ else if (signalStrength >= 127 && signalStrength < 229)
+ {
+ sprite->data0 = 1;
+ }
+ else if (signalStrength >= 229)
+ {
+ sprite->data0 = 0;
+ }
+ if (sprite->data0 != sprite->data1)
+ {
+ sub_800E15C(sprite, sprite->data0);
+ sprite->data1 = sprite->data0;
+ }
+ if (sprite->anims[sprite->data2][sprite->data4].frame.duration < sprite->data3)
+ {
+ sprite->data4++;
+ sprite->data3 = 0;
+ if (sprite->anims[sprite->data2][sprite->data4].type == -2)
+ {
+ sprite->data4 = 0;
+ }
+ }
+ else
+ {
+ sprite->data3++;
+ }
+ gMain.oamBuffer[125] = sWirelessStatusIndicatorOamData;
+ gMain.oamBuffer[125].x = sprite->pos1.x + sprite->centerToCornerVecX;
+ gMain.oamBuffer[125].y = sprite->pos1.y + sprite->centerToCornerVecY;
+ gMain.oamBuffer[125].paletteNum = sprite->oam.paletteNum;
+ gMain.oamBuffer[125].tileNum = sprite->data6 + sprite->anims[sprite->data2][sprite->data4].frame.imageValue;
+ CpuCopy16(gMain.oamBuffer + 125, (struct OamData *)OAM + 125, sizeof(struct OamData));
+ if (sub_8011A74() == 1)
+ {
+ sub_800E084();
+ }
+ }
+}