mirror of https://github.com/zeldaret/tp.git
cleanup and fix various inconsistancies or issues
This commit is contained in:
parent
3ab5a61f4b
commit
9b96da62ce
|
@ -9,7 +9,7 @@
|
||||||
/**
|
/**
|
||||||
* @ingroup actors-objects
|
* @ingroup actors-objects
|
||||||
* @class daObjCRVHAHEN_c
|
* @class daObjCRVHAHEN_c
|
||||||
* @brief Carven Wood Splinters
|
* @brief Bulblin Camp Caraven Wooden Fence Fragments
|
||||||
*
|
*
|
||||||
* @details Hahen (はへん) a fragment, shard, or splinter.
|
* @details Hahen (はへん) a fragment, shard, or splinter.
|
||||||
* physics-enabled shards or fragments that simulate debris from destruction.
|
* physics-enabled shards or fragments that simulate debris from destruction.
|
||||||
|
@ -36,11 +36,11 @@ public:
|
||||||
/* 0x6d0 */ csXyz mRotation[10];
|
/* 0x6d0 */ csXyz mRotation[10];
|
||||||
/* 0x70c */ csXyz mRotSpeed[10];
|
/* 0x70c */ csXyz mRotSpeed[10];
|
||||||
/* 0x748 */ u32 mFlags;
|
/* 0x748 */ u32 mFlags;
|
||||||
/* 0x74c */ float mGroundHeight;
|
/* 0x74c */ f32 mGroundHeight;
|
||||||
/* 0x750 */ bool mDrawHahen;
|
/* 0x750 */ bool mDrawHahen;
|
||||||
/* 0x751 */ u8 mStatus[10];
|
/* 0x751 */ u8 mStatus[10];
|
||||||
/* 0x75b */ u8 field_0x75b;
|
/* 0x75b */ u8 field_0x75b;
|
||||||
/* 0x75c */ float mTimer;
|
/* 0x75c */ f32 mTimer;
|
||||||
/* 0x760 */ J3DModel* mpModel[10];
|
/* 0x760 */ J3DModel* mpModel[10];
|
||||||
/* 0x788 */ request_of_phase_process_class mPhase;
|
/* 0x788 */ request_of_phase_process_class mPhase;
|
||||||
/* 0x790 */ u8 mEffectState;
|
/* 0x790 */ u8 mEffectState;
|
||||||
|
|
|
@ -27,7 +27,7 @@ static int useHeapInit(fopAc_ac_c* i_this) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 80BD33E8-80BD3408 000128 0020+00 1/0 0/0 0/0 .text daObjCRVHAHEN_Create__FP10fopAc_ac_c */
|
/* 80BD33E8-80BD3408 000128 0020+00 1/0 0/0 0/0 .text daObjCRVHAHEN_Create__FP10fopAc_ac_c */
|
||||||
static void daObjCRVHAHEN_Create(fopAc_ac_c* i_this) {
|
static int daObjCRVHAHEN_Create(fopAc_ac_c* i_this) {
|
||||||
static_cast<daObjCRVHAHEN_c*>(i_this)->create();
|
static_cast<daObjCRVHAHEN_c*>(i_this)->create();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,17 +39,17 @@ static int daObjCRVHAHEN_Delete(daObjCRVHAHEN_c* i_this) {
|
||||||
|
|
||||||
/* 80BD342C-80BD3628 00016C 01FC+00 0/0 0/0 2/2 .text
|
/* 80BD342C-80BD3628 00016C 01FC+00 0/0 0/0 2/2 .text
|
||||||
* HahenSet__15daObjCRVHAHEN_cF4cXyz4cXyz4cXyz4cXyzf */
|
* HahenSet__15daObjCRVHAHEN_cF4cXyz4cXyz4cXyz4cXyzf */
|
||||||
int daObjCRVHAHEN_c::HahenSet(cXyz param_1, cXyz param_2, cXyz param_3, cXyz param_4,
|
int daObjCRVHAHEN_c::HahenSet(cXyz i_param_1, cXyz i_param_2, cXyz i_param_3, cXyz i_param_4,
|
||||||
f32 duration) {
|
f32 duration) {
|
||||||
mDrawHahen = true;
|
mDrawHahen = true;
|
||||||
mTimer = duration;
|
mTimer = duration;
|
||||||
|
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
mPos[i].set(param_2.x + cM_rndFX(param_1.x), param_2.y + cM_rndF(param_1.y),
|
mPos[i].set(i_param_2.x + cM_rndFX(i_param_1.x), i_param_2.y + cM_rndF(i_param_1.y),
|
||||||
param_2.z + cM_rndFX(param_1.z));
|
i_param_2.z + cM_rndFX(i_param_1.z));
|
||||||
mInitialPos[i].set(cM_rndF(1.0f) + 0.5f, cM_rndF(1.0f) + 0.5f, cM_rndF(1.0f) + 0.5f);
|
mInitialPos[i].set(cM_rndF(1.0f) + 0.5f, cM_rndF(1.0f) + 0.5f, cM_rndF(1.0f) + 0.5f);
|
||||||
mVelocity[i].set(param_4.x + cM_rndFX(param_3.x), param_4.y + cM_rndF(param_3.y),
|
mVelocity[i].set(i_param_4.x + cM_rndFX(i_param_3.x), i_param_4.y + cM_rndF(i_param_3.y),
|
||||||
param_4.z + cM_rndF(param_3.z));
|
i_param_4.z + cM_rndF(i_param_3.z));
|
||||||
|
|
||||||
mDoMtx_stack_c::transS(current.pos);
|
mDoMtx_stack_c::transS(current.pos);
|
||||||
mDoMtx_stack_c::ZXYrotM(shape_angle);
|
mDoMtx_stack_c::ZXYrotM(shape_angle);
|
||||||
|
@ -67,12 +67,12 @@ int daObjCRVHAHEN_c::HahenSet(cXyz param_1, cXyz param_2, cXyz param_3, cXyz par
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 80BD3628-80BD36E4 000368 00BC+00 1/1 0/0 0/0 .text Wall_Check__15daObjCRVHAHEN_cF4cXyz4cXyz */
|
/* 80BD3628-80BD36E4 000368 00BC+00 1/1 0/0 0/0 .text Wall_Check__15daObjCRVHAHEN_cF4cXyz4cXyz */
|
||||||
bool daObjCRVHAHEN_c::Wall_Check(cXyz origin, cXyz target) {
|
bool daObjCRVHAHEN_c::Wall_Check(cXyz i_origin, cXyz i_target) {
|
||||||
dBgS_LinChk line_check;
|
dBgS_LinChk line_check;
|
||||||
|
|
||||||
cXyz linePos(origin.x + target.x, origin.y, origin.z + target.z);
|
cXyz linePos(i_origin.x + i_target.x, i_origin.y, i_origin.z + i_target.z);
|
||||||
|
|
||||||
line_check.Set(&origin, &linePos, NULL);
|
line_check.Set(&i_origin, &linePos, NULL);
|
||||||
|
|
||||||
bool did_line_cross = dComIfG_Bgsp().LineCross(&line_check);
|
bool did_line_cross = dComIfG_Bgsp().LineCross(&line_check);
|
||||||
|
|
||||||
|
@ -86,8 +86,8 @@ bool daObjCRVHAHEN_c::Wall_Check(cXyz origin, cXyz target) {
|
||||||
|
|
||||||
/* 80BD3720-80BD38DC 000460 01BC+00 1/1 0/0 0/0 .text Hahen_Hakai__15daObjCRVHAHEN_cFii
|
/* 80BD3720-80BD38DC 000460 01BC+00 1/1 0/0 0/0 .text Hahen_Hakai__15daObjCRVHAHEN_cFii
|
||||||
*/
|
*/
|
||||||
void daObjCRVHAHEN_c::Hahen_Hakai(int start, int end) {
|
void daObjCRVHAHEN_c::Hahen_Hakai(int i_start, int i_end) {
|
||||||
for (int i = start; i < end; ++i) {
|
for (int i = i_start; i < i_end; ++i) {
|
||||||
if (mStatus[i] > 3) {
|
if (mStatus[i] > 3) {
|
||||||
mPos[i].y = mGroundHeight;
|
mPos[i].y = mGroundHeight;
|
||||||
mRotation[i].x = 0x4000;
|
mRotation[i].x = 0x4000;
|
||||||
|
@ -95,9 +95,13 @@ void daObjCRVHAHEN_c::Hahen_Hakai(int start, int end) {
|
||||||
mVelocity[i].y += +-9.0f;
|
mVelocity[i].y += +-9.0f;
|
||||||
Wall_Check(mPos[i], mVelocity[i]);
|
Wall_Check(mPos[i], mVelocity[i]);
|
||||||
|
|
||||||
mPos[i].x = mPos[i].x + mVelocity[i].x;
|
// mPos[i].x = mPos[i].x + mVelocity[i].x;
|
||||||
mPos[i].y = mPos[i].y + mVelocity[i].y;
|
// mPos[i].y = mPos[i].y + mVelocity[i].y;
|
||||||
mPos[i].z = mPos[i].z + mVelocity[i].z;
|
// mPos[i].z = mPos[i].z + mVelocity[i].z;
|
||||||
|
|
||||||
|
mPos[i].x += mVelocity[i].x;
|
||||||
|
mPos[i].y += mVelocity[i].y;
|
||||||
|
mPos[i].z += mVelocity[i].z;
|
||||||
|
|
||||||
mRotation[i].x += mRotSpeed[i].x;
|
mRotation[i].x += mRotSpeed[i].x;
|
||||||
mRotation[i].y += mRotSpeed[i].y;
|
mRotation[i].y += mRotSpeed[i].y;
|
||||||
|
@ -111,6 +115,10 @@ void daObjCRVHAHEN_c::Hahen_Hakai(int start, int end) {
|
||||||
mVelocity[i].x = mVelocity[i].x * 0.8f;
|
mVelocity[i].x = mVelocity[i].x * 0.8f;
|
||||||
mVelocity[i].z = mVelocity[i].z * 0.8f;
|
mVelocity[i].z = mVelocity[i].z * 0.8f;
|
||||||
|
|
||||||
|
// mVelocity[i].y *= -0.6f;
|
||||||
|
// mVelocity[i].x *= 0.8f;
|
||||||
|
// mVelocity[i].z *= 0.8f;
|
||||||
|
|
||||||
mRotation[i].x = 0x4000;
|
mRotation[i].x = 0x4000;
|
||||||
mRotation[i].y = mRotation[i].y + mRotSpeed[i].y;
|
mRotation[i].y = mRotation[i].y + mRotSpeed[i].y;
|
||||||
}
|
}
|
||||||
|
@ -122,11 +130,10 @@ void daObjCRVHAHEN_c::Hahen_Hakai(int start, int end) {
|
||||||
void daObjCRVHAHEN_c::CheckCull() {
|
void daObjCRVHAHEN_c::CheckCull() {
|
||||||
daPy_py_c* player_actor = daPy_getPlayerActorClass();
|
daPy_py_c* player_actor = daPy_getPlayerActorClass();
|
||||||
cXyz& player_pos = fopAcM_GetPosition((fopAc_ac_c*)player_actor);
|
cXyz& player_pos = fopAcM_GetPosition((fopAc_ac_c*)player_actor);
|
||||||
int culled_num = 1;
|
|
||||||
|
|
||||||
|
int culled_num = 1;
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
float fVar2 = mPos[i].absXZ(player_pos);
|
if ((mPos[i].absXZ(player_pos) > mTimer) && !checkViewArea(&mPos[i])) {
|
||||||
if ((fVar2 > mTimer) && !checkViewArea(&mPos[i])) {
|
|
||||||
culled_num++;
|
culled_num++;
|
||||||
if (culled_num == 10) {
|
if (culled_num == 10) {
|
||||||
fopAcM_delete(this);
|
fopAcM_delete(this);
|
||||||
|
@ -151,7 +158,7 @@ bool daObjCRVHAHEN_c::checkViewArea(cXyz* i_this) {
|
||||||
|
|
||||||
/* 80BD3B20-80BD3B74 000860 0054+00 1/1 0/0 0/0 .text Execute__15daObjCRVHAHEN_cFv */
|
/* 80BD3B20-80BD3B74 000860 0054+00 1/1 0/0 0/0 .text Execute__15daObjCRVHAHEN_cFv */
|
||||||
int daObjCRVHAHEN_c::Execute() {
|
int daObjCRVHAHEN_c::Execute() {
|
||||||
if (mDrawHahen != false) {
|
if (mDrawHahen) {
|
||||||
daObjCRVHAHEN_c::Hahen_Hakai(0, 10);
|
daObjCRVHAHEN_c::Hahen_Hakai(0, 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -163,27 +170,24 @@ int daObjCRVHAHEN_c::Execute() {
|
||||||
|
|
||||||
/* 80BD3B74-80BD3C0C 0008B4 0098+00 1/1 0/0 0/0 .text Delete__15daObjCRVHAHEN_cFv */
|
/* 80BD3B74-80BD3C0C 0008B4 0098+00 1/1 0/0 0/0 .text Delete__15daObjCRVHAHEN_cFv */
|
||||||
int daObjCRVHAHEN_c::Delete() {
|
int daObjCRVHAHEN_c::Delete() {
|
||||||
J3DModelData* model_data;
|
|
||||||
|
|
||||||
if (mInitialized) {
|
if (mInitialized) {
|
||||||
model_data = (J3DModelData*)dRes_control_c::getRes(
|
J3DModelData* model_data = (J3DModelData*)dRes_control_c::getRes(
|
||||||
l_arcName, "CaravanPiece.bmd", g_dComIfG_gameInfo.mResControl.mObjectInfo, 0x80);
|
l_arcName, "CaravanPiece.bmd", g_dComIfG_gameInfo.mResControl.mObjectInfo, 0x80);
|
||||||
g_dComIfG_gameInfo.play.removeSimpleModel(model_data, (int)(char)current.roomNo);
|
dComIfGp_removeSimpleModel(model_data, (int)(char)current.roomNo);
|
||||||
}
|
}
|
||||||
|
|
||||||
dComIfG_resDelete(&this->mPhase, l_arcName);
|
dComIfG_resDelete(&mPhase, l_arcName);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 80BD3C0C-80BD3CA0 00094C 0094+00 1/1 0/0 0/0 .text setBaseMtx__15daObjCRVHAHEN_cFv */
|
/* 80BD3C0C-80BD3CA0 00094C 0094+00 1/1 0/0 0/0 .text setBaseMtx__15daObjCRVHAHEN_cFv */
|
||||||
void daObjCRVHAHEN_c::setBaseMtx() {
|
void daObjCRVHAHEN_c::setBaseMtx() {
|
||||||
int i;
|
for (int i = 0; i < 10; i++) {
|
||||||
for (i = 0; i < 10; i++) {
|
|
||||||
mDoMtx_stack_c::transS(mPos[i]);
|
mDoMtx_stack_c::transS(mPos[i]);
|
||||||
mDoMtx_stack_c::ZXYrotM(mRotation[i]);
|
mDoMtx_stack_c::ZXYrotM(mRotation[i]);
|
||||||
mDoMtx_stack_c::scaleM(mInitialPos[i]);
|
mDoMtx_stack_c::scaleM(mInitialPos[i]);
|
||||||
PSMTXCopy(mDoMtx_stack_c::get(), mpModel[i]->mBaseTransformMtx);
|
mpModel[i]->setBaseTRMtx(mDoMtx_stack_c::get());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,7 +218,7 @@ static int daObjCRVHAHEN_Draw(daObjCRVHAHEN_c* i_this) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 80BD3D9C-80BD3DBC 000ADC 0020+00 2/1 0/0 0/0 .text daObjCRVHAHEN_Execute__FP15daObjCRVHAHEN_c */
|
/* 80BD3D9C-80BD3DBC 000ADC 0020+00 2/1 0/0 0/0 .text daObjCRVHAHEN_Execute__FP15daObjCRVHAHEN_c */
|
||||||
static void daObjCRVHAHEN_Execute(daObjCRVHAHEN_c* i_this) {
|
static int daObjCRVHAHEN_Execute(daObjCRVHAHEN_c* i_this) {
|
||||||
i_this->Execute();
|
i_this->Execute();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -222,30 +226,29 @@ static void daObjCRVHAHEN_Execute(daObjCRVHAHEN_c* i_this) {
|
||||||
int daObjCRVHAHEN_c::create() {
|
int daObjCRVHAHEN_c::create() {
|
||||||
fopAcM_SetupActor(this, daObjCRVHAHEN_c);
|
fopAcM_SetupActor(this, daObjCRVHAHEN_c);
|
||||||
|
|
||||||
J3DModelData* model_data;
|
|
||||||
|
|
||||||
int phase_state = dComIfG_resLoad(&this->mPhase, l_arcName);
|
int phase_state = dComIfG_resLoad(&mPhase, l_arcName);
|
||||||
|
|
||||||
if (phase_state == cPhs_COMPLEATE_e) {
|
if (phase_state == cPhs_COMPLEATE_e) {
|
||||||
if (!fopAcM_entrySolidHeap(this, useHeapInit, 0x1320)) {
|
if (!fopAcM_entrySolidHeap(this, useHeapInit, 0x1320)) {
|
||||||
return cPhs_ERROR_e;
|
return cPhs_ERROR_e;
|
||||||
} else {
|
|
||||||
mDrawHahen = 0;
|
|
||||||
gravity = -9.0f;
|
|
||||||
model_data = (J3DModelData*)dRes_control_c::getRes(
|
|
||||||
l_arcName, "CaravanPiece.bmd", g_dComIfG_gameInfo.mResControl.mObjectInfo, 0x80);
|
|
||||||
g_dComIfG_gameInfo.play.addSimpleModel(model_data, (int)(char)current.roomNo, '\0');
|
|
||||||
mInitialized = true;
|
|
||||||
mGroundHeight = current.pos.y;
|
|
||||||
fopAcM_setCullSizeBox(this, -1000.0, -500.0, -1000.0, 1000.0, 500.0, 1000.0);
|
|
||||||
daObjCRVHAHEN_Execute(this);
|
|
||||||
}
|
}
|
||||||
|
mDrawHahen = 0;
|
||||||
|
gravity = -9.0f;
|
||||||
|
J3DModelData* model_data = (J3DModelData*)dRes_control_c::getRes(
|
||||||
|
l_arcName, "CaravanPiece.bmd", g_dComIfG_gameInfo.mResControl.mObjectInfo, 0x80);
|
||||||
|
dComIfGp_addSimpleModel(model_data, (int)(char)current.roomNo, '\0');
|
||||||
|
mInitialized = true;
|
||||||
|
mGroundHeight = current.pos.y;
|
||||||
|
fopAcM_setCullSizeBox(this, -1000.0, -500.0, -1000.0, 1000.0, 500.0, 1000.0);
|
||||||
|
daObjCRVHAHEN_Execute(this);
|
||||||
}
|
}
|
||||||
return phase_state;
|
return phase_state;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 80BD3FE0-80BD3FE8 000D20 0008+00 1/0 0/0 0/0 .text daObjCRVHAHEN_IsDelete__FP15daObjCRVHAHEN_c */
|
/* 80BD3FE0-80BD3FE8 000D20 0008+00 1/0 0/0 0/0 .text daObjCRVHAHEN_IsDelete__FP15daObjCRVHAHEN_c */
|
||||||
static bool daObjCRVHAHEN_IsDelete(daObjCRVHAHEN_c* i_this) {
|
static int daObjCRVHAHEN_IsDelete(daObjCRVHAHEN_c* i_this) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue