mirror of
https://github.com/TwilitRealm/dusklight
synced 2026-05-25 15:05:06 -04:00
341 lines
11 KiB
C++
341 lines
11 KiB
C++
/**
|
|
* @file d_a_obj_lv6SwGate.cpp
|
|
*
|
|
*/
|
|
|
|
#include "d/dolzel_rel.h" // IWYU pragma: keep
|
|
#include "d/d_s_play.h"
|
|
|
|
#include "d/actor/d_a_obj_lv6SwGate.h"
|
|
|
|
daLv6SwGate_HIO_c::daLv6SwGate_HIO_c() {
|
|
mSpeed = 15.0f;
|
|
mMaximumSpeed = 30.0f;
|
|
mAcceleration = 15.0f;
|
|
mMovementAmount = 275.0f;
|
|
unk18 = 3;
|
|
}
|
|
|
|
#if DEBUG
|
|
void daLv6SwGate_HIO_c::genMessage(JORMContext* context)
|
|
{
|
|
context->genLabel("--- 開く ---", 0);
|
|
context->genSlider("速度", &this->mSpeed, 0.1f, 100.0f);
|
|
context->genLabel("\n--- 閉まる ---", 0);
|
|
context->genSlider("最大速度", &this->mMaximumSpeed, 0.1f, 100.0f);
|
|
context->genSlider("加速度", &this->mAcceleration, 0.1f, 100.0f);
|
|
context->genLabel("\n------", 0);
|
|
context->genSlider("移動量", &this->mMovementAmount, 0.1f, 100.0f);
|
|
}
|
|
#endif
|
|
|
|
static daLv6SwGate_HIO_c l_HIO;
|
|
|
|
const dCcD_SrcGObjInf daLv6SwGate_c::mCcDObjInfo = {
|
|
{0, {{0, 0, 0}, {0x400, 0x11}, {0x79}}}, {1, 0, 0, 0, 0}, {0xA, 0, 0, 0, 0}, {0}
|
|
};
|
|
|
|
dCcD_SrcCyl daLv6SwGate_c::mCcDCyl = {
|
|
mCcDObjInfo,
|
|
{
|
|
{
|
|
{0.0f, 0.0f, 0.0f}, // mCenter
|
|
0.0f, // mRadius
|
|
0.0f // mHeight
|
|
} // mCyl
|
|
} // mCylAttr
|
|
};
|
|
|
|
static cull_box l_cull_box = {-1200.0f, -300.0f, -100.0f, 1200.0f, 300.0f, 100.0f};
|
|
|
|
void daLv6SwGate_c::setBaseMtx() {
|
|
mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z);
|
|
mDoMtx_stack_c::ZXYrotM(shape_angle.x, shape_angle.y, shape_angle.z);
|
|
mDoMtx_stack_c::transM(-150.0f - mMovementAmount, 0.0f, 0.0f);
|
|
mModel1->setBaseScale(scale);
|
|
mModel1->setBaseTRMtx(mDoMtx_stack_c::get());
|
|
MTXCopy(mDoMtx_stack_c::get(), mBgMtx);
|
|
mDoMtx_stack_c::transS(current.pos.x, current.pos.y, current.pos.z);
|
|
mDoMtx_stack_c::ZXYrotM(shape_angle.x, shape_angle.y + 0x8000, shape_angle.z);
|
|
mDoMtx_stack_c::transM(-150.0f - mMovementAmount, 0.0f, 0.0f);
|
|
mModel2->setBaseScale(scale);
|
|
mModel2->setBaseTRMtx(mDoMtx_stack_c::get());
|
|
MTXCopy(mDoMtx_stack_c::get(), mMtx);
|
|
}
|
|
|
|
int daLv6SwGate_c::CreateHeap() {
|
|
J3DModelData* modelData = (J3DModelData*)dComIfG_getObjectRes("L6SwGate", 4);
|
|
JUT_ASSERT(273, modelData != NULL);
|
|
mModel1 = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
|
|
|
|
if (mModel1 == NULL) {
|
|
return FALSE;
|
|
}
|
|
modelData = (J3DModelData*)dComIfG_getObjectRes("L6SwGate", 4);
|
|
JUT_ASSERT(284, modelData != NULL);
|
|
mModel2 = mDoExt_J3DModel__create(modelData, 0x80000, 0x11000084);
|
|
if (mModel2 == NULL) {
|
|
return FALSE;
|
|
}
|
|
mpBgW = new dBgW();
|
|
if (mpBgW != NULL && !mpBgW->Set((cBgD_t*)dComIfG_getObjectRes("L6SwGate", 7), 0x1, &mMtx)) {
|
|
mpBgW->SetCrrFunc(dBgS_MoveBGProc_TypicalRotY);
|
|
} else {
|
|
mpBgW = NULL;
|
|
return FALSE;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
int daLv6SwGate_c::create() {
|
|
fopAcM_ct(this, daLv6SwGate_c);
|
|
if (getSw2() != 0xff && fopAcM_isSwitch(this, getSw2())) {
|
|
return cPhs_ERROR_e;
|
|
}
|
|
int phase = dComIfG_resLoad(&mPhase, "L6SwGate");
|
|
if (phase == cPhs_COMPLEATE_e) {
|
|
if (MoveBGCreate("L6SwGate", 7, dBgS_MoveBGProc_TypicalRotY, 0x1700, NULL) == cPhs_ERROR_e)
|
|
{
|
|
return cPhs_ERROR_e;
|
|
}
|
|
fopAcM_SetMtx(this, mModel1->getBaseTRMtx());
|
|
// copy-paste error? l_cull_box.max.y twice
|
|
fopAcM_setCullSizeBox(this, l_cull_box.min.x, l_cull_box.min.y, l_cull_box.min.z,
|
|
l_cull_box.max.x, l_cull_box.max.y, l_cull_box.max.y);
|
|
mCcStts.Init(0xff, 0xff, this);
|
|
for (int i = 0; i < 12; i++) {
|
|
mCcDCyls[i].Set(mCcDCyl);
|
|
mCcDCyls[i].SetStts(&mCcStts);
|
|
}
|
|
if (mpBgW != NULL) {
|
|
dComIfG_Bgsp().Regist(mpBgW, this);
|
|
mpBgW->Move();
|
|
}
|
|
mUnderlyingSwitchState = getSwState();
|
|
if (mUnderlyingSwitchState == 0xf) {
|
|
mUnderlyingSwitchState = 0;
|
|
}
|
|
mUnderylingSwitch = getSw();
|
|
mIsSwitch = isSwitch();
|
|
mMovementAmount = 0.0f;
|
|
if (mIsSwitch) {
|
|
mMovementAmount = l_HIO.mMovementAmount;
|
|
}
|
|
init_modeWait();
|
|
setBaseMtx();
|
|
#if DEBUG
|
|
l_HIO.entryHIO("スイッチゲート(Lv6)");
|
|
#endif
|
|
}
|
|
return phase;
|
|
}
|
|
|
|
u8 daLv6SwGate_c::isSwitch() {
|
|
return fopAcM_isSwitch(this, mUnderylingSwitch) ^ mUnderlyingSwitchState;
|
|
}
|
|
|
|
int daLv6SwGate_c::Execute(Mtx** i_pMTx) {
|
|
moveGate();
|
|
for (int i = 0; i < 12; i++) {
|
|
if (mCcDCyls[i].ChkTgHit()) {
|
|
dCcD_GObjInf* o = mCcDCyls[i].GetTgHitGObj();
|
|
if (o->GetAtType() & 0x400) {
|
|
init_modeBreak();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
for (int i = 0; i < 6; i++) {
|
|
cXyz p(-150.0f - mMovementAmount + 120.0f - i * (55.0f + oREG_F(2)), 0.0f, 0.0f);
|
|
mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z);
|
|
mDoMtx_stack_c::multVec(&p, &p);
|
|
p += current.pos;
|
|
mCcDCyls[i].SetR(30.0f + oREG_F(0));
|
|
mCcDCyls[i].SetH(300.0f + oREG_F(1));
|
|
mCcDCyls[i].SetC(p);
|
|
dComIfG_Ccsp()->Set(&mCcDCyls[i]);
|
|
}
|
|
for (int i = 0; i < 6; i++) {
|
|
cXyz p(-150.0f - mMovementAmount + 120.0f - i * (55.0f + oREG_F(3)), 0.0f, 0.0f);
|
|
mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y + 0x8000, shape_angle.z);
|
|
mDoMtx_stack_c::multVec(&p, &p);
|
|
p += current.pos;
|
|
mCcDCyls[i + 6].SetR(30.0f + oREG_F(0));
|
|
mCcDCyls[i + 6].SetH(300.0f + oREG_F(1));
|
|
mCcDCyls[i + 6].SetC(p);
|
|
dComIfG_Ccsp()->Set(&mCcDCyls[i + 6]);
|
|
}
|
|
*i_pMTx = &mModel1->getBaseTRMtx();
|
|
setBaseMtx();
|
|
if (mpBgW != NULL) {
|
|
mpBgW->Move();
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
enum DALV6SWGATE_C_MODE {
|
|
DALV6SWGATE_C_MODE_WAIT,
|
|
DALV6SWGATE_C_MODE_OPEN,
|
|
DALV6SWGATE_C_MODE_CLOSE,
|
|
DALV6SWGATE_C_MODE_BREAK,
|
|
};
|
|
|
|
void daLv6SwGate_c::moveGate() {
|
|
typedef void (daLv6SwGate_c::*func_call)();
|
|
const static func_call mode_proc[] = {
|
|
/* DALV6SWGATE_C_MODE_WAIT */ &daLv6SwGate_c::modeWait,
|
|
/* DALV6SWGATE_C_MODE_OPEN */ &daLv6SwGate_c::modeOpen,
|
|
/* DALV6SWGATE_C_MODE_CLOSE */ &daLv6SwGate_c::modeClose,
|
|
/* DALV6SWGATE_C_MODE_BREAK */ &daLv6SwGate_c::modeBreak,
|
|
};
|
|
|
|
u8 oldIsSwitch = mIsSwitch;
|
|
mIsSwitch = isSwitch();
|
|
if (mIsSwitch != oldIsSwitch) {
|
|
if (mIsSwitch) {
|
|
init_modeOpen();
|
|
} else {
|
|
init_modeClose();
|
|
}
|
|
}
|
|
(this->*mode_proc[mMode])();
|
|
}
|
|
|
|
void daLv6SwGate_c::init_modeWait() {
|
|
mMode = DALV6SWGATE_C_MODE_WAIT;
|
|
}
|
|
|
|
void daLv6SwGate_c::modeWait() {
|
|
return;
|
|
}
|
|
|
|
void daLv6SwGate_c::init_modeOpen() {
|
|
mMode = DALV6SWGATE_C_MODE_OPEN;
|
|
}
|
|
|
|
void daLv6SwGate_c::modeOpen() {
|
|
f32 calc = cLib_addCalc(&mMovementAmount, l_HIO.mMovementAmount, 0.1f, l_HIO.mSpeed, 5.0f);
|
|
mDoAud_seStartLevel(Z2SE_OBJ_L6_SW_GATE_OP_MV, ¤t.pos, 0,
|
|
dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
if (calc == 0.0f) {
|
|
mDoAud_seStart(Z2SE_OBJ_L6_SW_GATE_OP_ST, ¤t.pos, 0,
|
|
dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
init_modeWait();
|
|
}
|
|
}
|
|
|
|
void daLv6SwGate_c::init_modeClose() {
|
|
fopAcM_SetSpeedF(this, 0.0f);
|
|
mMode = DALV6SWGATE_C_MODE_CLOSE;
|
|
}
|
|
|
|
void daLv6SwGate_c::modeClose() {
|
|
int unused = cLib_chaseF(&speedF, l_HIO.mMaximumSpeed, l_HIO.mAcceleration);
|
|
f32 calc = cLib_addCalc(&mMovementAmount, 0.0f, 1.0f, fopAcM_GetSpeedF(this), 5.0f);
|
|
mDoAud_seStartLevel(Z2SE_OBJ_L6_SW_GATE_CL_MV, ¤t.pos, 0,
|
|
dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
if (calc == 0.0f) {
|
|
mDoAud_seStart(Z2SE_OBJ_L6_SW_GATE_CL_ST, ¤t.pos, 0,
|
|
dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
init_modeWait();
|
|
}
|
|
}
|
|
|
|
void daLv6SwGate_c::init_modeBreak() {
|
|
OS_REPORT("== break! ==\n");
|
|
mDoAud_seStart(Z2SE_OBJ_TRAP_BREAK, ¤t.pos, 0, dComIfGp_getReverb(fopAcM_GetRoomNo(this)));
|
|
mMode = DALV6SWGATE_C_MODE_BREAK;
|
|
}
|
|
|
|
void daLv6SwGate_c::modeBreak() {
|
|
cXyz p(-150.0f - mMovementAmount, 0.0f, 0.0f);
|
|
mDoMtx_stack_c::ZXYrotS(shape_angle.x, shape_angle.y, shape_angle.z);
|
|
mDoMtx_stack_c::multVec(&p, &p);
|
|
p += current.pos;
|
|
dComIfGp_particle_set(0x8B79, &p, &shape_angle, 0);
|
|
dComIfGp_particle_set(0x8B7A, &p, &shape_angle, 0);
|
|
dComIfGp_particle_set(0x8B7B, &p, &shape_angle, 0);
|
|
dComIfGp_particle_set(0x8B7C, &p, &shape_angle, 0);
|
|
dComIfGp_particle_set(0x8B7D, &p, &shape_angle, 0);
|
|
p.set(-150.0f - mMovementAmount, 0.0f, 0.0f);
|
|
csXyz shapeAngle(shape_angle);
|
|
shapeAngle.y += 0x8000;
|
|
mDoMtx_stack_c::ZXYrotS(shapeAngle.x, shapeAngle.y, shapeAngle.z);
|
|
mDoMtx_stack_c::multVec(&p, &p);
|
|
p += current.pos;
|
|
dComIfGp_particle_set(0x8B79, &p, &shapeAngle, 0);
|
|
dComIfGp_particle_set(0x8B7A, &p, &shapeAngle, 0);
|
|
dComIfGp_particle_set(0x8B7B, &p, &shapeAngle, 0);
|
|
dComIfGp_particle_set(0x8B7C, &p, &shapeAngle, 0);
|
|
dComIfGp_particle_set(0x8B7D, &p, &shapeAngle, 0);
|
|
if (getSw2() != 0xff) {
|
|
fopAcM_onSwitch(this, getSw2());
|
|
}
|
|
fopAcM_delete(this);
|
|
}
|
|
|
|
int daLv6SwGate_c::Draw() {
|
|
g_env_light.settingTevStruct(0x10, ¤t.pos, &tevStr);
|
|
g_env_light.setLightTevColorType_MAJI(mModel1, &tevStr);
|
|
dComIfGd_setListBG();
|
|
mDoExt_modelUpdateDL(mModel1);
|
|
mDoExt_modelUpdateDL(mModel2);
|
|
dComIfGd_setList();
|
|
return TRUE;
|
|
}
|
|
|
|
int daLv6SwGate_c::Delete() {
|
|
dComIfG_resDelete(&mPhase, "L6SwGate");
|
|
if (mpBgW != NULL && mpBgW->ChkUsed()) {
|
|
dComIfG_Bgsp().Release(mpBgW);
|
|
}
|
|
#if DEBUG
|
|
l_HIO.removeHIO(this);
|
|
#endif
|
|
return TRUE;
|
|
}
|
|
|
|
static int daLv6SwGate_Draw(daLv6SwGate_c* i_this) {
|
|
return i_this->MoveBGDraw();
|
|
}
|
|
|
|
static int daLv6SwGate_Execute(daLv6SwGate_c* i_this) {
|
|
return i_this->MoveBGExecute();
|
|
}
|
|
|
|
static int daLv6SwGate_Delete(daLv6SwGate_c* i_this) {
|
|
fpc_ProcID id = fopAcM_GetID(i_this);
|
|
return i_this->MoveBGDelete();
|
|
}
|
|
|
|
static int daLv6SwGate_Create(fopAc_ac_c* i_this) {
|
|
daLv6SwGate_c* this_gate = (daLv6SwGate_c*)i_this;
|
|
fpc_ProcID id = fopAcM_GetID(i_this);
|
|
return this_gate->create();
|
|
}
|
|
|
|
static actor_method_class l_daLv6SwGate_Method = {
|
|
(process_method_func)daLv6SwGate_Create,
|
|
(process_method_func)daLv6SwGate_Delete,
|
|
(process_method_func)daLv6SwGate_Execute,
|
|
NULL,
|
|
(process_method_func)daLv6SwGate_Draw,
|
|
};
|
|
|
|
actor_process_profile_definition g_profile_Obj_Lv6SwGate = {
|
|
fpcLy_CURRENT_e, // mLayerID
|
|
3, // mListID
|
|
fpcPi_CURRENT_e, // mListPrio
|
|
PROC_Obj_Lv6SwGate, // mProcName
|
|
&g_fpcLf_Method.base, // sub_method
|
|
sizeof(daLv6SwGate_c), // mSize
|
|
0, // mSizeOther
|
|
0, // mParameters
|
|
&g_fopAc_Method.base, // sub_method
|
|
624, // mPriority
|
|
&l_daLv6SwGate_Method, // sub_method
|
|
0x00040000, // mStatus
|
|
fopAc_ACTOR_e, // mActorType
|
|
fopAc_CULLBOX_CUSTOM_e, // cullType
|
|
};
|