pokeemerald/src/wallclock.c

1111 lines
25 KiB
C
Raw Normal View History

2017-11-25 00:00:26 +01:00
#include "global.h"
#include "bg.h"
#include "clock.h"
2018-11-12 15:04:32 +01:00
#include "decompress.h"
2017-11-25 00:00:26 +01:00
#include "event_data.h"
2018-11-12 15:04:32 +01:00
#include "gpu_regs.h"
2017-11-25 00:00:26 +01:00
#include "graphics.h"
2018-11-12 15:04:32 +01:00
#include "main.h"
2017-11-25 00:00:26 +01:00
#include "menu.h"
2018-11-12 15:04:32 +01:00
#include "palette.h"
#include "rtc.h"
2018-01-29 17:47:12 +01:00
#include "scanline_effect.h"
2017-11-25 03:06:46 +01:00
#include "sound.h"
2018-11-12 15:04:32 +01:00
#include "strings.h"
#include "task.h"
#include "text.h"
#include "text_window.h"
2017-11-25 04:08:12 +01:00
#include "trig.h"
2018-11-12 15:04:32 +01:00
#include "wallclock.h"
#include "window.h"
2019-04-04 23:05:46 +02:00
#include "constants/rgb.h"
2018-11-12 15:04:32 +01:00
#include "constants/songs.h"
2017-11-25 04:43:05 +01:00
2020-08-29 21:50:23 +02:00
static void CB2_WallClock(void);
static void Task_SetClock_WaitFadeIn(u8 taskId);
static void Task_SetClock_HandleInput(u8 taskId);
static void Task_SetClock_AskConfirm(u8 taskId);
static void Task_SetClock_HandleConfirmInput(u8 taskId);
static void Task_SetClock_Confirmed(u8 taskId);
static void Task_SetClock_Exit(u8 taskId);
static void Task_ViewClock_WaitFadeIn(u8 taskId);
static void Task_ViewClock_HandleInput(u8 taskId);
static void Task_ViewClock_FadeOut(u8 taskId);
static void Task_ViewClock_Exit(u8 taskId);
2018-11-12 15:04:32 +01:00
static u16 CalcNewMinHandAngle(u16 angle, u8 direction, u8 speed);
static bool32 AdvanceClock(u8 taskId, u8 direction);
static void UpdateClockPeriod(u8 taskId, u8 direction);
2017-12-16 16:23:05 +01:00
static void InitClockWithRtc(u8 taskId);
static void SpriteCB_MinuteHand(struct Sprite *sprite);
static void SpriteCB_HourHand(struct Sprite *sprite);
static void SpriteCB_PMIndicator(struct Sprite *sprite);
2020-08-29 21:50:23 +02:00
static void SpriteCB_AMIndicator(struct Sprite *sprite);
2018-11-12 15:04:32 +01:00
#define tMinuteHandAngle data[0]
#define tHourHandAngle data[1]
#define tHours data[2]
#define tMinutes data[3]
2020-08-29 21:50:23 +02:00
#define tMoveDir data[4]
2018-11-12 15:04:32 +01:00
#define tPeriod data[5]
2020-08-29 21:50:23 +02:00
#define tMoveSpeed data[6]
2018-11-12 15:04:32 +01:00
2020-08-29 21:50:23 +02:00
#define GFXTAG_WALL_CLOCK_HAND 0x1000
#define PALTAG_WALL_CLOCK_MALE 0x1000
#define PALTAG_WALL_CLOCK_FEMALE 0x1001
2018-11-12 15:04:32 +01:00
enum
{
PERIOD_AM,
PERIOD_PM,
};
enum
{
2020-08-29 21:50:23 +02:00
MOVE_NONE,
MOVE_BACKWARD,
MOVE_FORWARD,
2018-11-12 15:04:32 +01:00
};
2020-08-29 21:50:23 +02:00
static const u32 sHand_Gfx[] = INCBIN_U32("graphics/wallclock/hand.4bpp.lz");
static const u16 sTextPrompt_Pal[] = INCBIN_U16("graphics/wallclock/text_prompt.gbapal"); // for "Cancel" or "Confirm"
2017-11-25 00:00:26 +01:00
2020-08-29 21:50:23 +02:00
static const struct WindowTemplate sWindowTemplates[] =
2018-09-02 17:10:06 +02:00
{
{
2018-10-27 00:53:07 +02:00
.bg = 0,
2018-09-02 17:10:06 +02:00
.tilemapLeft = 3,
.tilemapTop = 17,
.width = 24,
.height = 2,
.paletteNum = 14,
.baseBlock = 512
},
{
2018-10-27 00:53:07 +02:00
.bg = 2,
2018-09-02 17:10:06 +02:00
.tilemapLeft = 24,
.tilemapTop = 16,
.width = 6,
.height = 2,
.paletteNum = 12,
.baseBlock = 560
},
2017-11-25 01:06:01 +01:00
DUMMY_WIN_TEMPLATE
};
2020-08-29 21:50:23 +02:00
static const struct WindowTemplate sWindowTemplate_ConfirmYesNo =
2018-09-02 17:10:06 +02:00
{
2018-10-27 00:53:07 +02:00
.bg = 0,
2018-09-02 17:10:06 +02:00
.tilemapLeft = 24,
.tilemapTop = 9,
.width = 5,
.height = 4,
.paletteNum = 14,
.baseBlock = 572
2017-11-25 01:06:01 +01:00
};
2020-08-29 21:50:23 +02:00
static const struct BgTemplate sBgTemplates[] =
{
2017-11-25 01:06:01 +01:00
{
.bg = 0,
.charBaseIndex = 2,
.mapBaseIndex = 31,
.priority = 0
},
{
.bg = 2,
.charBaseIndex = 1,
.mapBaseIndex = 8,
.priority = 1
},
{
.bg = 3,
.charBaseIndex = 0,
.mapBaseIndex = 7,
.priority = 2
}
};
2020-08-29 21:50:23 +02:00
static const struct CompressedSpriteSheet sSpriteSheet_ClockHand =
{
2020-08-29 21:50:23 +02:00
sHand_Gfx, 0x2000, GFXTAG_WALL_CLOCK_HAND
2017-11-25 01:06:01 +01:00
};
2020-08-29 21:50:23 +02:00
static const u8 sUnused[8] = {0};
2020-08-29 21:50:23 +02:00
static const struct SpritePalette sSpritePalettes_Clock[] =
{
{
2020-08-29 21:50:23 +02:00
.data = gWallClockMale_Pal,
.tag = PALTAG_WALL_CLOCK_MALE
},
{
2020-08-29 21:50:23 +02:00
.data = gWallClockFemale_Pal,
.tag = PALTAG_WALL_CLOCK_FEMALE
},
2017-11-25 01:06:01 +01:00
{}
};
2020-08-29 21:50:23 +02:00
static const struct OamData sOam_ClockHand =
{
2021-04-15 08:04:01 +02:00
.y = DISPLAY_HEIGHT,
.shape = SPRITE_SHAPE(64x64),
.size = SPRITE_SIZE(64x64),
2018-11-12 15:04:32 +01:00
.priority = 1,
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd sAnim_MinuteHand[] =
{
ANIMCMD_FRAME(0, 30),
2018-11-12 15:04:32 +01:00
ANIMCMD_END,
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd sAnim_HourHand[] =
{
ANIMCMD_FRAME(64, 30),
2018-11-12 15:04:32 +01:00
ANIMCMD_END,
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd *const sAnims_MinuteHand[] =
{
2020-08-29 21:50:23 +02:00
sAnim_MinuteHand
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd *const sAnims_HourHand[] =
{
2020-08-29 21:50:23 +02:00
sAnim_HourHand
};
2020-08-29 21:50:23 +02:00
static const struct SpriteTemplate sSpriteTemplate_MinuteHand =
2018-09-02 17:10:06 +02:00
{
2020-08-29 21:50:23 +02:00
.tileTag = GFXTAG_WALL_CLOCK_HAND,
.paletteTag = PALTAG_WALL_CLOCK_MALE,
.oam = &sOam_ClockHand,
.anims = sAnims_MinuteHand,
2018-09-02 17:10:06 +02:00
.images = NULL,
.affineAnims = gDummySpriteAffineAnimTable,
2018-11-12 15:04:32 +01:00
.callback = SpriteCB_MinuteHand,
2018-09-02 17:10:06 +02:00
};
2020-08-29 21:50:23 +02:00
static const struct SpriteTemplate sSpriteTemplate_HourHand =
2018-09-02 17:10:06 +02:00
{
2020-08-29 21:50:23 +02:00
.tileTag = GFXTAG_WALL_CLOCK_HAND,
.paletteTag = PALTAG_WALL_CLOCK_MALE,
.oam = &sOam_ClockHand,
.anims = sAnims_HourHand,
2018-09-02 17:10:06 +02:00
.images = NULL,
.affineAnims = gDummySpriteAffineAnimTable,
2018-11-12 15:04:32 +01:00
.callback = SpriteCB_HourHand,
};
2020-08-29 21:50:23 +02:00
static const struct OamData sOam_PeriodIndicator =
{
2021-04-15 08:04:01 +02:00
.y = DISPLAY_HEIGHT,
.shape = SPRITE_SHAPE(16x16),
.size = SPRITE_SIZE(16x16),
2018-11-12 15:04:32 +01:00
.priority = 3,
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd sAnim_PM[] =
{
2018-11-12 15:04:32 +01:00
ANIMCMD_FRAME(132, 30),
ANIMCMD_END,
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd sAnim_AM[] =
{
2018-11-12 15:04:32 +01:00
ANIMCMD_FRAME(128, 30),
ANIMCMD_END,
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd *const sAnims_PM[] =
{
2020-08-29 21:50:23 +02:00
sAnim_PM
};
2020-08-29 21:50:23 +02:00
static const union AnimCmd *const sAnims_AM[] =
{
2020-08-29 21:50:23 +02:00
sAnim_AM
};
2020-08-29 21:50:23 +02:00
static const struct SpriteTemplate sSpriteTemplate_PM =
2018-09-02 17:10:06 +02:00
{
2020-08-29 21:50:23 +02:00
.tileTag = GFXTAG_WALL_CLOCK_HAND,
.paletteTag = PALTAG_WALL_CLOCK_MALE,
.oam = &sOam_PeriodIndicator,
.anims = sAnims_PM,
2018-09-02 17:10:06 +02:00
.images = NULL,
.affineAnims = gDummySpriteAffineAnimTable,
2020-08-29 21:50:23 +02:00
.callback = SpriteCB_PMIndicator
2018-09-02 17:10:06 +02:00
};
2020-08-29 21:50:23 +02:00
static const struct SpriteTemplate sSpriteTemplate_AM =
2018-09-02 17:10:06 +02:00
{
2020-08-29 21:50:23 +02:00
.tileTag = GFXTAG_WALL_CLOCK_HAND,
.paletteTag = PALTAG_WALL_CLOCK_MALE,
.oam = &sOam_PeriodIndicator,
.anims = sAnims_AM,
2018-09-02 17:10:06 +02:00
.images = NULL,
.affineAnims = gDummySpriteAffineAnimTable,
2020-08-29 21:50:23 +02:00
.callback = SpriteCB_AMIndicator
};
static const s8 sClockHandCoords[][2] =
{
2017-11-25 02:46:29 +01:00
{ 0x00, -0x18},
{ 0x01, -0x19},
{ 0x01, -0x19},
{ 0x02, -0x19},
{ 0x02, -0x19},
{ 0x02, -0x19},
{ 0x03, -0x18},
{ 0x03, -0x19},
{ 0x04, -0x19},
{ 0x04, -0x19},
{ 0x04, -0x19},
{ 0x05, -0x19},
{ 0x05, -0x19},
{ 0x06, -0x18},
{ 0x06, -0x18},
{ 0x06, -0x18},
{ 0x07, -0x18},
{ 0x07, -0x18},
{ 0x07, -0x18},
{ 0x08, -0x18},
{ 0x08, -0x18},
{ 0x09, -0x18},
{ 0x09, -0x18},
{ 0x0a, -0x17},
{ 0x0a, -0x17},
{ 0x0b, -0x16},
{ 0x0b, -0x16},
{ 0x0b, -0x16},
{ 0x0c, -0x16},
{ 0x0c, -0x15},
{ 0x0d, -0x15},
{ 0x0d, -0x15},
{ 0x0d, -0x15},
{ 0x0e, -0x15},
{ 0x0e, -0x15},
{ 0x0e, -0x14},
{ 0x0e, -0x14},
{ 0x0f, -0x14},
{ 0x0f, -0x13},
{ 0x10, -0x13},
{ 0x10, -0x13},
{ 0x10, -0x13},
{ 0x10, -0x12},
{ 0x10, -0x12},
{ 0x11, -0x12},
{ 0x11, -0x11},
{ 0x11, -0x11},
{ 0x12, -0x11},
{ 0x12, -0x11},
{ 0x12, -0x10},
{ 0x12, -0x10},
{ 0x13, -0x10},
{ 0x13, -0x0f},
{ 0x13, -0x0f},
{ 0x14, -0x0f},
{ 0x14, -0x0e},
{ 0x14, -0x0e},
{ 0x14, -0x0d},
{ 0x14, -0x0d},
{ 0x15, -0x0d},
{ 0x15, -0x0d},
{ 0x15, -0x0c},
{ 0x16, -0x0c},
{ 0x16, -0x0c},
{ 0x16, -0x0b},
{ 0x16, -0x0b},
{ 0x16, -0x0a},
{ 0x17, -0x0a},
{ 0x17, -0x09},
{ 0x17, -0x09},
{ 0x17, -0x09},
{ 0x17, -0x09},
{ 0x17, -0x08},
{ 0x17, -0x08},
{ 0x17, -0x07},
{ 0x17, -0x07},
{ 0x17, -0x06},
{ 0x18, -0x06},
{ 0x18, -0x06},
{ 0x19, -0x05},
{ 0x19, -0x05},
{ 0x18, -0x04},
{ 0x19, -0x04},
{ 0x18, -0x03},
{ 0x19, -0x03},
{ 0x19, -0x03},
{ 0x19, -0x02},
{ 0x19, -0x02},
{ 0x18, -0x01},
{ 0x19, -0x01},
{ 0x18, 0x00},
{ 0x18, 0x00},
{ 0x18, 0x00},
{ 0x18, 0x01},
{ 0x18, 0x01},
{ 0x19, 0x02},
{ 0x18, 0x02},
{ 0x19, 0x02},
{ 0x18, 0x03},
{ 0x18, 0x03},
{ 0x19, 0x04},
{ 0x18, 0x04},
{ 0x18, 0x05},
{ 0x18, 0x05},
{ 0x18, 0x05},
{ 0x18, 0x06},
{ 0x17, 0x06},
{ 0x17, 0x06},
{ 0x17, 0x07},
{ 0x17, 0x08},
{ 0x17, 0x08},
{ 0x17, 0x08},
{ 0x17, 0x09},
{ 0x17, 0x09},
{ 0x17, 0x0a},
{ 0x16, 0x0a},
{ 0x16, 0x0a},
{ 0x16, 0x0b},
{ 0x16, 0x0b},
{ 0x16, 0x0b},
{ 0x16, 0x0c},
{ 0x15, 0x0c},
{ 0x15, 0x0c},
{ 0x15, 0x0d},
{ 0x14, 0x0d},
{ 0x14, 0x0d},
{ 0x13, 0x0d},
{ 0x13, 0x0d},
{ 0x13, 0x0e},
{ 0x13, 0x0e},
{ 0x13, 0x0f},
{ 0x13, 0x0f},
{ 0x12, 0x0f},
{ 0x12, 0x10},
{ 0x11, 0x10},
{ 0x11, 0x10},
{ 0x11, 0x11},
{ 0x11, 0x11},
{ 0x10, 0x11},
{ 0x10, 0x12},
{ 0x10, 0x12},
{ 0x0f, 0x12},
{ 0x0e, 0x12},
{ 0x0f, 0x13},
{ 0x0e, 0x13},
{ 0x0e, 0x13},
{ 0x0d, 0x13},
{ 0x0d, 0x14},
{ 0x0d, 0x14},
{ 0x0d, 0x14},
{ 0x0c, 0x14},
{ 0x0c, 0x14},
{ 0x0c, 0x15},
{ 0x0b, 0x15},
{ 0x0b, 0x15},
{ 0x0b, 0x15},
{ 0x0a, 0x15},
{ 0x0a, 0x16},
{ 0x0a, 0x16},
{ 0x09, 0x16},
{ 0x09, 0x16},
{ 0x08, 0x16},
{ 0x07, 0x16},
{ 0x07, 0x17},
{ 0x07, 0x17},
{ 0x06, 0x17},
{ 0x06, 0x17},
{ 0x05, 0x17},
{ 0x05, 0x17},
{ 0x05, 0x18},
{ 0x04, 0x18},
{ 0x04, 0x18},
{ 0x04, 0x18},
{ 0x03, 0x18},
{ 0x02, 0x18},
{ 0x02, 0x18},
{ 0x01, 0x18},
{ 0x01, 0x18},
{ 0x00, 0x18},
{ 0x00, 0x18},
{-0x01, 0x17},
{ 0x00, 0x18},
{ 0x00, 0x18},
{-0x01, 0x18},
{-0x01, 0x18},
{-0x02, 0x18},
{-0x02, 0x18},
{-0x03, 0x18},
{-0x03, 0x18},
{-0x04, 0x18},
{-0x04, 0x18},
{-0x05, 0x18},
{-0x05, 0x17},
{-0x05, 0x17},
{-0x06, 0x17},
{-0x06, 0x17},
{-0x07, 0x17},
{-0x07, 0x17},
{-0x07, 0x17},
{-0x08, 0x17},
{-0x08, 0x16},
{-0x09, 0x16},
{-0x09, 0x16},
{-0x0a, 0x16},
{-0x0a, 0x16},
{-0x0a, 0x15},
{-0x0b, 0x15},
{-0x0b, 0x15},
{-0x0b, 0x15},
{-0x0b, 0x14},
{-0x0c, 0x14},
{-0x0c, 0x14},
{-0x0d, 0x14},
{-0x0d, 0x14},
{-0x0d, 0x13},
{-0x0e, 0x13},
{-0x0e, 0x13},
{-0x0e, 0x13},
{-0x0e, 0x12},
{-0x0f, 0x12},
{-0x0f, 0x12},
{-0x0f, 0x11},
{-0x10, 0x11},
{-0x10, 0x11},
{-0x11, 0x11},
{-0x11, 0x10},
{-0x11, 0x10},
{-0x12, 0x10},
{-0x11, 0x0f},
{-0x12, 0x0f},
{-0x12, 0x0f},
{-0x13, 0x0f},
{-0x13, 0x0e},
{-0x13, 0x0e},
{-0x13, 0x0d},
{-0x13, 0x0d},
{-0x14, 0x0d},
{-0x14, 0x0c},
{-0x14, 0x0c},
{-0x15, 0x0c},
{-0x15, 0x0c},
{-0x15, 0x0b},
{-0x15, 0x0b},
{-0x15, 0x0a},
{-0x15, 0x0a},
{-0x15, 0x09},
{-0x16, 0x09},
{-0x16, 0x09},
{-0x16, 0x08},
{-0x16, 0x08},
{-0x16, 0x07},
{-0x17, 0x07},
{-0x17, 0x07},
{-0x17, 0x06},
{-0x17, 0x06},
{-0x17, 0x05},
{-0x18, 0x05},
{-0x17, 0x04},
{-0x17, 0x04},
{-0x18, 0x04},
{-0x18, 0x04},
{-0x18, 0x03},
{-0x18, 0x03},
{-0x18, 0x02},
{-0x18, 0x02},
{-0x18, 0x01},
{-0x18, 0x01},
{-0x18, 0x01},
{-0x18, 0x00},
{-0x19, 0x00},
{-0x18, -0x01},
{-0x19, -0x01},
{-0x18, -0x01},
{-0x18, -0x02},
{-0x18, -0x02},
{-0x18, -0x03},
{-0x18, -0x03},
{-0x18, -0x04},
{-0x18, -0x04},
{-0x18, -0x04},
{-0x18, -0x05},
{-0x18, -0x05},
{-0x18, -0x06},
{-0x18, -0x06},
{-0x17, -0x06},
{-0x17, -0x07},
{-0x17, -0x07},
{-0x17, -0x08},
{-0x17, -0x08},
{-0x17, -0x09},
{-0x17, -0x09},
{-0x16, -0x09},
{-0x16, -0x09},
{-0x16, -0x0a},
{-0x16, -0x0a},
{-0x15, -0x0a},
{-0x15, -0x0b},
{-0x16, -0x0b},
{-0x16, -0x0c},
{-0x15, -0x0c},
{-0x15, -0x0d},
{-0x15, -0x0d},
{-0x14, -0x0d},
{-0x15, -0x0e},
{-0x14, -0x0e},
{-0x14, -0x0e},
{-0x13, -0x0e},
{-0x13, -0x0f},
{-0x13, -0x0f},
{-0x12, -0x10},
{-0x12, -0x10},
{-0x12, -0x10},
{-0x12, -0x11},
{-0x12, -0x11},
{-0x11, -0x11},
{-0x11, -0x12},
{-0x11, -0x12},
{-0x10, -0x12},
{-0x10, -0x12},
{-0x10, -0x13},
{-0x10, -0x13},
{-0x0f, -0x13},
{-0x0f, -0x13},
{-0x0f, -0x14},
{-0x0e, -0x14},
{-0x0e, -0x14},
{-0x0e, -0x15},
{-0x0d, -0x15},
{-0x0d, -0x15},
{-0x0d, -0x15},
{-0x0c, -0x15},
{-0x0c, -0x16},
{-0x0b, -0x16},
{-0x0b, -0x16},
{-0x0b, -0x16},
{-0x0a, -0x16},
{-0x0a, -0x16},
{-0x09, -0x16},
{-0x09, -0x17},
{-0x09, -0x17},
{-0x08, -0x17},
{-0x08, -0x17},
{-0x07, -0x17},
{-0x07, -0x17},
{-0x07, -0x18},
{-0x06, -0x18},
{-0x06, -0x18},
{-0x05, -0x18},
{-0x05, -0x18},
{-0x04, -0x18},
{-0x04, -0x18},
{-0x04, -0x18},
{-0x04, -0x19},
{-0x03, -0x19},
{-0x02, -0x19},
{-0x02, -0x18},
{-0x02, -0x18},
{-0x01, -0x19},
{-0x01, -0x19},
{ 0x00, -0x19}
};
2017-11-25 00:00:26 +01:00
2020-08-29 21:50:23 +02:00
static void VBlankCB_WallClock(void)
2017-11-25 00:00:26 +01:00
{
LoadOam();
ProcessSpriteCopyRequests();
TransferPlttBuffer();
}
2017-12-16 16:23:05 +01:00
static void LoadWallClockGraphics(void)
2017-11-25 00:00:26 +01:00
{
SetVBlankCallback(NULL);
2018-12-26 13:43:07 +01:00
SetGpuReg(REG_OFFSET_DISPCNT, 0);
SetGpuReg(REG_OFFSET_BG3CNT, 0);
SetGpuReg(REG_OFFSET_BG2CNT, 0);
SetGpuReg(REG_OFFSET_BG1CNT, 0);
SetGpuReg(REG_OFFSET_BG0CNT, 0);
2017-11-25 00:00:26 +01:00
ChangeBgX(0, 0, 0);
ChangeBgY(0, 0, 0);
ChangeBgX(1, 0, 0);
ChangeBgY(1, 0, 0);
ChangeBgX(2, 0, 0);
ChangeBgY(2, 0, 0);
ChangeBgX(3, 0, 0);
ChangeBgY(3, 0, 0);
DmaFillLarge16(3, 0, (void *)VRAM, VRAM_SIZE, 0x1000);
DmaClear32(3, (void *)OAM, OAM_SIZE);
DmaClear16(3, (void *)PLTT, PLTT_SIZE);
2020-08-29 21:50:23 +02:00
LZ77UnCompVram(gWallClock_Gfx, (void *)VRAM);
if (gSpecialVar_0x8004 == MALE)
LoadPalette(gWallClockMale_Pal, 0, 32);
2017-11-25 00:00:26 +01:00
else
2020-08-29 21:50:23 +02:00
LoadPalette(gWallClockFemale_Pal, 0, 32);
LoadPalette(GetOverworldTextboxPalettePtr(), 0xe0, 32);
LoadPalette(sTextPrompt_Pal, 0xc0, 8);
2017-11-25 00:00:26 +01:00
ResetBgsAndClearDma3BusyFlags(0);
2020-08-29 21:50:23 +02:00
InitBgsFromTemplates(0, sBgTemplates, ARRAY_COUNT(sBgTemplates));
InitWindows(sWindowTemplates);
2017-11-25 00:00:26 +01:00
DeactivateAllTextPrinters();
2018-07-15 13:23:38 +02:00
LoadUserWindowBorderGfx(0, 0x250, 0xd0);
ClearScheduledBgCopiesToVram();
2018-01-16 18:59:06 +01:00
ScanlineEffect_Stop();
2017-11-25 00:00:26 +01:00
ResetTasks();
ResetSpriteData();
ResetPaletteFade();
FreeAllSpritePalettes();
2020-08-29 21:50:23 +02:00
LoadCompressedSpriteSheet(&sSpriteSheet_ClockHand);
LoadSpritePalettes(sSpritePalettes_Clock);
2017-11-25 00:00:26 +01:00
}
2017-12-16 16:23:05 +01:00
static void WallClockInit(void)
{
2021-02-24 17:01:02 +01:00
BeginNormalPaletteFade(PALETTES_ALL, 0, 16, 0, RGB_BLACK);
EnableInterrupts(INTR_FLAG_VBLANK);
2020-08-29 21:50:23 +02:00
SetVBlankCallback(VBlankCB_WallClock);
SetMainCallback2(CB2_WallClock);
2018-12-26 13:43:07 +01:00
SetGpuReg(REG_OFFSET_BLDCNT, 0);
SetGpuReg(REG_OFFSET_BLDALPHA, 0);
SetGpuReg(REG_OFFSET_BLDY, 0);
SetGpuReg(REG_OFFSET_DISPCNT, DISPCNT_OBJ_1D_MAP | DISPCNT_OBJ_ON);
ShowBg(0);
ShowBg(2);
ShowBg(3);
}
void CB2_StartWallClock(void)
{
u8 taskId;
u8 spriteId;
LoadWallClockGraphics();
2020-08-29 21:50:23 +02:00
LZ77UnCompVram(gWallClockStart_Tilemap, (u16 *)BG_SCREEN_ADDR(7));
2017-12-16 16:23:05 +01:00
2020-08-29 21:50:23 +02:00
taskId = CreateTask(Task_SetClock_WaitFadeIn, 0);
2017-12-16 16:23:05 +01:00
gTasks[taskId].tHours = 10;
gTasks[taskId].tMinutes = 0;
2020-08-29 21:50:23 +02:00
gTasks[taskId].tMoveDir = 0;
2017-12-16 16:23:05 +01:00
gTasks[taskId].tPeriod = 0;
2020-08-29 21:50:23 +02:00
gTasks[taskId].tMoveSpeed = 0;
2017-12-16 16:23:05 +01:00
gTasks[taskId].tMinuteHandAngle = 0;
gTasks[taskId].tHourHandAngle = 300;
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_MinuteHand, 120, 80, 1);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
gSprites[spriteId].oam.affineMode = ST_OAM_AFFINE_NORMAL;
gSprites[spriteId].oam.matrixNum = 0;
2017-12-16 16:23:05 +01:00
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_HourHand, 120, 80, 0);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
gSprites[spriteId].oam.affineMode = ST_OAM_AFFINE_NORMAL;
gSprites[spriteId].oam.matrixNum = 1;
2017-12-16 16:23:05 +01:00
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_PM, 120, 80, 2);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
gSprites[spriteId].data[1] = 45;
2017-12-16 16:23:05 +01:00
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_AM, 120, 80, 2);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
gSprites[spriteId].data[1] = 90;
2017-12-16 16:23:05 +01:00
WallClockInit();
2021-10-30 22:47:37 +02:00
AddTextPrinterParameterized(1, FONT_NORMAL, gText_Confirm3, 0, 1, 0, NULL);
PutWindowTilemap(1);
2020-05-14 10:37:09 +02:00
ScheduleBgCopyTilemapToVram(2);
}
2017-11-25 02:06:29 +01:00
void CB2_ViewWallClock(void)
2017-11-25 02:06:29 +01:00
{
u8 taskId;
u8 spriteId;
2017-12-16 16:23:05 +01:00
u8 angle1;
u8 angle2;
2017-11-25 02:06:29 +01:00
LoadWallClockGraphics();
2020-08-29 21:50:23 +02:00
LZ77UnCompVram(gWallClockView_Tilemap, (u16 *)BG_SCREEN_ADDR(7));
2017-12-16 16:23:05 +01:00
2020-08-29 21:50:23 +02:00
taskId = CreateTask(Task_ViewClock_WaitFadeIn, 0);
2017-12-16 16:23:05 +01:00
InitClockWithRtc(taskId);
2020-08-29 21:50:23 +02:00
if (gTasks[taskId].tPeriod == PERIOD_AM)
2017-11-25 02:06:29 +01:00
{
2017-12-16 16:23:05 +01:00
angle1 = 45;
angle2 = 90;
2017-11-25 02:06:29 +01:00
}
else
{
2017-12-16 16:23:05 +01:00
angle1 = 90;
angle2 = 135;
2017-11-25 02:06:29 +01:00
}
2017-12-17 23:45:27 +01:00
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_MinuteHand, 120, 80, 1);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
2017-11-25 02:06:29 +01:00
gSprites[spriteId].oam.affineMode = ST_OAM_AFFINE_NORMAL;
gSprites[spriteId].oam.matrixNum = 0;
2017-12-17 23:45:27 +01:00
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_HourHand, 120, 80, 0);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
2017-11-25 02:06:29 +01:00
gSprites[spriteId].oam.affineMode = ST_OAM_AFFINE_NORMAL;
gSprites[spriteId].oam.matrixNum = 1;
2017-12-17 23:45:27 +01:00
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_PM, 120, 80, 2);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
2017-12-16 16:23:05 +01:00
gSprites[spriteId].data[1] = angle1;
2017-12-17 23:45:27 +01:00
2020-08-29 21:50:23 +02:00
spriteId = CreateSprite(&sSpriteTemplate_AM, 120, 80, 2);
2017-12-16 03:04:25 +01:00
gSprites[spriteId].data[0] = taskId;
2017-12-16 16:23:05 +01:00
gSprites[spriteId].data[1] = angle2;
2017-12-17 23:45:27 +01:00
2017-12-16 16:23:05 +01:00
WallClockInit();
2017-12-17 23:45:27 +01:00
2021-10-30 22:47:37 +02:00
AddTextPrinterParameterized(1, FONT_NORMAL, gText_Cancel4, 0, 1, 0, NULL);
2017-11-25 02:06:29 +01:00
PutWindowTilemap(1);
2020-05-14 10:37:09 +02:00
ScheduleBgCopyTilemapToVram(2);
2017-11-25 02:06:29 +01:00
}
2017-11-25 02:46:29 +01:00
2020-08-29 21:50:23 +02:00
static void CB2_WallClock(void)
2017-11-25 02:46:29 +01:00
{
RunTasks();
AnimateSprites();
BuildOamBuffer();
DoScheduledBgTilemapCopiesToVram();
2017-11-25 02:46:29 +01:00
UpdatePaletteFade();
}
2020-08-29 21:50:23 +02:00
static void Task_SetClock_WaitFadeIn(u8 taskId)
2017-11-25 02:46:29 +01:00
{
if (!gPaletteFade.active)
{
2020-08-29 21:50:23 +02:00
gTasks[taskId].func = Task_SetClock_HandleInput;
2017-11-25 02:46:29 +01:00
}
}
2020-08-29 21:50:23 +02:00
static void Task_SetClock_HandleInput(u8 taskId)
2017-11-25 02:46:29 +01:00
{
2017-12-16 16:23:05 +01:00
if (gTasks[taskId].tMinuteHandAngle % 6)
2017-11-25 02:46:29 +01:00
{
2020-08-29 21:50:23 +02:00
gTasks[taskId].tMinuteHandAngle = CalcNewMinHandAngle(gTasks[taskId].tMinuteHandAngle, gTasks[taskId].tMoveDir, gTasks[taskId].tMoveSpeed);
2017-11-25 02:46:29 +01:00
}
else
{
2017-12-16 16:23:05 +01:00
gTasks[taskId].tMinuteHandAngle = gTasks[taskId].tMinutes * 6;
gTasks[taskId].tHourHandAngle = (gTasks[taskId].tHours % 12) * 30 + (gTasks[taskId].tMinutes / 10) * 5;
2020-09-05 03:11:55 +02:00
if (JOY_NEW(A_BUTTON))
2017-11-25 02:46:29 +01:00
{
2020-08-29 21:50:23 +02:00
gTasks[taskId].func = Task_SetClock_AskConfirm;
2017-11-25 02:46:29 +01:00
}
else
{
2020-08-29 21:50:23 +02:00
gTasks[taskId].tMoveDir = MOVE_NONE;
2020-09-05 03:11:55 +02:00
if (JOY_HELD(DPAD_LEFT))
2020-08-29 21:50:23 +02:00
gTasks[taskId].tMoveDir = MOVE_BACKWARD;
2020-09-05 03:11:55 +02:00
if (JOY_HELD(DPAD_RIGHT))
2020-08-29 21:50:23 +02:00
gTasks[taskId].tMoveDir = MOVE_FORWARD;
if (gTasks[taskId].tMoveDir != MOVE_NONE)
2017-11-25 02:46:29 +01:00
{
2020-08-29 21:50:23 +02:00
if (gTasks[taskId].tMoveSpeed < 0xFF)
gTasks[taskId].tMoveSpeed++;
gTasks[taskId].tMinuteHandAngle = CalcNewMinHandAngle(gTasks[taskId].tMinuteHandAngle, gTasks[taskId].tMoveDir, gTasks[taskId].tMoveSpeed);
AdvanceClock(taskId, gTasks[taskId].tMoveDir);
2017-11-25 02:46:29 +01:00
}
else
{
2020-08-29 21:50:23 +02:00
gTasks[taskId].tMoveSpeed = 0;
2017-11-25 02:46:29 +01:00
}
}
}
}
2017-11-25 03:06:46 +01:00
2020-08-29 21:50:23 +02:00
static void Task_SetClock_AskConfirm(u8 taskId)
2017-11-25 03:06:46 +01:00
{
DrawStdFrameWithCustomTileAndPalette(0, FALSE, 0x250, 0x0d);
2021-10-30 22:47:37 +02:00
AddTextPrinterParameterized(0, FONT_NORMAL, gText_IsThisTheCorrectTime, 0, 1, 0, NULL);
2017-11-25 03:06:46 +01:00
PutWindowTilemap(0);
2020-05-14 10:37:09 +02:00
ScheduleBgCopyTilemapToVram(0);
2020-08-29 21:50:23 +02:00
CreateYesNoMenu(&sWindowTemplate_ConfirmYesNo, 0x250, 0x0d, 1);
gTasks[taskId].func = Task_SetClock_HandleConfirmInput;
2017-11-25 03:06:46 +01:00
}
2020-08-29 21:50:23 +02:00
static void Task_SetClock_HandleConfirmInput(u8 taskId)
2017-11-25 03:06:46 +01:00
{
2018-11-05 21:45:54 +01:00
switch (Menu_ProcessInputNoWrapClearOnChoose())
2017-11-25 03:06:46 +01:00
{
2020-08-29 21:50:23 +02:00
case 0: // YES
PlaySE(SE_SELECT);
gTasks[taskId].func = Task_SetClock_Confirmed;
break;
case 1: // NO
case MENU_B_PRESSED:
PlaySE(SE_SELECT);
ClearStdWindowAndFrameToTransparent(0, FALSE);
ClearWindowTilemap(0);
gTasks[taskId].func = Task_SetClock_HandleInput;
break;
2017-11-25 03:06:46 +01:00
}
}
2017-11-25 03:11:32 +01:00
2020-08-29 21:50:23 +02:00
static void Task_SetClock_Confirmed(u8 taskId)
2017-11-25 03:11:32 +01:00
{
2017-12-16 16:23:05 +01:00
RtcInitLocalTimeOffset(gTasks[taskId].tHours, gTasks[taskId].tMinutes);
2021-02-24 17:01:02 +01:00
BeginNormalPaletteFade(PALETTES_ALL, 0, 0, 16, RGB_BLACK);
2020-08-29 21:50:23 +02:00
gTasks[taskId].func = Task_SetClock_Exit;
2017-11-25 03:11:32 +01:00
}
2020-08-29 21:50:23 +02:00
static void Task_SetClock_Exit(u8 taskId)
2017-11-25 03:11:32 +01:00
{
if (!gPaletteFade.active)
{
FreeAllWindowBuffers();
SetMainCallback2(gMain.savedCallback);
}
}
2017-11-25 03:17:50 +01:00
2020-08-29 21:50:23 +02:00
static void Task_ViewClock_WaitFadeIn(u8 taskId)
2017-11-25 03:17:50 +01:00
{
if (!gPaletteFade.active)
2020-08-29 21:50:23 +02:00
gTasks[taskId].func = Task_ViewClock_HandleInput;
2017-11-25 03:17:50 +01:00
}
2020-08-29 21:50:23 +02:00
static void Task_ViewClock_HandleInput(u8 taskId)
2017-11-25 03:17:50 +01:00
{
2017-12-16 16:23:05 +01:00
InitClockWithRtc(taskId);
2020-09-05 03:11:55 +02:00
if (JOY_NEW(A_BUTTON | B_BUTTON))
2020-08-29 21:50:23 +02:00
gTasks[taskId].func = Task_ViewClock_FadeOut;
2017-11-25 03:17:50 +01:00
}
2020-08-29 21:50:23 +02:00
static void Task_ViewClock_FadeOut(u8 taskId)
2017-11-25 03:17:50 +01:00
{
2021-02-24 17:01:02 +01:00
BeginNormalPaletteFade(PALETTES_ALL, 0, 0, 16, RGB_BLACK);
2020-08-29 21:50:23 +02:00
gTasks[taskId].func = Task_ViewClock_Exit;
2017-11-25 03:17:50 +01:00
}
2020-08-29 21:50:23 +02:00
static void Task_ViewClock_Exit(u8 taskId)
2017-11-25 03:17:50 +01:00
{
if (!gPaletteFade.active)
SetMainCallback2(gMain.savedCallback);
}
2017-11-25 03:27:05 +01:00
2018-11-12 15:04:32 +01:00
static u8 CalcMinHandDelta(u16 speed)
2017-11-25 03:27:05 +01:00
{
2018-11-12 15:04:32 +01:00
if (speed > 60)
2017-11-25 03:27:05 +01:00
return 6;
2018-11-12 15:04:32 +01:00
if (speed > 30)
2017-11-25 03:27:05 +01:00
return 3;
2018-11-12 15:04:32 +01:00
if (speed > 10)
2017-11-25 03:27:05 +01:00
return 2;
2020-08-29 21:50:23 +02:00
2017-11-25 03:27:05 +01:00
return 1;
}
2018-11-12 15:04:32 +01:00
static u16 CalcNewMinHandAngle(u16 angle, u8 direction, u8 speed)
2017-11-25 03:27:05 +01:00
{
2018-11-12 15:04:32 +01:00
u8 delta = CalcMinHandDelta(speed);
switch (direction)
2017-11-25 03:27:05 +01:00
{
2020-08-29 21:50:23 +02:00
case MOVE_BACKWARD:
if (angle)
angle -= delta;
else
angle = 360 - delta;
break;
case MOVE_FORWARD:
if (angle < 360 - delta)
angle += delta;
else
angle = 0;
break;
2017-11-25 03:27:05 +01:00
}
2018-11-12 15:04:32 +01:00
return angle;
2017-11-25 03:27:05 +01:00
}
2017-11-25 03:37:42 +01:00
2018-11-12 15:04:32 +01:00
static bool32 AdvanceClock(u8 taskId, u8 direction)
2017-11-25 03:37:42 +01:00
{
2018-11-12 15:04:32 +01:00
switch (direction)
2017-11-25 03:37:42 +01:00
{
2020-08-29 21:50:23 +02:00
case MOVE_BACKWARD:
if (gTasks[taskId].tMinutes > 0)
{
gTasks[taskId].tMinutes--;
}
else
{
gTasks[taskId].tMinutes = 59;
if (gTasks[taskId].tHours > 0)
gTasks[taskId].tHours--;
2017-11-25 03:37:42 +01:00
else
2020-08-29 21:50:23 +02:00
gTasks[taskId].tHours = 23;
UpdateClockPeriod(taskId, direction);
}
break;
case MOVE_FORWARD:
if (gTasks[taskId].tMinutes < 59)
{
gTasks[taskId].tMinutes++;
}
else
{
gTasks[taskId].tMinutes = 0;
if (gTasks[taskId].tHours < 23)
gTasks[taskId].tHours++;
2017-11-25 03:37:42 +01:00
else
2020-08-29 21:50:23 +02:00
gTasks[taskId].tHours = 0;
UpdateClockPeriod(taskId, direction);
}
break;
2017-11-25 03:37:42 +01:00
}
return FALSE;
}
2017-11-25 03:52:22 +01:00
2018-11-12 15:04:32 +01:00
static void UpdateClockPeriod(u8 taskId, u8 direction)
2017-11-25 03:52:22 +01:00
{
2017-12-16 16:23:05 +01:00
u8 hours = gTasks[taskId].tHours;
2018-11-12 15:04:32 +01:00
switch (direction)
2017-11-25 03:52:22 +01:00
{
2020-08-29 21:50:23 +02:00
case MOVE_BACKWARD:
switch (hours)
{
case 11:
gTasks[taskId].tPeriod = PERIOD_AM;
2017-11-25 03:52:22 +01:00
break;
2020-08-29 21:50:23 +02:00
case 23:
gTasks[taskId].tPeriod = PERIOD_PM;
break;
}
break;
case MOVE_FORWARD:
switch (hours)
{
case 0:
gTasks[taskId].tPeriod = PERIOD_AM;
break;
case 12:
gTasks[taskId].tPeriod = PERIOD_PM;
2017-11-25 03:52:22 +01:00
break;
2020-08-29 21:50:23 +02:00
}
break;
2017-11-25 03:52:22 +01:00
}
}
2017-11-25 04:08:12 +01:00
2017-12-16 16:23:05 +01:00
static void InitClockWithRtc(u8 taskId)
2017-11-25 04:08:12 +01:00
{
RtcCalcLocalTime();
2017-12-16 16:23:05 +01:00
gTasks[taskId].tHours = gLocalTime.hours;
gTasks[taskId].tMinutes = gLocalTime.minutes;
gTasks[taskId].tMinuteHandAngle = gTasks[taskId].tMinutes * 6;
gTasks[taskId].tHourHandAngle = (gTasks[taskId].tHours % 12) * 30 + (gTasks[taskId].tMinutes / 10) * 5;
2020-08-29 21:50:23 +02:00
2017-11-25 04:08:12 +01:00
if (gLocalTime.hours < 12)
2018-11-12 15:04:32 +01:00
gTasks[taskId].tPeriod = PERIOD_AM;
2017-11-25 04:08:12 +01:00
else
2018-11-12 15:04:32 +01:00
gTasks[taskId].tPeriod = PERIOD_PM;
2017-11-25 04:08:12 +01:00
}
2017-12-16 16:23:05 +01:00
static void SpriteCB_MinuteHand(struct Sprite *sprite)
2017-11-25 04:08:12 +01:00
{
2017-12-16 16:23:05 +01:00
u16 angle = gTasks[sprite->data[0]].tMinuteHandAngle;
2017-11-25 04:08:12 +01:00
s16 sin = Sin2(angle) / 16;
s16 cos = Cos2(angle) / 16;
2020-08-29 21:50:23 +02:00
u16 x, y;
2017-12-16 16:23:05 +01:00
2017-11-25 04:08:12 +01:00
SetOamMatrix(0, cos, sin, -sin, cos);
2020-08-29 21:50:23 +02:00
x = sClockHandCoords[angle][0];
y = sClockHandCoords[angle][1];
2017-12-16 16:23:05 +01:00
2020-08-29 21:50:23 +02:00
if (x > 128)
x |= 0xff00;
if (y > 128)
y |= 0xff00;
2021-07-07 15:11:52 +02:00
sprite->x2 = x;
sprite->y2 = y;
2017-11-25 04:08:12 +01:00
}
2017-11-25 04:28:13 +01:00
2017-12-16 16:23:05 +01:00
static void SpriteCB_HourHand(struct Sprite *sprite)
2017-11-25 04:28:13 +01:00
{
2017-12-16 16:23:05 +01:00
u16 angle = gTasks[sprite->data[0]].tHourHandAngle;
2017-11-25 04:28:13 +01:00
s16 sin = Sin2(angle) / 16;
s16 cos = Cos2(angle) / 16;
2020-08-29 21:50:23 +02:00
u16 x, y;
2017-12-16 16:23:05 +01:00
2017-11-25 04:28:13 +01:00
SetOamMatrix(1, cos, sin, -sin, cos);
2020-08-29 21:50:23 +02:00
x = sClockHandCoords[angle][0];
y = sClockHandCoords[angle][1];
if (x > 128)
x |= 0xff00;
if (y > 128)
y |= 0xff00;
2021-07-07 15:11:52 +02:00
sprite->x2 = x;
sprite->y2 = y;
2017-11-25 04:28:13 +01:00
}
2020-08-29 21:50:23 +02:00
static void SpriteCB_PMIndicator(struct Sprite *sprite)
2017-11-25 04:28:13 +01:00
{
2020-08-29 21:50:23 +02:00
if (gTasks[sprite->data[0]].tPeriod != PERIOD_AM)
2017-11-25 04:28:13 +01:00
{
2017-12-16 03:04:25 +01:00
if (sprite->data[1] >= 60 && sprite->data[1] < 90)
2017-11-25 04:28:13 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1] += 5;
2017-11-25 04:28:13 +01:00
}
2017-12-16 03:04:25 +01:00
if (sprite->data[1] < 60)
2017-11-25 04:28:13 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1]++;
2017-11-25 04:28:13 +01:00
}
}
else
{
2017-12-16 03:04:25 +01:00
if (sprite->data[1] >= 46 && sprite->data[1] < 76)
2017-11-25 04:28:13 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1] -= 5;
2017-11-25 04:28:13 +01:00
}
2017-12-16 03:04:25 +01:00
if (sprite->data[1] > 75)
2017-11-25 04:28:13 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1]--;
2017-11-25 04:28:13 +01:00
}
}
2021-07-07 15:11:52 +02:00
sprite->x2 = Cos2(sprite->data[1]) * 30 / 0x1000;
sprite->y2 = Sin2(sprite->data[1]) * 30 / 0x1000;
2017-11-25 04:28:13 +01:00
}
2017-11-25 04:30:20 +01:00
2020-08-29 21:50:23 +02:00
static void SpriteCB_AMIndicator(struct Sprite *sprite)
2017-11-25 04:30:20 +01:00
{
2020-08-29 21:50:23 +02:00
if (gTasks[sprite->data[0]].tPeriod != PERIOD_AM)
2017-11-25 04:30:20 +01:00
{
2017-12-16 03:04:25 +01:00
if (sprite->data[1] >= 105 && sprite->data[1] < 135)
2017-11-25 04:30:20 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1] += 5;
2017-11-25 04:30:20 +01:00
}
2017-12-16 03:04:25 +01:00
if (sprite->data[1] < 105)
2017-11-25 04:30:20 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1]++;
2017-11-25 04:30:20 +01:00
}
}
else
{
2017-12-16 03:04:25 +01:00
if (sprite->data[1] >= 91 && sprite->data[1] < 121)
2017-11-25 04:30:20 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1] -= 5;
2017-11-25 04:30:20 +01:00
}
2017-12-16 03:04:25 +01:00
if (sprite->data[1] > 120)
2017-11-25 04:30:20 +01:00
{
2017-12-16 03:04:25 +01:00
sprite->data[1]--;
2017-11-25 04:30:20 +01:00
}
}
2021-07-07 15:11:52 +02:00
sprite->x2 = Cos2(sprite->data[1]) * 30 / 0x1000;
sprite->y2 = Sin2(sprite->data[1]) * 30 / 0x1000;
2017-11-25 04:30:20 +01:00
}