mirror of
https://github.com/zeldaret/tww.git
synced 2026-06-04 10:48:31 -04:00
201 lines
5.5 KiB
C++
201 lines
5.5 KiB
C++
//
|
|
// Generated by dtk
|
|
// Translation Unit: d_a_ikari.cpp
|
|
//
|
|
|
|
#include "d/actor/d_a_ikari.h"
|
|
#include "d/res/res_ikari.h"
|
|
#include "d/d_kankyo_wether.h"
|
|
#include "d/d_procname.h"
|
|
#include "d/d_s_play.h"
|
|
#include "m_Do/m_Do_mtx.h"
|
|
|
|
daObjIkariHIO_c l_HIO;
|
|
|
|
const char daIkari_c::M_arcname[6] = "Ikari";
|
|
|
|
/* 000000EC-0000010C .text createHeap_CB__FP10fopAc_ac_c */
|
|
static BOOL createHeap_CB(fopAc_ac_c* i_this) {
|
|
return ((daIkari_c*)i_this)->_createHeap();
|
|
}
|
|
|
|
/* 0000010C-000001C4 .text setMtx__9daIkari_cFv */
|
|
void daIkari_c::setMtx() {
|
|
mpModel->setBaseScale(scale);
|
|
|
|
mDoMtx_stack_c::transS(current.pos);
|
|
mDoMtx_stack_c::YrotM(shape_angle.y);
|
|
mDoMtx_stack_c::XrotM(current.angle.x);
|
|
mDoMtx_stack_c::YrotM(-shape_angle.y);
|
|
mDoMtx_stack_c::YrotM(current.angle.y);
|
|
|
|
mpModel->setBaseTRMtx(mDoMtx_stack_c::get());
|
|
}
|
|
|
|
/* 000001C4-00000290 .text _createHeap__9daIkari_cFv */
|
|
BOOL daIkari_c::_createHeap() {
|
|
static int ikari_bdl[5] = {
|
|
IKARI_BDL_S_IKARI2,
|
|
IKARI_BDL_S_IKARI2,
|
|
IKARI_BDL_S_IKARI2,
|
|
IKARI_BDL_S_IKARI3,
|
|
IKARI_BDL_S_IKARI4,
|
|
};
|
|
|
|
J3DModelData* modelData =
|
|
static_cast<J3DModelData*>(dComIfG_getObjectRes(M_arcname, ikari_bdl[mModelType]));
|
|
JUT_ASSERT(0x7e, modelData != NULL);
|
|
mpModel = mDoExt_J3DModel__create(modelData, 0x00080000, 0x11000022);
|
|
|
|
if (mpModel == NULL) {
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/* 00000290-000002F8 .text getArg__9daIkari_cFv */
|
|
void daIkari_c::getArg() {
|
|
u32 param = fopAcM_GetParam(this);
|
|
|
|
mModelType = fopAcM_GetParamBit(param, 8, 16);
|
|
mEnvType = param;
|
|
|
|
if (mModelType == 0xff) {
|
|
mModelType = 0;
|
|
}
|
|
|
|
if (mEnvType == 0xff) {
|
|
scale.x = 1.0f;
|
|
scale.y = 1.0f;
|
|
scale.z = 1.0f;
|
|
} else if (mEnvType == 0x01) {
|
|
scale.x = 1.27f;
|
|
scale.y = 1.27f;
|
|
scale.z = 1.27f;
|
|
}
|
|
}
|
|
|
|
/* 000002F8-000003CC .text _execute__9daIkari_cFv */
|
|
bool daIkari_c::_execute() {
|
|
mTimer++;
|
|
|
|
cXyz* windVec = dKyw_get_wind_vec();
|
|
s16 windAngle = cM_atan2s(windVec->x, windVec->z);
|
|
f32* windPow = dKyw_get_wind_power();
|
|
|
|
shape_angle.y = windAngle;
|
|
|
|
f32 rotX = *windPow * 10000.0f * l_HIO.mWindPowerScale;
|
|
|
|
current.angle.x =
|
|
rotX + rotX * JMASSin(mTimer * (REG0_S(5) + 500) & 0xffff);
|
|
|
|
setMtx();
|
|
|
|
return true;
|
|
}
|
|
|
|
/* 000003CC-00000494 .text _draw__9daIkari_cFv */
|
|
bool daIkari_c::_draw() {
|
|
if (mEnvType == 1) {
|
|
g_env_light.settingTevStruct(TEV_TYPE_BG0, ¤t.pos, &tevStr);
|
|
tevStr.mColorC0.r = g_env_light.mActorC0.r;
|
|
tevStr.mColorC0.g = g_env_light.mActorC0.g;
|
|
tevStr.mColorC0.b = g_env_light.mActorC0.b;
|
|
tevStr.mColorC0.a = g_env_light.mActorC0.a;
|
|
tevStr.mColorK0.r = g_env_light.mActorK0.r;
|
|
tevStr.mColorK0.g = g_env_light.mActorK0.g;
|
|
tevStr.mColorK0.b = g_env_light.mActorK0.b;
|
|
} else {
|
|
g_env_light.settingTevStruct(TEV_TYPE_ACTOR, ¤t.pos, &tevStr);
|
|
}
|
|
g_env_light.setLightTevColorType(mpModel, &tevStr);
|
|
mDoExt_modelUpdateDL(mpModel);
|
|
return true;
|
|
}
|
|
|
|
/* 00000494-000005B0 .text _create__9daIkari_cFv */
|
|
int daIkari_c::_create() {
|
|
int phase = dComIfG_resLoad(&mPhs, M_arcname);
|
|
|
|
fopAcM_SetupActor(this, daIkari_c);
|
|
|
|
if (phase == cPhs_COMPLEATE_e) {
|
|
getArg();
|
|
|
|
if (!fopAcM_entrySolidHeap(this, createHeap_CB, 0xC20)) {
|
|
return cPhs_ERROR_e;
|
|
} else {
|
|
setMtx();
|
|
|
|
f32 mScaleX = scale.x;
|
|
|
|
fopAcM_SetMtx(this, &mpModel->mBaseTransformMtx[0]);
|
|
fopAcM_setCullSizeBox(this,
|
|
-160.0f * mScaleX, -2500.0f * mScaleX, -600.0f * mScaleX,
|
|
160.0f * mScaleX, 100.0f * mScaleX, 600.0f * mScaleX);
|
|
fopAcM_setCullSizeFar(this, 10.0f);
|
|
|
|
mTimer = (short)(int)cM_rndF(32768.0f);
|
|
}
|
|
}
|
|
|
|
return phase;
|
|
}
|
|
|
|
/* 000005B0-000005E0 .text _delete__9daIkari_cFv */
|
|
bool daIkari_c::_delete() {
|
|
dComIfG_resDelete(&mPhs, M_arcname);
|
|
return true;
|
|
}
|
|
|
|
/* 000005E0-00000600 .text daIkariCreate__FPv */
|
|
static s32 daIkariCreate(void* i_this) {
|
|
return ((daIkari_c*)i_this)->_create();
|
|
}
|
|
|
|
/* 00000600-00000624 .text daIkariDelete__FPv */
|
|
static BOOL daIkariDelete(void* i_this) {
|
|
return ((daIkari_c*)i_this)->_delete();
|
|
}
|
|
|
|
/* 00000624-00000648 .text daIkariExecute__FPv */
|
|
static BOOL daIkariExecute(void* i_this) {
|
|
return ((daIkari_c*)i_this)->_execute();
|
|
}
|
|
|
|
/* 00000648-0000066C .text daIkariDraw__FPv */
|
|
static BOOL daIkariDraw(void* i_this) {
|
|
return ((daIkari_c*)i_this)->_draw();
|
|
}
|
|
|
|
/* 0000066C-00000674 .text daIkariIsDelete__FPv */
|
|
static BOOL daIkariIsDelete(void* i_this) {
|
|
return TRUE;
|
|
}
|
|
|
|
static actor_method_class daIkariMethodTable = {
|
|
(process_method_func)daIkariCreate,
|
|
(process_method_func)daIkariDelete,
|
|
(process_method_func)daIkariExecute,
|
|
(process_method_func)daIkariIsDelete,
|
|
(process_method_func)daIkariDraw,
|
|
};
|
|
|
|
actor_process_profile_definition g_profile_IKARI = {
|
|
/* LayerID */ fpcLy_CURRENT_e,
|
|
/* ListID */ 0x0007,
|
|
/* ListPrio */ fpcPi_CURRENT_e,
|
|
/* ProcName */ PROC_IKARI,
|
|
/* Proc SubMtd */ &g_fpcLf_Method.base,
|
|
/* Size */ sizeof(daIkari_c),
|
|
/* SizeOther */ 0,
|
|
/* Parameters */ 0,
|
|
/* Leaf SubMtd */ &g_fopAc_Method.base,
|
|
/* Priority */ 0x019D,
|
|
/* Actor SubMtd */ &daIkariMethodTable,
|
|
/* Status */ fopAcStts_NOCULLEXEC_e | fopAcStts_CULL_e | fopAcStts_UNK4000_e | fopAcStts_UNK40000_e,
|
|
/* Group */ fopAc_ACTOR_e,
|
|
/* CullType */ fopAc_CULLBOX_CUSTOM_e,
|
|
};
|