/** * @file d_a_obj_laundry.cpp * */ #include "d/dolzel_rel.h" // IWYU pragma: keep #include "d/actor/d_a_obj_laundry.h" #include "SSystem/SComponent/c_math.h" #include "d/d_cc_d.h" #include "d/d_com_inf_game.h" #include "d/d_kankyo_wether.h" // // Declarations: // /* ############################################################################################## */ /* 80C52000-80C52034 000000 0034+00 3/3 0/0 0/0 .rodata M_attr__10daObjLdy_c */ daObjLdy_Attr_c const daObjLdy_c::mAttr = {5.0f, 30.0f, 130.0f, -50.0f, 0.15f, 0.45f, 0.3f, 1000.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0, 10, 0}; /* 80C50F98-80C51088 000078 00F0+00 1/1 0/0 0/0 .text create_init__10daObjLdy_cFv */ void daObjLdy_c::create_init() { fopAcM_setCullSizeBox(this, -60.0f, -200.0f, -60.0f, 60.0f, 50.0f, 60.0f); fopAcM_setCullSizeFar(this, 1.5f); LaundJoint_c* joint = &mJoints[0]; int index = 0; for (int i = 0; i < 3; i++) { joint->mPos1 = current.pos; joint->mPos1.y += (index + 1) * mAttr.field_0xc; joint->mPos2 = joint->mPos1; index++; joint++; } gravity = mAttr.field_0x0; initBaseMtx(); } /* 80C51088-80C510F8 000168 0070+00 1/1 0/0 0/0 .text initBaseMtx__10daObjLdy_cFv */ void daObjLdy_c::initBaseMtx() { setBaseMtx(); LaundJoint_c* joint = &mJoints[0]; for (int i = 0; i < 3; i++) { f32 cosAngleY = cM_scos(shape_angle.y); f32 sinAngleY = cM_ssin(shape_angle.y); joint->mPos4.set(sinAngleY, 0.0f, cosAngleY); joint++; } } /* 80C510F8-80C5116C 0001D8 0074+00 2/2 0/0 0/0 .text setBaseMtx__10daObjLdy_cFv */ void daObjLdy_c::setBaseMtx() { mDoMtx_stack_c::transS(current.pos); mDoMtx_stack_c::YrotM(shape_angle.y); mDoMtx_stack_c::ZrotM(shape_angle.z); mpModel->setBaseTRMtx(mDoMtx_stack_c::get()); PSMTXCopy(mDoMtx_stack_c::get(), mMtx); } /* 80C5116C-80C51194 00024C 0028+00 1/1 0/0 0/0 .text getJointAngle__10daObjLdy_cFP5csXyzi */ void daObjLdy_c::getJointAngle(csXyz* i_jointAngle, int i_index) { LaundJoint_c* joint = &mJoints[i_index]; *i_jointAngle = joint->mAngle; } /* ############################################################################################## */ /* 80C52054-80C52098 000054 0044+00 0/0 0/0 0/0 .rodata ccCylSrc$3800 */ const static dCcD_SrcCyl ccCylSrc = { { {0x0, {{0x0, 0x0, 0x0}, {0x16048, 0x11}, 0x149}}, // mObj {dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x0}, // mGObjAt {dCcD_SE_NONE, 0x0, 0x0, 0x0, 0x4}, // mGObjTg {0x0}, // mGObjCo }, // mObjInf { {0.0f, -80.0f, 0.0f}, // mCenter 25.0f, // mRadius 25.0f // mHeight } // mCyl }; static f32 dummy(cXyz v) { return 40.0f + v.abs(); } /* 80C51194-80C51644 000274 04B0+00 1/1 0/0 0/0 .text setNormalClothPos__10daObjLdy_cFv */ void daObjLdy_c::setNormalClothPos() { cXyz adjustedPosition; cXyz windVector = dKyw_get_AllWind_vecpow(¤t.pos); windVector *= mAttr.field_0xc * mAttr.field_0x10; f32 windPower = windVector.abs(); LaundJoint_c* joint = &mJoints[0]; if (mCyl.ChkTgHit() != 0) { cCcD_Obj* tgHitObj = mCyl.GetTgHitObj(); if (tgHitObj->ChkAtType(AT_TYPE_40) != 0 || tgHitObj->ChkAtType(AT_TYPE_ARROW) != 0) { cXyz position = fopAcM_GetPosition(dComIfGp_getPlayer(0)) - mJoints[1].mPos1; position.normalizeZP(); position *= 100.0f; for (int i = 2; i >= 0; i--) { mJoints[i].mPos3 = position; position *= mAttr.field_0x18; } divorceParent(); } else { if (tgHitObj->ChkAtType(AT_TYPE_BOOMERANG) != 0) { divorceParent(); } } } else { if (mCyl.ChkCoHit() != 0) { if (fopAcM_GetName(mCyl.GetCoHitAc()) == PROC_NPC_TK) { cXyz position = fopAcM_GetPosition(dComIfGp_getPlayer(0)) - mJoints[1].mPos1; position.normalizeZP(); position *= 100.0f; for (int i = 2; i >= 0; i--) { mJoints[i].mPos3 = position; position *= mAttr.field_0x18; } divorceParent(); } } else { if (!windVector.isZero()) { for (int i = 0; i < 3; i++) { if (cM_rnd() < 0.6f && cM_rnd() < 0.1f) { joint->mPos3 += joint->mPos4 * windPower; } joint++; } } } } int i; LaundJoint_c* mJoint = &mJoints[0]; cXyz* currentPosition = &fopAcM_GetPosition(this); for (i = 0; i < 3; i++) { adjustedPosition = *currentPosition - mJoint->mPos1; adjustedPosition.y += gravity; adjustedPosition += mJoint->mPos3; adjustedPosition.normalizeZP(); mJoint->mPos1 = *currentPosition + (adjustedPosition * mAttr.field_0xc); mJoint->mPos3 = (mJoint->mPos3 + (mJoint->mPos2 - mJoint->mPos1)) * mAttr.field_0x14; mJoint->mPos2 = mJoint->mPos1; currentPosition = &mJoint->mPos1; mJoint++; } } /* 80C51644-80C5183C 000724 01F8+00 1/1 0/0 0/0 .text calcJointAngle__10daObjLdy_cFv */ void daObjLdy_c::calcJointAngle() { cXyz position; LaundJoint_c* joint = &mJoints[0]; mDoMtx_stack_c::copy(mMtx); for (int i = 0; i < 3; i++) { mDoMtx_stack_c::push(); mDoMtx_stack_c::inverse(); mDoMtx_stack_c::multVec(&joint->mPos1, &position); mDoMtx_stack_c::pop(); position *= -1.0f; joint->mAngle.x = cM_atan2s(position.z, position.y); joint->mAngle.z = cM_atan2s(-position.y, position.absXZ()); mDoMtx_stack_c::XrotM(joint->mAngle.x); mDoMtx_stack_c::transM(0.0f, mAttr.field_0xc, 0.0f); joint++; } } /* 80C5183C-80C51844 00091C 0008+00 1/1 0/0 0/0 .text divorceParent__10daObjLdy_cFv */ bool daObjLdy_c::divorceParent() { return true; } /* 80C51844-80C518FC 000924 00B8+00 1/1 0/0 0/0 .text nodeCallBack__FP8J3DJointi */ static int nodeCallBack(J3DJoint* i_joint, int i_callbackCondition) { J3DModel* jointModel; u16 jointNo; csXyz jointAngle[2]; if (i_callbackCondition != 0) { return 1; } jointNo = i_joint->getJntNo(); jointModel = j3dSys.getModel(); ((daObjLdy_c*)jointModel->getUserArea())->getJointAngle(jointAngle, jointNo); cMtx_copy(jointModel->getAnmMtx(jointNo), mDoMtx_stack_c::get()); mDoMtx_stack_c::XrotM(jointAngle->x); jointModel->setAnmMtx(jointNo, mDoMtx_stack_c::get()); mDoMtx_copy(mDoMtx_stack_c::get(), J3DSys::mCurrentMtx); return 1; } /* 80C520F0-80C520F4 -00001 0004+00 3/3 0/0 0/0 .data l_arcName */ static char* l_arcName = "J_Sentaku"; int daObjLdy_c::getObjType() { return fopAcM_GetParam(this) & 0xff; } int daObjLdy_c::createHeap() { J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes(l_arcName, "J_Sentaku.bmd"); mpModel = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000284); J3DAnmTextureSRTKey* key = (J3DAnmTextureSRTKey*)dComIfG_getObjectRes(l_arcName, "J_Sentaku.btk"); mpBtkAnm = new mDoExt_btkAnm(); int initResult = mpBtkAnm->init(modelData, key, 1, 2, 1.0f, 0, -1); if (initResult == 0) { return 0; } mpBtkAnm->setFrame(getObjType()); for (u16 i = 0; i < 3; i++) { J3DJoint* joint = mpModel->getModelData()->getJointNodePointer(i); if (joint != NULL) { joint->setCallBack(nodeCallBack); mpModel->setUserArea((uintptr_t)this); } } if (mpModel == NULL) { return 0; } return 1; } /* 80C518FC-80C51A98 0009DC 019C+00 1/1 0/0 0/0 .text createSolidHeap__FP10fopAc_ac_c */ static int createSolidHeap(fopAc_ac_c* i_this) { return static_cast(i_this)->createHeap(); } int daObjLdy_c::daObjLdy_Draw() { g_env_light.settingTevStruct(0x10, ¤t.pos, &tevStr); g_env_light.setLightTevColorType_MAJI(mpModel, &tevStr); dComIfGd_setListBG(); mpBtkAnm->entry(mpModel->getModelData()); mDoExt_modelUpdateDL(mpModel); dComIfGd_setList(); return 1; } /* 80C51AE0-80C51B9C 000BC0 00BC+00 1/0 0/0 0/0 .text daObjLdy_Draw__FP10daObjLdy_c */ static int daObjLdy_Draw(daObjLdy_c* i_this) { return i_this->daObjLdy_Draw(); } int daObjLdy_c::daObjLdy_Execute() { setNormalClothPos(); setBaseMtx(); calcJointAngle(); return 1; } /* 80C51B9C-80C51BDC 000C7C 0040+00 1/0 0/0 0/0 .text daObjLdy_Execute__FP10daObjLdy_c */ static int daObjLdy_Execute(daObjLdy_c* i_this) { return i_this->daObjLdy_Execute(); } /* 80C51BDC-80C51BE4 000CBC 0008+00 1/0 0/0 0/0 .text daObjLdy_IsDelete__FP10daObjLdy_c */ static int daObjLdy_IsDelete(daObjLdy_c* i_this) { return 1; } daObjLdy_c::~daObjLdy_c() { dComIfG_resDelete(&mPhase, l_arcName); } /* 80C51BE4-80C51D2C 000CC4 0148+00 1/0 0/0 0/0 .text daObjLdy_Delete__FP10daObjLdy_c */ static int daObjLdy_Delete(daObjLdy_c* i_this) { i_this->~daObjLdy_c(); return 1; } int daObjLdy_c::create() { fopAcM_ct(this, daObjLdy_c); int phase = dComIfG_resLoad(&mPhase, l_arcName); if (phase == cPhs_COMPLEATE_e) { if (!fopAcM_entrySolidHeap(this, createSolidHeap, 0x9a0)) { phase = cPhs_ERROR_e; } else { create_init(); fopAcM_SetMtx(this, mMtx); } } return phase; } /* 80C51D68-80C51EC0 000E48 0158+00 1/0 0/0 0/0 .text daObjLdy_Create__FP10fopAc_ac_c */ static int daObjLdy_Create(fopAc_ac_c* i_this) { return ((daObjLdy_c*)i_this)->create(); } /* 80C520F4-80C52114 -00001 0020+00 1/0 0/0 0/0 .data l_daObjLdy_Method */ static actor_method_class l_daObjLdy_Method = { (process_method_func)daObjLdy_Create, (process_method_func)daObjLdy_Delete, (process_method_func)daObjLdy_Execute, (process_method_func)daObjLdy_IsDelete, (process_method_func)daObjLdy_Draw, }; /* 80C52114-80C52144 -00001 0030+00 0/0 0/0 1/0 .data g_profile_Obj_Laundry */ extern actor_process_profile_definition g_profile_Obj_Laundry = { fpcLy_CURRENT_e, // mLayerID 7, // mListID fpcPi_CURRENT_e, // mListPrio PROC_Obj_Laundry, // mProcName &g_fpcLf_Method.base, // sub_method sizeof(daObjLdy_c), // mSize 0, // mSizeOther 0, // mParameters &g_fopAc_Method.base, // sub_method 37, // mPriority &l_daObjLdy_Method, // sub_method 0x00040180, // mStatus fopAc_ACTOR_e, // mActorType fopAc_CULLBOX_CUSTOM_e, // cullType };