1
0
Fork 0
mirror of https://github.com/zeldaret/oot.git synced 2025-01-14 12:17:08 +00:00

made suggested changes

This commit is contained in:
chandler 2020-04-07 23:39:10 -04:00
parent 8f9ea21511
commit 2b8bc8ce6d
2 changed files with 21 additions and 23 deletions

View file

@ -12,7 +12,7 @@
void EnAni_SetupAction(EnAni* this, ActorFunc actionFunc); void EnAni_SetupAction(EnAni* this, ActorFunc actionFunc);
void EnAni_Init(EnAni* this, GlobalContext* globalCtx); void EnAni_Init(EnAni* this, GlobalContext* globalCtx);
void EnAni_Destroy(EnAni* this, GlobalContext* globalCtx); void EnAni_Destroy(EnAni* this, GlobalContext* globalCtx);
s32 EnAni_SetText(EnAni* this, GlobalContext* globalCtx, u16 textId); s32 EnAni_SetText(EnAni* this, GlobalContext* globalCtx, u16 textId);
void func_809B04F0(EnAni* this, GlobalContext* globalCtx); void func_809B04F0(EnAni* this, GlobalContext* globalCtx);
void func_809B0524(EnAni* this, GlobalContext* globalCtx); void func_809B0524(EnAni* this, GlobalContext* globalCtx);
void func_809B0558(EnAni* this, GlobalContext* globalCtx); void func_809B0558(EnAni* this, GlobalContext* globalCtx);
@ -24,7 +24,7 @@ void func_809B0994(EnAni* this, GlobalContext* globalCtx);
void func_809B0A28(EnAni* this, GlobalContext* globalCtx); void func_809B0A28(EnAni* this, GlobalContext* globalCtx);
void func_809B0A6C(EnAni* this, GlobalContext* globalCtx); void func_809B0A6C(EnAni* this, GlobalContext* globalCtx);
void EnAni_Update(EnAni* this, GlobalContext* globalCtx); void EnAni_Update(EnAni* this, GlobalContext* globalCtx);
s32 EnAni_UpdateMtxFunc(GlobalContext* globalCtx, s32 limbIndex, Gfx** dList, Vec3f* pos, Vec3s* rot, EnAni* enAni); s32 EnAni_UpdateMtxFunc(GlobalContext* globalCtx, s32 limbIndex, Gfx** dList, Vec3f* pos, Vec3s* rot, EnAni* enAni);
void EnAni_LimbAppendDList(GlobalContext* globalCtx, s32 limbIndex, Gfx** dList, Vec3s* rot, EnAni* enAni); void EnAni_LimbAppendDList(GlobalContext* globalCtx, s32 limbIndex, Gfx** dList, Vec3s* rot, EnAni* enAni);
void EnAni_Draw(EnAni* this, GlobalContext* globalCtx); void EnAni_Draw(EnAni* this, GlobalContext* globalCtx);
@ -47,7 +47,7 @@ const ActorInit En_Ani_InitVars = {
}; };
static ColliderCylinderInit cylinderInitData = { static ColliderCylinderInit cylinderInitData = {
0x0A, 0x00, 0x11, 0x39, 0x0A, 0x00, 0x11, 0x39,
0x10, 0x01, 0x00, 0x00, 0x10, 0x01, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00000000, 0x00000000,
@ -73,7 +73,6 @@ UNK_PTR D_809B0F80[] = {
0x06000408, 0x06000408,
0x06001518, 0x06001518,
0x06001D18, 0x06001D18,
0x00000000,
}; };
void EnAni_SetupAction(EnAni* this, ActorFunc actionFunc) { void EnAni_SetupAction(EnAni* this, ActorFunc actionFunc) {
@ -87,7 +86,8 @@ void EnAni_Init(EnAni* this, GlobalContext* globalCtx) {
anim = &D_060076EC; anim = &D_060076EC;
Actor_ProcessInitChain(&this->actor, initChain); Actor_ProcessInitChain(&this->actor, initChain);
ActorShape_Init(&this->actor.shape, -2800.0f, ActorShadow_DrawFunc_Circle, 36.0f); ActorShape_Init(&this->actor.shape, -2800.0f, ActorShadow_DrawFunc_Circle, 36.0f);
SkelAnime_InitSV(globalCtx, &this->skelAnime, &D_060000F0, anim, &this->unk_1DC, &this->unk_23C, 0x10); SkelAnime_InitSV(globalCtx, &this->skelAnime, &D_060000F0, anim, this->actorDrawTable, this->transitionDrawTable,
0x10);
SkelAnime_ChangeAnimDefaultStop(&this->skelAnime, anim); SkelAnime_ChangeAnimDefaultStop(&this->skelAnime, anim);
ActorCollider_AllocCylinder(globalCtx, &this->collider); ActorCollider_AllocCylinder(globalCtx, &this->collider);
ActorCollider_InitCylinder(globalCtx, &this->collider, &this->actor, &cylinderInitData); ActorCollider_InitCylinder(globalCtx, &this->collider, &this->actor, &cylinderInitData);
@ -130,7 +130,7 @@ void func_809B0524(EnAni* this, GlobalContext* globalCtx) {
void func_809B0558(EnAni* this, GlobalContext* globalCtx) { void func_809B0558(EnAni* this, GlobalContext* globalCtx) {
if (func_8002F410(&this->actor, globalCtx) != 0) { if (func_8002F410(&this->actor, globalCtx) != 0) {
this->actor.attachedA = 0; this->actor.attachedA = NULL;
if (LINK_IS_CHILD) { if (LINK_IS_CHILD) {
EnAni_SetupAction(this, func_809B04F0); EnAni_SetupAction(this, func_809B04F0);
} else { } else {
@ -151,7 +151,7 @@ void func_809B05F0(EnAni* this, GlobalContext* globalCtx) {
void func_809B064C(EnAni* this, GlobalContext* globalCtx) { void func_809B064C(EnAni* this, GlobalContext* globalCtx) {
u16 textId; u16 textId;
s16 rotDiff; s16 yawDiff;
u16 textId2; u16 textId2;
textId2 = Text_GetFaceReaction(globalCtx, 0xA); textId2 = Text_GetFaceReaction(globalCtx, 0xA);
@ -164,7 +164,7 @@ void func_809B064C(EnAni* this, GlobalContext* globalCtx) {
// "...all I can do is look at Death Mountain." // "...all I can do is look at Death Mountain."
} }
rotDiff = this->actor.rotTowardsLinkY - this->actor.shape.rot.y; yawDiff = this->actor.rotTowardsLinkY - this->actor.shape.rot.y;
if (func_8002F194(&this->actor, globalCtx) != 0) { if (func_8002F194(&this->actor, globalCtx) != 0) {
if (this->actor.textId == 0x5056) { // "To get a good view..." if (this->actor.textId == 0x5056) { // "To get a good view..."
EnAni_SetupAction(this, func_809B04F0); EnAni_SetupAction(this, func_809B04F0);
@ -173,24 +173,24 @@ void func_809B064C(EnAni* this, GlobalContext* globalCtx) {
} else { } else {
EnAni_SetupAction(this, func_809B04F0); EnAni_SetupAction(this, func_809B04F0);
} }
} else if (rotDiff >= -0x36AF && rotDiff < 0 && this->actor.xzDistanceFromLink < 150.0f } else if (yawDiff >= -0x36AF && yawDiff < 0 && this->actor.xzDistanceFromLink < 150.0f &&
&& -80.0f < this->actor.yDistanceFromLink) { -80.0f < this->actor.yDistanceFromLink) {
if ((gSaveContext.item_get_inf[1] & 0x20) != 0) { if ((gSaveContext.item_get_inf[1] & 0x20) != 0) {
EnAni_SetText(this, globalCtx, 0x5056); // "To get a good view..." EnAni_SetText(this, globalCtx, 0x5056); // "To get a good view..."
} else { } else {
EnAni_SetText(this, globalCtx, 0x5055); // "...I'll give you this as a memento." EnAni_SetText(this, globalCtx, 0x5055); // "...I'll give you this as a memento."
} }
} else if (rotDiff >= -0x3E7 && rotDiff < 0x36B0 && this->actor.xzDistanceFromLink < 350.0f) { } else if (yawDiff >= -0x3E7 && yawDiff < 0x36B0 && this->actor.xzDistanceFromLink < 350.0f) {
EnAni_SetText(this, globalCtx, textId); EnAni_SetText(this, globalCtx, textId);
} }
} }
void func_809B07F8(EnAni* this, GlobalContext* globalCtx) { void func_809B07F8(EnAni* this, GlobalContext* globalCtx) {
s16 pad; s16 pad;
s16 rotDiff; s16 yawDiff;
u16 textId; u16 textId;
rotDiff = this->actor.rotTowardsLinkY - this->actor.shape.rot.y; yawDiff = this->actor.rotTowardsLinkY - this->actor.shape.rot.y;
if (func_8002F194(&this->actor, globalCtx) != 0) { if (func_8002F194(&this->actor, globalCtx) != 0) {
if (this->actor.textId == 0x5056) { // "To get a good view..." if (this->actor.textId == 0x5056) { // "To get a good view..."
EnAni_SetupAction(this, func_809B0524); EnAni_SetupAction(this, func_809B0524);
@ -199,14 +199,14 @@ void func_809B07F8(EnAni* this, GlobalContext* globalCtx) {
} else { } else {
EnAni_SetupAction(this, func_809B0524); EnAni_SetupAction(this, func_809B0524);
} }
} else if (rotDiff >= -0x36AF && rotDiff < 0 && this->actor.xzDistanceFromLink < 150.0f } else if (yawDiff >= -0x36AF && yawDiff < 0 && this->actor.xzDistanceFromLink < 150.0f &&
&& -80.0f < this->actor.yDistanceFromLink) { -80.0f < this->actor.yDistanceFromLink) {
if ((gSaveContext.item_get_inf[1] & 0x20) != 0) { if ((gSaveContext.item_get_inf[1] & 0x20) != 0) {
EnAni_SetText(this, globalCtx, 0x5056); // "To get a good view..." EnAni_SetText(this, globalCtx, 0x5056); // "To get a good view..."
} else { } else {
EnAni_SetText(this, globalCtx, 0x5055); // "...I'll give you this as a memento." EnAni_SetText(this, globalCtx, 0x5055); // "...I'll give you this as a memento."
} }
} else if (rotDiff >= -0x3E7 && rotDiff < 0x36B0 && this->actor.xzDistanceFromLink < 350.0f) { } else if (yawDiff >= -0x3E7 && yawDiff < 0x36B0 && this->actor.xzDistanceFromLink < 350.0f) {
if ((gSaveContext.event_chk_inf[2] & 0x8000) == 0) { if ((gSaveContext.event_chk_inf[2] & 0x8000) == 0) {
textId = 0x5052; // "...Something is happening on Death Mountain!" textId = 0x5052; // "...Something is happening on Death Mountain!"
} else { } else {
@ -310,7 +310,7 @@ void EnAni_Update(EnAni* this, GlobalContext* globalCtx) {
} }
if (phi_v0 == 0) { if (phi_v0 == 0) {
this->unk_2AE = Math_Rand_S16Offset(0x3c, 0x3c); this->unk_2AE = Math_Rand_S16Offset(60, 60);
} }
this->unk_2AC = this->unk_2AE; this->unk_2AC = this->unk_2AE;
if (this->unk_2AC >= 3) { if (this->unk_2AC >= 3) {
@ -344,12 +344,12 @@ void EnAni_Draw(EnAni* this, GlobalContext* globalCtx) {
temp = D_809B0F80; temp = D_809B0F80;
gfxCtx = globalCtx->state.gfxCtx; gfxCtx = globalCtx->state.gfxCtx;
Graph_OpenDisps(dispRefs, globalCtx->state.gfxCtx, "../z_en_ani.c", 0x2CF); Graph_OpenDisps(dispRefs, globalCtx->state.gfxCtx, "../z_en_ani.c", 719);
func_800943C8(globalCtx->state.gfxCtx); func_800943C8(globalCtx->state.gfxCtx);
gSPSegment(gfxCtx->polyOpa.p++, 0x08, SEGMENTED_TO_VIRTUAL(temp[this->unk_2AC])); gSPSegment(gfxCtx->polyOpa.p++, 0x08, SEGMENTED_TO_VIRTUAL(temp[this->unk_2AC]));
SkelAnime_DrawSV(globalCtx, this->skelAnime.skeleton, this->skelAnime.actorDrawTbl, this->skelAnime.dListCount, SkelAnime_DrawSV(globalCtx, this->skelAnime.skeleton, this->skelAnime.actorDrawTbl, this->skelAnime.dListCount,
EnAni_UpdateMtxFunc, EnAni_LimbAppendDList, &this->actor); EnAni_UpdateMtxFunc, EnAni_LimbAppendDList, &this->actor);
Graph_CloseDisps(dispRefs, globalCtx->state.gfxCtx, "../z_en_ani.c", 0x2E0); Graph_CloseDisps(dispRefs, globalCtx->state.gfxCtx, "../z_en_ani.c", 736);
} }

View file

@ -8,10 +8,8 @@ typedef struct {
/* 0x0000 */ Actor actor; /* 0x0000 */ Actor actor;
/* 0x014C */ ColliderCylinderMain collider; /* 0x014C */ ColliderCylinderMain collider;
/* 0x0198 */ SkelAnime skelAnime; /* 0x0198 */ SkelAnime skelAnime;
/* 0x01DC */ u8 unk_1DC; /* 0x01DC */ Vec3s actorDrawTable[16];
/* 0x01DD */ char unk_1DD[0x5F]; /* 0x023C */ Vec3s transitionDrawTable[16];
/* 0x023C */ u16 unk_23C;
/* 0x023E */ char unk_23E[0x5E];
/* 0x029C */ Vec3s unk_29C; /* 0x029C */ Vec3s unk_29C;
/* 0x02A2 */ Vec3s unk_2A2; /* 0x02A2 */ Vec3s unk_2A2;
/* 0x02A8 */ u16 unk_2A8; /* 0x02A8 */ u16 unk_2A8;