Merge pull request #209 from jiangzhengwenjz/pc_screen_effect
pc_screen_effect
This commit is contained in:
@@ -1,477 +0,0 @@
|
|||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.syntax unified
|
|
||||||
|
|
||||||
.text
|
|
||||||
|
|
||||||
thumb_func_start sub_80A0A48
|
|
||||||
sub_80A0A48: @ 80A0A48
|
|
||||||
push {r4,r5,lr}
|
|
||||||
adds r4, r0, 0
|
|
||||||
adds r5, r1, 0
|
|
||||||
adds r3, r2, 0
|
|
||||||
lsls r4, 16
|
|
||||||
lsrs r4, 16
|
|
||||||
lsls r5, 16
|
|
||||||
lsrs r5, 16
|
|
||||||
lsls r3, 24
|
|
||||||
lsrs r3, 24
|
|
||||||
ldr r0, _080A0A6C @ =sub_80A0B0C
|
|
||||||
adds r1, r4, 0
|
|
||||||
adds r2, r5, 0
|
|
||||||
bl sub_80A0AC0
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.align 2, 0
|
|
||||||
_080A0A6C: .4byte sub_80A0B0C
|
|
||||||
thumb_func_end sub_80A0A48
|
|
||||||
|
|
||||||
thumb_func_start sub_80A0A70
|
|
||||||
sub_80A0A70: @ 80A0A70
|
|
||||||
push {r4,r5,lr}
|
|
||||||
adds r4, r0, 0
|
|
||||||
adds r5, r1, 0
|
|
||||||
adds r3, r2, 0
|
|
||||||
lsls r4, 16
|
|
||||||
lsrs r4, 16
|
|
||||||
lsls r5, 16
|
|
||||||
lsrs r5, 16
|
|
||||||
lsls r3, 24
|
|
||||||
lsrs r3, 24
|
|
||||||
ldr r0, _080A0A94 @ =sub_80A0C78
|
|
||||||
adds r1, r4, 0
|
|
||||||
adds r2, r5, 0
|
|
||||||
bl sub_80A0AC0
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.align 2, 0
|
|
||||||
_080A0A94: .4byte sub_80A0C78
|
|
||||||
thumb_func_end sub_80A0A70
|
|
||||||
|
|
||||||
thumb_func_start sub_80A0A98
|
|
||||||
sub_80A0A98: @ 80A0A98
|
|
||||||
push {lr}
|
|
||||||
ldr r0, _080A0AA8 @ =sub_80A0B0C
|
|
||||||
bl FuncIsActiveTask
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
.align 2, 0
|
|
||||||
_080A0AA8: .4byte sub_80A0B0C
|
|
||||||
thumb_func_end sub_80A0A98
|
|
||||||
|
|
||||||
thumb_func_start sub_80A0AAC
|
|
||||||
sub_80A0AAC: @ 80A0AAC
|
|
||||||
push {lr}
|
|
||||||
ldr r0, _080A0ABC @ =sub_80A0C78
|
|
||||||
bl FuncIsActiveTask
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
.align 2, 0
|
|
||||||
_080A0ABC: .4byte sub_80A0C78
|
|
||||||
thumb_func_end sub_80A0AAC
|
|
||||||
|
|
||||||
thumb_func_start sub_80A0AC0
|
|
||||||
sub_80A0AC0: @ 80A0AC0
|
|
||||||
push {r4,r5,lr}
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r4, r1, 16
|
|
||||||
adds r5, r4, 0
|
|
||||||
lsls r3, 24
|
|
||||||
lsrs r3, 24
|
|
||||||
adds r1, r3, 0
|
|
||||||
bl CreateTask
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
adds r2, r0, 0
|
|
||||||
ldr r1, _080A0B08 @ =gTasks
|
|
||||||
lsls r0, r2, 2
|
|
||||||
adds r0, r2
|
|
||||||
lsls r0, 3
|
|
||||||
adds r1, r0, r1
|
|
||||||
movs r0, 0
|
|
||||||
strh r0, [r1, 0x8]
|
|
||||||
movs r0, 0x10
|
|
||||||
cmp r4, 0
|
|
||||||
beq _080A0AEE
|
|
||||||
adds r0, r4, 0
|
|
||||||
_080A0AEE:
|
|
||||||
strh r0, [r1, 0xA]
|
|
||||||
movs r0, 0x14
|
|
||||||
cmp r5, 0
|
|
||||||
beq _080A0AF8
|
|
||||||
adds r0, r5, 0
|
|
||||||
_080A0AF8:
|
|
||||||
strh r0, [r1, 0xC]
|
|
||||||
ldr r1, [r1]
|
|
||||||
adds r0, r2, 0
|
|
||||||
bl _call_via_r1
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.align 2, 0
|
|
||||||
_080A0B08: .4byte gTasks
|
|
||||||
thumb_func_end sub_80A0AC0
|
|
||||||
|
|
||||||
thumb_func_start sub_80A0B0C
|
|
||||||
sub_80A0B0C: @ 80A0B0C
|
|
||||||
push {r4,r5,lr}
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r5, r0, 24
|
|
||||||
lsls r0, r5, 2
|
|
||||||
adds r0, r5
|
|
||||||
lsls r0, 3
|
|
||||||
ldr r1, _080A0B30 @ =gTasks
|
|
||||||
adds r4, r0, r1
|
|
||||||
movs r1, 0x8
|
|
||||||
ldrsh r0, [r4, r1]
|
|
||||||
cmp r0, 0x1
|
|
||||||
beq _080A0B8C
|
|
||||||
cmp r0, 0x1
|
|
||||||
bgt _080A0B34
|
|
||||||
cmp r0, 0
|
|
||||||
beq _080A0B3E
|
|
||||||
b _080A0C5A
|
|
||||||
.align 2, 0
|
|
||||||
_080A0B30: .4byte gTasks
|
|
||||||
_080A0B34:
|
|
||||||
cmp r0, 0x2
|
|
||||||
beq _080A0BAE
|
|
||||||
cmp r0, 0x3
|
|
||||||
beq _080A0C10
|
|
||||||
b _080A0C5A
|
|
||||||
_080A0B3E:
|
|
||||||
movs r0, 0x78
|
|
||||||
strh r0, [r4, 0xE]
|
|
||||||
strh r0, [r4, 0x10]
|
|
||||||
movs r0, 0x50
|
|
||||||
strh r0, [r4, 0x12]
|
|
||||||
movs r0, 0x51
|
|
||||||
strh r0, [r4, 0x14]
|
|
||||||
movs r1, 0x80
|
|
||||||
lsls r1, 6
|
|
||||||
movs r0, 0
|
|
||||||
bl SetGpuRegBits
|
|
||||||
ldrh r1, [r4, 0xE]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x10]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x40
|
|
||||||
bl SetGpuReg
|
|
||||||
ldrh r1, [r4, 0x12]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x14]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x44
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x48
|
|
||||||
movs r1, 0x3F
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x4A
|
|
||||||
movs r1, 0
|
|
||||||
bl SetGpuReg
|
|
||||||
b _080A0C6A
|
|
||||||
_080A0B8C:
|
|
||||||
movs r0, 0x50
|
|
||||||
bl GetGpuReg
|
|
||||||
strh r0, [r4, 0x16]
|
|
||||||
movs r0, 0x54
|
|
||||||
bl GetGpuReg
|
|
||||||
strh r0, [r4, 0x18]
|
|
||||||
movs r0, 0x50
|
|
||||||
movs r1, 0xBF
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x54
|
|
||||||
movs r1, 0x10
|
|
||||||
bl SetGpuReg
|
|
||||||
b _080A0C6A
|
|
||||||
_080A0BAE:
|
|
||||||
ldrh r0, [r4, 0xE]
|
|
||||||
ldrh r1, [r4, 0xA]
|
|
||||||
subs r0, r1
|
|
||||||
movs r5, 0
|
|
||||||
strh r0, [r4, 0xE]
|
|
||||||
ldrh r2, [r4, 0x10]
|
|
||||||
adds r1, r2
|
|
||||||
strh r1, [r4, 0x10]
|
|
||||||
lsls r0, 16
|
|
||||||
cmp r0, 0
|
|
||||||
ble _080A0BCC
|
|
||||||
lsls r0, r1, 16
|
|
||||||
asrs r0, 16
|
|
||||||
cmp r0, 0xEF
|
|
||||||
ble _080A0BF2
|
|
||||||
_080A0BCC:
|
|
||||||
strh r5, [r4, 0xE]
|
|
||||||
movs r0, 0xF0
|
|
||||||
strh r0, [r4, 0x10]
|
|
||||||
movs r0, 0x54
|
|
||||||
movs r1, 0
|
|
||||||
bl SetGpuReg
|
|
||||||
ldrh r1, [r4, 0x16]
|
|
||||||
movs r0, 0x50
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x1
|
|
||||||
negs r0, r0
|
|
||||||
movs r1, 0
|
|
||||||
movs r2, 0
|
|
||||||
bl BlendPalettes
|
|
||||||
ldr r0, _080A0C0C @ =gPlttBufferFaded
|
|
||||||
strh r5, [r0]
|
|
||||||
_080A0BF2:
|
|
||||||
ldrh r1, [r4, 0xE]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x10]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x40
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r1, 0xE
|
|
||||||
ldrsh r0, [r4, r1]
|
|
||||||
b _080A0C54
|
|
||||||
.align 2, 0
|
|
||||||
_080A0C0C: .4byte gPlttBufferFaded
|
|
||||||
_080A0C10:
|
|
||||||
ldrh r0, [r4, 0x12]
|
|
||||||
ldrh r1, [r4, 0xC]
|
|
||||||
subs r0, r1
|
|
||||||
strh r0, [r4, 0x12]
|
|
||||||
ldrh r2, [r4, 0x14]
|
|
||||||
adds r1, r2
|
|
||||||
strh r1, [r4, 0x14]
|
|
||||||
lsls r0, 16
|
|
||||||
cmp r0, 0
|
|
||||||
ble _080A0C2C
|
|
||||||
lsls r0, r1, 16
|
|
||||||
asrs r0, 16
|
|
||||||
cmp r0, 0x9F
|
|
||||||
ble _080A0C3E
|
|
||||||
_080A0C2C:
|
|
||||||
movs r0, 0
|
|
||||||
strh r0, [r4, 0x12]
|
|
||||||
movs r0, 0xA0
|
|
||||||
strh r0, [r4, 0x14]
|
|
||||||
movs r1, 0x80
|
|
||||||
lsls r1, 6
|
|
||||||
movs r0, 0
|
|
||||||
bl ClearGpuRegBits
|
|
||||||
_080A0C3E:
|
|
||||||
ldrh r1, [r4, 0x12]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x14]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x44
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r1, 0x12
|
|
||||||
ldrsh r0, [r4, r1]
|
|
||||||
_080A0C54:
|
|
||||||
cmp r0, 0
|
|
||||||
bne _080A0C70
|
|
||||||
b _080A0C6A
|
|
||||||
_080A0C5A:
|
|
||||||
ldrh r1, [r4, 0x16]
|
|
||||||
movs r0, 0x50
|
|
||||||
bl SetGpuReg
|
|
||||||
adds r0, r5, 0
|
|
||||||
bl DestroyTask
|
|
||||||
b _080A0C70
|
|
||||||
_080A0C6A:
|
|
||||||
ldrh r0, [r4, 0x8]
|
|
||||||
adds r0, 0x1
|
|
||||||
strh r0, [r4, 0x8]
|
|
||||||
_080A0C70:
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
thumb_func_end sub_80A0B0C
|
|
||||||
|
|
||||||
thumb_func_start sub_80A0C78
|
|
||||||
sub_80A0C78: @ 80A0C78
|
|
||||||
push {r4,r5,lr}
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r5, r0, 24
|
|
||||||
lsls r0, r5, 2
|
|
||||||
adds r0, r5
|
|
||||||
lsls r0, 3
|
|
||||||
ldr r1, _080A0C9C @ =gTasks
|
|
||||||
adds r4, r0, r1
|
|
||||||
movs r0, 0x8
|
|
||||||
ldrsh r1, [r4, r0]
|
|
||||||
cmp r1, 0x1
|
|
||||||
beq _080A0CB4
|
|
||||||
cmp r1, 0x1
|
|
||||||
bgt _080A0CA0
|
|
||||||
cmp r1, 0
|
|
||||||
beq _080A0CAA
|
|
||||||
b _080A0DA8
|
|
||||||
.align 2, 0
|
|
||||||
_080A0C9C: .4byte gTasks
|
|
||||||
_080A0CA0:
|
|
||||||
cmp r1, 0x2
|
|
||||||
beq _080A0D02
|
|
||||||
cmp r1, 0x3
|
|
||||||
beq _080A0D54
|
|
||||||
b _080A0DA8
|
|
||||||
_080A0CAA:
|
|
||||||
ldr r0, _080A0CB0 @ =gPlttBufferFaded
|
|
||||||
strh r1, [r0]
|
|
||||||
b _080A0DCA
|
|
||||||
.align 2, 0
|
|
||||||
_080A0CB0: .4byte gPlttBufferFaded
|
|
||||||
_080A0CB4:
|
|
||||||
movs r1, 0
|
|
||||||
strh r1, [r4, 0xE]
|
|
||||||
movs r0, 0xF0
|
|
||||||
strh r0, [r4, 0x10]
|
|
||||||
strh r1, [r4, 0x12]
|
|
||||||
movs r0, 0xA0
|
|
||||||
strh r0, [r4, 0x14]
|
|
||||||
movs r1, 0x80
|
|
||||||
lsls r1, 6
|
|
||||||
movs r0, 0
|
|
||||||
bl SetGpuRegBits
|
|
||||||
ldrh r1, [r4, 0xE]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x10]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x40
|
|
||||||
bl SetGpuReg
|
|
||||||
ldrh r1, [r4, 0x12]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x14]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x44
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x48
|
|
||||||
movs r1, 0x3F
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x4A
|
|
||||||
movs r1, 0
|
|
||||||
bl SetGpuReg
|
|
||||||
b _080A0DCA
|
|
||||||
_080A0D02:
|
|
||||||
ldrh r0, [r4, 0xC]
|
|
||||||
ldrh r2, [r4, 0x12]
|
|
||||||
adds r1, r0, r2
|
|
||||||
strh r1, [r4, 0x12]
|
|
||||||
ldrh r2, [r4, 0x14]
|
|
||||||
subs r0, r2, r0
|
|
||||||
strh r0, [r4, 0x14]
|
|
||||||
lsls r1, 16
|
|
||||||
asrs r1, 16
|
|
||||||
cmp r1, 0x4F
|
|
||||||
bgt _080A0D20
|
|
||||||
lsls r0, 16
|
|
||||||
asrs r0, 16
|
|
||||||
cmp r0, 0x51
|
|
||||||
bgt _080A0D38
|
|
||||||
_080A0D20:
|
|
||||||
movs r0, 0x50
|
|
||||||
strh r0, [r4, 0x12]
|
|
||||||
movs r0, 0x51
|
|
||||||
strh r0, [r4, 0x14]
|
|
||||||
movs r0, 0x50
|
|
||||||
movs r1, 0xBF
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x54
|
|
||||||
movs r1, 0x10
|
|
||||||
bl SetGpuReg
|
|
||||||
_080A0D38:
|
|
||||||
ldrh r1, [r4, 0x12]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x14]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x44
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r1, 0x12
|
|
||||||
ldrsh r0, [r4, r1]
|
|
||||||
cmp r0, 0x50
|
|
||||||
bne _080A0DD0
|
|
||||||
b _080A0DCA
|
|
||||||
_080A0D54:
|
|
||||||
ldrh r0, [r4, 0xA]
|
|
||||||
ldrh r2, [r4, 0xE]
|
|
||||||
adds r1, r0, r2
|
|
||||||
strh r1, [r4, 0xE]
|
|
||||||
ldrh r2, [r4, 0x10]
|
|
||||||
subs r0, r2, r0
|
|
||||||
strh r0, [r4, 0x10]
|
|
||||||
lsls r1, 16
|
|
||||||
asrs r1, 16
|
|
||||||
cmp r1, 0x77
|
|
||||||
bgt _080A0D72
|
|
||||||
lsls r0, 16
|
|
||||||
asrs r0, 16
|
|
||||||
cmp r0, 0x78
|
|
||||||
bgt _080A0D88
|
|
||||||
_080A0D72:
|
|
||||||
movs r0, 0x78
|
|
||||||
strh r0, [r4, 0xE]
|
|
||||||
strh r0, [r4, 0x10]
|
|
||||||
subs r0, 0x79
|
|
||||||
movs r1, 0x10
|
|
||||||
movs r2, 0
|
|
||||||
bl BlendPalettes
|
|
||||||
ldr r1, _080A0DA4 @ =gPlttBufferFaded
|
|
||||||
movs r0, 0
|
|
||||||
strh r0, [r1]
|
|
||||||
_080A0D88:
|
|
||||||
ldrh r1, [r4, 0xE]
|
|
||||||
lsls r1, 8
|
|
||||||
ldrh r0, [r4, 0x10]
|
|
||||||
orrs r1, r0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
movs r0, 0x40
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r1, 0xE
|
|
||||||
ldrsh r0, [r4, r1]
|
|
||||||
cmp r0, 0x78
|
|
||||||
bne _080A0DD0
|
|
||||||
b _080A0DCA
|
|
||||||
.align 2, 0
|
|
||||||
_080A0DA4: .4byte gPlttBufferFaded
|
|
||||||
_080A0DA8:
|
|
||||||
movs r1, 0x80
|
|
||||||
lsls r1, 6
|
|
||||||
movs r0, 0
|
|
||||||
bl ClearGpuRegBits
|
|
||||||
movs r0, 0x54
|
|
||||||
movs r1, 0
|
|
||||||
bl SetGpuReg
|
|
||||||
movs r0, 0x50
|
|
||||||
movs r1, 0
|
|
||||||
bl SetGpuReg
|
|
||||||
adds r0, r5, 0
|
|
||||||
bl DestroyTask
|
|
||||||
b _080A0DD0
|
|
||||||
_080A0DCA:
|
|
||||||
ldrh r0, [r4, 0x8]
|
|
||||||
adds r0, 0x1
|
|
||||||
strh r0, [r4, 0x8]
|
|
||||||
_080A0DD0:
|
|
||||||
pop {r4,r5}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
thumb_func_end sub_80A0C78
|
|
||||||
|
|
||||||
.align 2, 0 @ Don't pad with nop.
|
|
||||||
+1
-1
@@ -148,7 +148,7 @@ SECTIONS {
|
|||||||
asm/script_pokemon_util_80A0058.o(.text);
|
asm/script_pokemon_util_80A0058.o(.text);
|
||||||
src/field_poison.o(.text);
|
src/field_poison.o(.text);
|
||||||
src/pokemon_size_record.o(.text);
|
src/pokemon_size_record.o(.text);
|
||||||
asm/pc_screen_effect.o(.text);
|
src/pc_screen_effect.o(.text);
|
||||||
src/fldeff_poison.o(.text);
|
src/fldeff_poison.o(.text);
|
||||||
src/fldeff_berrytree.o(.text);
|
src/fldeff_berrytree.o(.text);
|
||||||
src/field_special_scene.o(.text);
|
src/field_special_scene.o(.text);
|
||||||
|
|||||||
@@ -0,0 +1,156 @@
|
|||||||
|
#include "global.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "gpu_regs.h"
|
||||||
|
#include "palette.h"
|
||||||
|
|
||||||
|
static void sub_80A0AC0(TaskFunc func, u16 a2, UNUSED u16 a3, u8 priority);
|
||||||
|
static void sub_80A0B0C(u8 taskId);
|
||||||
|
static void sub_80A0C78(u8 taskId);
|
||||||
|
|
||||||
|
void sub_80A0A48(u16 a1, u16 a2, u8 a3)
|
||||||
|
{
|
||||||
|
sub_80A0AC0(sub_80A0B0C, a1, a2, a3);
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_80A0A70(u16 a1, u16 a2, u8 a3)
|
||||||
|
{
|
||||||
|
sub_80A0AC0(sub_80A0C78, a1, a2, a3);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 sub_80A0A98(void)
|
||||||
|
{
|
||||||
|
return FuncIsActiveTask(sub_80A0B0C);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 sub_80A0AAC(void)
|
||||||
|
{
|
||||||
|
return FuncIsActiveTask(sub_80A0C78);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sub_80A0AC0(TaskFunc func, u16 a2, UNUSED u16 a3, u8 priority)
|
||||||
|
{
|
||||||
|
u8 taskId = CreateTask(func, priority);
|
||||||
|
|
||||||
|
gTasks[taskId].data[0] = 0;
|
||||||
|
gTasks[taskId].data[1] = a2 == 0 ? 16 : a2;
|
||||||
|
gTasks[taskId].data[2] = a2 == 0 ? 20 : a2;
|
||||||
|
gTasks[taskId].func(taskId);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sub_80A0B0C(u8 taskId)
|
||||||
|
{
|
||||||
|
struct Task *task = &gTasks[taskId];
|
||||||
|
|
||||||
|
switch (task->data[0])
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
task->data[3] = 120;
|
||||||
|
task->data[4] = 120;
|
||||||
|
task->data[5] = 80;
|
||||||
|
task->data[6] = 81;
|
||||||
|
SetGpuRegBits(REG_OFFSET_DISPCNT, DISPCNT_WIN0_ON);
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0H, WIN_RANGE(task->data[3], task->data[4]));
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(task->data[5], task->data[6]));
|
||||||
|
SetGpuReg(REG_OFFSET_WININ, WININ_WIN0_BG_ALL | WININ_WIN0_OBJ | WININ_WIN0_CLR);
|
||||||
|
SetGpuReg(REG_OFFSET_WINOUT, 0);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
task->data[7] = GetGpuReg(REG_OFFSET_BLDCNT);
|
||||||
|
task->data[8] = GetGpuReg(REG_OFFSET_BLDY);
|
||||||
|
SetGpuReg(REG_OFFSET_BLDCNT, BLDCNT_TGT1_BG0 | BLDCNT_TGT1_BG1 | BLDCNT_TGT1_BG2 | BLDCNT_TGT1_BG3 | BLDCNT_TGT1_OBJ | BLDCNT_TGT1_BD | BLDCNT_EFFECT_LIGHTEN);
|
||||||
|
SetGpuReg(REG_OFFSET_BLDY, 16);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
task->data[3] -= task->data[1];
|
||||||
|
task->data[4] += task->data[1];
|
||||||
|
if (task->data[3] <= 0 || task->data[4] >= DISPLAY_WIDTH)
|
||||||
|
{
|
||||||
|
task->data[3] = 0;
|
||||||
|
task->data[4] = DISPLAY_WIDTH;
|
||||||
|
SetGpuReg(REG_OFFSET_BLDY, 0);
|
||||||
|
SetGpuReg(REG_OFFSET_BLDCNT, task->data[7]);
|
||||||
|
BlendPalettes(0xFFFFFFFF, 0, RGB_BLACK);
|
||||||
|
gPlttBufferFaded[0] = 0;
|
||||||
|
}
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0H, WIN_RANGE(task->data[3], task->data[4]));
|
||||||
|
if (task->data[3])
|
||||||
|
return;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
task->data[5] -= task->data[2];
|
||||||
|
task->data[6] += task->data[2];
|
||||||
|
if (task->data[5] <= 0 || task->data[6] >= DISPLAY_HEIGHT)
|
||||||
|
{
|
||||||
|
task->data[5] = 0;
|
||||||
|
task->data[6] = DISPLAY_HEIGHT;
|
||||||
|
ClearGpuRegBits(REG_OFFSET_DISPCNT, DISPCNT_WIN0_ON);
|
||||||
|
}
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(task->data[5], task->data[6]));
|
||||||
|
if (task->data[5])
|
||||||
|
return;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
SetGpuReg(REG_OFFSET_BLDCNT, task->data[7]);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
++task->data[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
static void sub_80A0C78(u8 taskId)
|
||||||
|
{
|
||||||
|
struct Task *task = &gTasks[taskId];
|
||||||
|
|
||||||
|
switch (task->data[0])
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
gPlttBufferFaded[0] = 0;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
task->data[3] = 0;
|
||||||
|
task->data[4] = DISPLAY_WIDTH;
|
||||||
|
task->data[5] = 0;
|
||||||
|
task->data[6] = DISPLAY_HEIGHT;
|
||||||
|
SetGpuRegBits(REG_OFFSET_DISPCNT, DISPCNT_WIN0_ON);
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0H, WIN_RANGE(task->data[3], task->data[4]));
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(task->data[5], task->data[6]));
|
||||||
|
SetGpuReg(REG_OFFSET_WININ, WININ_WIN0_BG_ALL | WININ_WIN0_OBJ | WININ_WIN0_CLR);
|
||||||
|
SetGpuReg(REG_OFFSET_WINOUT, 0);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
task->data[5] += task->data[2];
|
||||||
|
task->data[6] -= task->data[2];
|
||||||
|
if (task->data[5] >= 80 || task->data[6] <= 81)
|
||||||
|
{
|
||||||
|
task->data[5] = 80;
|
||||||
|
task->data[6] = 81;
|
||||||
|
SetGpuReg(REG_OFFSET_BLDCNT, BLDCNT_TGT1_BG0 | BLDCNT_TGT1_BG1 | BLDCNT_TGT1_BG2 | BLDCNT_TGT1_BG3 | BLDCNT_TGT1_OBJ | BLDCNT_TGT1_BD | BLDCNT_EFFECT_LIGHTEN);
|
||||||
|
SetGpuReg(REG_OFFSET_BLDY, 16);
|
||||||
|
}
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0V, WIN_RANGE(task->data[5], task->data[6]));
|
||||||
|
if (task->data[5] != 80)
|
||||||
|
return;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
task->data[3] += task->data[1];
|
||||||
|
task->data[4] -= task->data[1];
|
||||||
|
if (task->data[3] >= 120 || task->data[4] <= 120)
|
||||||
|
{
|
||||||
|
task->data[3] = 120;
|
||||||
|
task->data[4] = 120;
|
||||||
|
BlendPalettes(0xFFFFFFFF, 0x10, RGB_BLACK);
|
||||||
|
gPlttBufferFaded[0] = 0;
|
||||||
|
}
|
||||||
|
SetGpuReg(REG_OFFSET_WIN0H, WIN_RANGE(task->data[3], task->data[4]));
|
||||||
|
if (task->data[3] != 120)
|
||||||
|
return;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
ClearGpuRegBits(REG_OFFSET_DISPCNT, DISPCNT_WIN0_ON);
|
||||||
|
SetGpuReg(REG_OFFSET_BLDY, 0);
|
||||||
|
SetGpuReg(REG_OFFSET_BLDCNT, 0);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
++task->data[0];
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user