Housekeeping NPCs, Octorok, TransferDungeonMapGfx
This commit is contained in:
@@ -59,18 +59,16 @@ pullpc ; Bank 0x33
|
|||||||
|
|
||||||
TransferDungeonMapGfx:
|
TransferDungeonMapGfx:
|
||||||
{
|
{
|
||||||
REP #$20 ; A = 16, XY = 8
|
REP #$20
|
||||||
|
LDX #$80 : STX $2100
|
||||||
LDX #$80 : STX $2100 ; turn the screen off (required)
|
LDX #$80 : STX $2115
|
||||||
LDX #$80 : STX $2115 ; Set the video port register every time we write it increase by 1
|
LDA #$5000 : STA $2116 ; Destination of the DMA in VRAM
|
||||||
LDA #$5000 : STA $2116 ; Destination of the DMA $5800 in vram <- this need to be divided by 2
|
|
||||||
LDA #$1801 : STA $4300 ; DMA Transfer Mode and destination register
|
LDA #$1801 : STA $4300 ; DMA Transfer Mode and destination register
|
||||||
LDA.w #MapGfx : STA $4302 ; Source address where you want gfx from ROM
|
LDA.w #MapGfx : STA $4302
|
||||||
LDX.b #MapGfx>>16 : STX $4304
|
LDX.b #MapGfx>>16 : STX $4304
|
||||||
LDA #$2000 : STA $4305 ; size of the transfer 4 sheets of $800 each
|
LDA #$2000 : STA $4305
|
||||||
LDX #$01 : STX $420B ; Do the DMA
|
LDX #$01 : STX $420B
|
||||||
|
LDX #$0F : STX $2100
|
||||||
LDX #$0F : STX $2100 ; Turn the screen back on
|
|
||||||
SEP #$30
|
SEP #$30
|
||||||
|
|
||||||
LDA.b #$09 : STA.b $14
|
LDA.b #$09 : STA.b $14
|
||||||
|
|||||||
@@ -269,7 +269,7 @@ Sprite_WaterOctorok_Attack:
|
|||||||
JSL Sprite_DamageFlash_Long
|
JSL Sprite_DamageFlash_Long
|
||||||
JSL Sprite_CheckDamageToPlayer
|
JSL Sprite_CheckDamageToPlayer
|
||||||
|
|
||||||
LDA SprMiscG, X
|
LDA.w SprMiscG, X
|
||||||
JSL UseImplicitRegIndexedLocalJumpTable
|
JSL UseImplicitRegIndexedLocalJumpTable
|
||||||
|
|
||||||
dw WaterOctorok_Hidden
|
dw WaterOctorok_Hidden
|
||||||
|
|||||||
@@ -655,7 +655,6 @@ MinecartFollower_Top:
|
|||||||
|
|
||||||
LDA $02CF : TAY
|
LDA $02CF : TAY
|
||||||
LDA .start_index, Y : STA $06
|
LDA .start_index, Y : STA $06
|
||||||
|
|
||||||
PHX
|
PHX
|
||||||
LDX .nbr_of_tiles, Y ; amount of tiles -1
|
LDX .nbr_of_tiles, Y ; amount of tiles -1
|
||||||
LDY.b #$00
|
LDY.b #$00
|
||||||
@@ -687,11 +686,8 @@ MinecartFollower_Top:
|
|||||||
LDA .properties, X : STA ($90), Y
|
LDA .properties, X : STA ($90), Y
|
||||||
|
|
||||||
PHY
|
PHY
|
||||||
|
|
||||||
TYA : LSR #2 : TAY
|
TYA : LSR #2 : TAY
|
||||||
|
|
||||||
LDA.b #$02 : ORA $0F : STA ($92), Y ; store size in oam buffer
|
LDA.b #$02 : ORA $0F : STA ($92), Y ; store size in oam buffer
|
||||||
|
|
||||||
PLY : INY
|
PLY : INY
|
||||||
PLX : DEX : BPL .nextTile
|
PLX : DEX : BPL .nextTile
|
||||||
|
|
||||||
@@ -766,11 +762,8 @@ MinecartFollower_Bottom:
|
|||||||
LDA .properties, X : STA ($90), Y
|
LDA .properties, X : STA ($90), Y
|
||||||
|
|
||||||
PHY
|
PHY
|
||||||
|
|
||||||
TYA : LSR #2 : TAY
|
TYA : LSR #2 : TAY
|
||||||
|
|
||||||
LDA.b #$02 : ORA $0F : STA ($92), Y ; store size in oam buffer
|
LDA.b #$02 : ORA $0F : STA ($92), Y ; store size in oam buffer
|
||||||
|
|
||||||
PLY : INY
|
PLY : INY
|
||||||
PLX : DEX : BPL .nextTile
|
PLX : DEX : BPL .nextTile
|
||||||
|
|
||||||
@@ -981,4 +974,4 @@ org $028A5B
|
|||||||
org $0289BF
|
org $0289BF
|
||||||
JSL CheckForFollowerIntraroomTransition
|
JSL CheckForFollowerIntraroomTransition
|
||||||
|
|
||||||
pullpc
|
pullpc
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
!DeathAnimation = 00 ; 00 = normal death, 01 = no death animation
|
!DeathAnimation = 00 ; 00 = normal death, 01 = no death animation
|
||||||
!ImperviousAll = 00 ; 00 = Can be attack, 01 = attack will clink on it
|
!ImperviousAll = 00 ; 00 = Can be attack, 01 = attack will clink on it
|
||||||
!SmallShadow = 00 ; 01 = small shadow, 00 = no shadow
|
!SmallShadow = 00 ; 01 = small shadow, 00 = no shadow
|
||||||
!Shadow = 00 ; 00 = don't draw shadow, 01 = draw a shadow
|
!Shadow = 00 ; 00 = don't draw shadow, 01 = draw a shadow
|
||||||
!Palette = 00 ; Unused in this template (can be 0 to 7)
|
!Palette = 00 ; Unused in this template (can be 0 to 7)
|
||||||
!Hitbox = 02 ; 00 to 31, can be viewed in sprite draw tool
|
!Hitbox = 02 ; 00 to 31, can be viewed in sprite draw tool
|
||||||
!Persist = 00 ; 01 = your sprite continue to live offscreen
|
!Persist = 00 ; 01 = your sprite continue to live offscreen
|
||||||
@@ -48,10 +48,9 @@ Sprite_ZoraPrincess_Long:
|
|||||||
Sprite_ZoraPrincess_Prep:
|
Sprite_ZoraPrincess_Prep:
|
||||||
{
|
{
|
||||||
PHB : PHK : PLB
|
PHB : PHK : PLB
|
||||||
|
|
||||||
LDA.l $7EF302
|
LDA.l $7EF302
|
||||||
BEQ .doesnt_have_mask
|
BEQ .doesnt_have_mask
|
||||||
STZ.w $0DD0, X ; Kill the sprite
|
STZ.w $0DD0, X ; Kill the sprite
|
||||||
.doesnt_have_mask
|
.doesnt_have_mask
|
||||||
|
|
||||||
LDA #$00 : STA $0CAA, X
|
LDA #$00 : STA $0CAA, X
|
||||||
@@ -98,7 +97,7 @@ Sprite_ZoraPrincess_Main:
|
|||||||
{
|
{
|
||||||
%PlayAnimation(0, 1, 10)
|
%PlayAnimation(0, 1, 10)
|
||||||
LDA.w SprTimerD, X : BNE +
|
LDA.w SprTimerD, X : BNE +
|
||||||
%ShowUnconditionalMessage($0C6)
|
%ShowUnconditionalMessage($0C6)
|
||||||
LDA.b #$C0 : STA.w SprTimerD, X
|
LDA.b #$C0 : STA.w SprTimerD, X
|
||||||
%GotoAction(3)
|
%GotoAction(3)
|
||||||
+
|
+
|
||||||
@@ -133,12 +132,11 @@ Sprite_ZoraPrincess_Draw:
|
|||||||
.nextTile
|
.nextTile
|
||||||
|
|
||||||
PHX ; Save current Tile Index?
|
PHX ; Save current Tile Index?
|
||||||
|
|
||||||
TXA : CLC : ADC $06 ; Add Animation Index Offset
|
TXA : CLC : ADC $06 ; Add Animation Index Offset
|
||||||
|
|
||||||
PHA ; Keep the value with animation index offset?
|
PHA ; Keep the value with animation index offset?
|
||||||
|
|
||||||
ASL A : TAX
|
ASL A : TAX
|
||||||
|
|
||||||
REP #$20
|
REP #$20
|
||||||
|
|
||||||
@@ -161,13 +159,9 @@ Sprite_ZoraPrincess_Draw:
|
|||||||
LDA .properties, X : STA ($90), Y
|
LDA .properties, X : STA ($90), Y
|
||||||
|
|
||||||
PHY
|
PHY
|
||||||
|
|
||||||
TYA : LSR #2 : TAY
|
TYA : LSR #2 : TAY
|
||||||
|
|
||||||
LDA .sizes, X : ORA $0F : STA ($92), Y ; store size in oam buffer
|
LDA .sizes, X : ORA $0F : STA ($92), Y ; store size in oam buffer
|
||||||
|
|
||||||
PLY : INY
|
PLY : INY
|
||||||
|
|
||||||
PLX : DEX : BPL .nextTile
|
PLX : DEX : BPL .nextTile
|
||||||
|
|
||||||
PLX
|
PLX
|
||||||
|
|||||||
Reference in New Issue
Block a user