GyorgFemaleEye to new entity style

This commit is contained in:
Ibot02 2021-12-29 15:03:34 +01:00
parent 770a98c8bd
commit 7f0caf50fa
3 changed files with 67 additions and 71 deletions

37
include/enemy/gyorg.h Normal file
View File

@ -0,0 +1,37 @@
#ifndef ENEMY_GYORG_H
#define ENEMY_GYORG_H
#include "enemy.h"
typedef struct {
Entity base;
u8 unk_68[0x8];
u16 unk_70;
u8 unk_72[0x6];
u8 unk_78;
u8 unk_79;
u16 unk_7a;
u8 unk_7c;
u8 unk_7d;
u8 unk_7e[1];
u8 unk_7f;
u8 unk_80;
u8 unk_81[1];
u8 unk_82;
u8 unk_83[5];
} GyorgFemaleEntity;
typedef struct {
GenericEntity* unk_00;
u8 unk_04[0x4];
Entity* unk_08;
Entity* unk_0c;
void* unk_10;
void* unk_14;
void* unk_18[0x8];
u16 unk_38;
u16 unk_3a;
u8 unk_3c;
} GyorgFemaleHeap;
#endif

View File

@ -6,6 +6,7 @@
#include "audio.h"
#include "asm.h"
#include "functions.h"
#include "enemy/gyorg.h"
extern u8 gEntCount;
extern u8 gMapDataTopSpecial[];
@ -17,35 +18,6 @@ extern void sub_080197D4(u32);
extern u32 sub_08000E62(u32);
extern void RegisterTransitionManager(void*, void (*)(), void (*)());
typedef struct {
Entity base;
u8 unk_68[0x8];
u16 unk_70;
u8 unk_72[0x6];
u8 unk_78;
u8 unk_79;
u16 unk_7a;
u8 unk_7c;
u8 unk_7d;
u8 unk_7e[1];
u8 unk_7f;
u8 unk_80;
u8 unk_81[1];
u8 unk_82;
u8 unk_83[5];
} GyorgFemaleEntity;
typedef struct {
GenericEntity* unk_00;
u8 unk_04[0xC];
void* unk_10;
void* unk_14;
u32 unk_18[0x8];
u16 unk_38;
u16 unk_3a;
u8 unk_3c;
} GyorgFemaleHeap;
void sub_08046498();
void sub_0804660C(GyorgFemaleEntity*, u32);
void sub_080464C0(GyorgFemaleEntity*);

View File

@ -1,27 +1,14 @@
// #define NENT_DEPRECATED
#define NENT_DEPRECATED
#include "global.h"
#include "entity.h"
#include "enemy.h"
#include "player.h"
#include "functions.h"
typedef struct {
u8 unk_00[0x8];
Entity* unk_08;
Entity* unk_0c;
u8 unk_10[0x08];
void* unk_18[0x8];
u16 unk_38;
u16 unk_3a;
u8 unk_3c;
} GyorgFemaleHeap;
typedef struct {
} GyorgFemaleEyeHeap;
#include "enemy/gyorg.h"
typedef struct {
Entity base;
// u8 unk_68[0x20];
u8 unk_68[0x20];
} GyorgFemaleEyeEntity;
extern void (*const gUnk_080D1F64[])(GyorgFemaleEyeEntity*);
@ -32,7 +19,7 @@ extern const u8 gUnk_080D2010[];
void sub_08048D20(GyorgFemaleEyeEntity*);
u32 sub_08048D70(Entity*); // GyorgFemaleEntity*
u32 sub_08048D70(GyorgFemaleEntity*);
void GyorgFemaleEye(Entity* this) {
if (this->parent->next == NULL) {
@ -46,13 +33,13 @@ void sub_080489B4(GyorgFemaleEyeEntity* this) {
}
void sub_080489CC(GyorgFemaleEyeEntity* this) {
Entity* parent;
GyorgFemaleEntity* parent;
if (super->health != 0xFF) {
parent = super->parent;
parent = (GyorgFemaleEntity*)super->parent;
#ifndef EU
if ((parent->field_0x78.HALF.LO >> super->type) & 1) {
if ((parent->unk_78 >> super->type) & 1) {
#endif
parent->field_0x7c.BYTES.byte0 |= (1 << super->type);
parent->unk_7c |= (1 << super->type);
#ifndef EU
switch (super->bitfield & 0x7F) {
case 4 ... 6:
@ -60,14 +47,14 @@ void sub_080489CC(GyorgFemaleEyeEntity* this) {
case 16 ... 18:
case 24 ... 26:
#endif
((GyorgFemaleHeap*)parent->myHeap)->unk_18[super->type] = super->field_0x4c;
((GyorgFemaleHeap*)parent->myHeap)->unk_38 = (gPlayerEntity.x.HALF.HI + super->x.HALF.HI) / 2;
((GyorgFemaleHeap*)parent->myHeap)->unk_3a = (gPlayerEntity.y.HALF.HI + super->y.HALF.HI) / 2;
((GyorgFemaleHeap*)parent->myHeap)->unk_3c = (super->knockbackDirection ^= 0x10);
((GyorgFemaleHeap*)parent->base.myHeap)->unk_18[super->type] = super->field_0x4c;
((GyorgFemaleHeap*)parent->base.myHeap)->unk_38 = (gPlayerEntity.x.HALF.HI + super->x.HALF.HI) / 2;
((GyorgFemaleHeap*)parent->base.myHeap)->unk_3a = (gPlayerEntity.y.HALF.HI + super->y.HALF.HI) / 2;
((GyorgFemaleHeap*)parent->base.myHeap)->unk_3c = (super->knockbackDirection ^= 0x10);
#ifndef EU
break;
default:
((GyorgFemaleHeap*)parent->myHeap)->unk_3c = 0xFF;
((GyorgFemaleHeap*)parent->base.myHeap)->unk_3c = 0xFF;
break;
}
}
@ -88,9 +75,9 @@ void sub_08048AF0(GyorgFemaleEyeEntity* this) {
}
void sub_08048B2C(GyorgFemaleEyeEntity* this) {
Entity* parent;
GyorgFemaleEntity* parent;
sub_08048D20(this);
parent = super->parent;
parent = (GyorgFemaleEntity*)super->parent;
if (sub_08048D70(parent)) {
if (!super->spriteSettings.draw) {
CreateFx(super, 2, 0x40);
@ -99,7 +86,7 @@ void sub_08048B2C(GyorgFemaleEyeEntity* this) {
} else {
super->spriteSettings.draw = 0;
}
if ((parent->field_0x78.HALF.LO >> super->type) & 1) {
if ((parent->unk_78 >> super->type) & 1) {
super->action = 2;
}
}
@ -114,9 +101,9 @@ void sub_08048B84(GyorgFemaleEyeEntity* this) {
}
void sub_08048BB0(GyorgFemaleEyeEntity* this) {
Entity* parent = super->parent;
if (!((parent->field_0x78.HALF.LO >> super->type) & 1)) {
if (parent->health != 0) {
GyorgFemaleEntity* parent = (GyorgFemaleEntity*)super->parent;
if (!((parent->unk_78 >> super->type) & 1)) {
if (parent->base.health != 0) {
super->action = 4;
super->flags &= ~0x80;
InitializeAnimation(super, gUnk_080D2030[(super->animationState << 3) + super->type]);
@ -128,11 +115,11 @@ void sub_08048BB0(GyorgFemaleEyeEntity* this) {
CreateFx(super, 2, 0x40);
}
} else {
if ((parent->field_0x80.HALF.LO >> super->type) & 1) {
if ((parent->unk_80 >> super->type) & 1) {
if (super->animIndex <= 0x13) {
super->iframes = 0xF4;
super->hitType = 0x89;
InitializeAnimation(super, (parent->animationState >> 6) + 0x14);
InitializeAnimation(super, (parent->base.animationState >> 6) + 0x14);
SoundReq(0x119);
}
GetNextFrame(super);
@ -140,10 +127,10 @@ void sub_08048BB0(GyorgFemaleEyeEntity* this) {
super->hitType = 0x1E;
InitializeAnimation(super, gUnk_080D2010[(super->animationState << 3) + super->type]);
UpdateAnimationVariableFrames(super, 7);
parent->field_0x80.HALF.LO &= ~(1 << super->type);
parent->unk_80 &= ~(1 << super->type);
}
} else {
if (parent->field_0x78.HALF.LO == 0xFF) {
if (parent->unk_78 == 0xFF) {
u32 tmp = super->animIndex;
if (tmp < 0x10 || tmp > 0x13) {
InitializeAnimation(super, super->animationState + 0x10);
@ -170,9 +157,9 @@ typedef struct {
extern const xy gUnk_080D1F90[];
void sub_08048D20(GyorgFemaleEyeEntity* this) {
Entity* parent = super->parent;
GyorgFemaleEntity* parent = (GyorgFemaleEntity*)super->parent;
const xy* tmp;
u32 tmp2 = (parent->animationState >> 6);
u32 tmp2 = (parent->base.animationState >> 6);
if (tmp2 != super->animationState) {
super->animationState = tmp2;
tmp = &gUnk_080D1F90[super->type + (tmp2 << 3)];
@ -182,14 +169,14 @@ void sub_08048D20(GyorgFemaleEyeEntity* this) {
}
}
u32 sub_08048D70(Entity* parent) {
u32 sub_08048D70(GyorgFemaleEntity* parent) {
Entity* tmp;
if (parent->health != 0) {
if (parent->base.health != 0) {
return 1;
}
tmp = ((GyorgFemaleHeap*)parent->myHeap)->unk_08;
tmp = ((GyorgFemaleHeap*)parent->base.myHeap)->unk_08;
if (!tmp) {
tmp = ((GyorgFemaleHeap*)parent->myHeap)->unk_0c;
tmp = ((GyorgFemaleHeap*)parent->base.myHeap)->unk_0c;
}
if (tmp->health != 0) {
return 0;