mirror of
https://github.com/zeldaret/tww.git
synced 2026-05-23 06:54:16 -04:00
238 lines
6.0 KiB
C++
238 lines
6.0 KiB
C++
//
|
|
// Generated by dtk
|
|
// Translation Unit: d_cam_param.cpp
|
|
//
|
|
|
|
#include "d/d_cam_param.h"
|
|
#include "d/d_kankyo_wether.h"
|
|
#include "m_Do/m_Do_mtx.h"
|
|
#include "SSystem/SComponent/c_math.h"
|
|
|
|
/* 800AF384-800AF4F4 .text rationalBezierRatio__8dCamMathFff */
|
|
f32 dCamMath::rationalBezierRatio(f32 x, f32 y) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800AF4F4-800AF544 .text customRBRatio__8dCamMathFff */
|
|
f32 dCamMath::customRBRatio(f32 x, f32 y) {
|
|
/* Nonmatching */
|
|
if (x > 0.7071068f) {
|
|
if (x < 0.0f) {
|
|
return -1.0f;
|
|
} else {
|
|
return 1.0f;
|
|
}
|
|
}
|
|
|
|
return rationalBezierRatio(x * 1.414214f, y);
|
|
}
|
|
|
|
/* 800AF544-800AF5A0 .text zoomFovy__8dCamMathFff */
|
|
f32 dCamMath::zoomFovy(f32 deg, f32 y) {
|
|
cDegree d(deg);
|
|
return cAngle::r2d(cM_atan2f(d.Sin(), d.Cos() * y));
|
|
}
|
|
|
|
/* 800AF5A0-800AF608 .text xyzRotateX__8dCamMathFR4cXyz7cSAngle */
|
|
cXyz dCamMath::xyzRotateX(cXyz& vec, cSAngle angle) {
|
|
cXyz ret;
|
|
Mtx mtx;
|
|
cMtx_XrotS(mtx, angle.Val());
|
|
cMtx_multVec(mtx, &vec, &ret);
|
|
return ret;
|
|
}
|
|
|
|
/* 800AF608-800AF670 .text xyzRotateY__8dCamMathFR4cXyz7cSAngle */
|
|
cXyz dCamMath::xyzRotateY(cXyz& vec, cSAngle angle) {
|
|
cXyz ret;
|
|
Mtx mtx;
|
|
cMtx_YrotS(mtx, angle.Val());
|
|
cMtx_multVec(mtx, &vec, &ret);
|
|
return ret;
|
|
}
|
|
|
|
/* 800AF670-800AF734 .text xyzHorizontalDistance__8dCamMathFR4cXyzR4cXyz */
|
|
f32 dCamMath::xyzHorizontalDistance(cXyz& a, cXyz& b) {
|
|
f64 x = a.x - b.x;
|
|
f64 z = a.z - b.z;
|
|
f64 distSq = x*x + z*z;
|
|
return sqrt(distSq);
|
|
}
|
|
|
|
/* 800AF734-800AF810 .text xyzProjPosOnYZ__8dCamMathF7cSAngleR4cXyzR4cXyz */
|
|
cXyz dCamMath::xyzProjPosOnYZ(cSAngle angle, cXyz& a, cXyz& b) {
|
|
/* Nonmatching */
|
|
cXyz line;
|
|
cXyz rot;
|
|
line = b - a;
|
|
rot = xyzRotateY(line, -angle);
|
|
rot.x = 0.0f;
|
|
line = xyzRotateY(rot, angle);
|
|
return b + line;
|
|
}
|
|
|
|
/* 800AF810-800AF838 .text __ct__9dCstick_cFv */
|
|
dCstick_c::dCstick_c() {
|
|
/* Nonmatching */
|
|
m00 = 0.2f;
|
|
m04 = 0.95f;
|
|
m08 = 6;
|
|
}
|
|
|
|
/* 800AF838-800AF840 .text Shift__9dCstick_cFUl */
|
|
s32 dCstick_c::Shift(u32) {
|
|
return 0;
|
|
}
|
|
|
|
/* 800AF840-800AF8F4 .text __ct__11dCamBGChk_cFv */
|
|
dCamBGChk_c::dCamBGChk_c() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800AF8F4-800AF930 .text __ct__11dCamParam_cFl */
|
|
dCamParam_c::dCamParam_c(s32 styleIdx) {
|
|
Change(styleIdx);
|
|
}
|
|
|
|
/* 800AF930-800AF978 .text __dt__11dCamParam_cFv */
|
|
dCamParam_c::~dCamParam_c() {
|
|
}
|
|
|
|
/* 800AF978-800AF9BC .text Change__11dCamParam_cFl */
|
|
BOOL dCamParam_c::Change(s32 i_styleIdx) {
|
|
mStyleIdx = i_styleIdx;
|
|
if (i_styleIdx < style_num) {
|
|
mpStyle = &styles[mStyleIdx];
|
|
return TRUE;
|
|
} else {
|
|
mpStyle = &styles[0];
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* 800AF9BC-800AFA04 .text SearchStyle__11dCamParam_cFUl */
|
|
s32 dCamParam_c::SearchStyle(u32 r4) {
|
|
s32 styleIndex = -1;
|
|
for (s32 i = 0; i < style_num; i++) {
|
|
if (styles[i].m00 == r4) {
|
|
styleIndex = i;
|
|
break;
|
|
}
|
|
}
|
|
return styleIndex;
|
|
}
|
|
|
|
/* 800AFA04-800AFAA4 .text ratiof__11dCamParam_cFffff */
|
|
f32 dCamParam_c::ratiof(f32 t, f32 upper, f32 lower, f32 base) {
|
|
if (t == 0.0f)
|
|
return base;
|
|
|
|
f32 ret = base;
|
|
if (t < 0.0f) {
|
|
ret += (ret - lower) * dCamMath::customRBRatio(t, 0.25f);
|
|
} else {
|
|
ret += (upper - ret) * dCamMath::customRBRatio(t, 0.25f);
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
/* 800AFAA4-800AFB00 .text DefaultRadius__11dCamParam_cFPf */
|
|
BOOL dCamParam_c::DefaultRadius(f32* radius) {
|
|
/* Nonmatching */
|
|
f32 min, max;
|
|
if (mpStyle->m3C < mpStyle->m40) {
|
|
min = mpStyle->m3C;
|
|
max = mpStyle->m40;
|
|
} else {
|
|
min = mpStyle->m40;
|
|
max = mpStyle->m3C;
|
|
}
|
|
|
|
if (*radius > max) {
|
|
*radius = max;
|
|
return FALSE;
|
|
} else if (*radius < min) {
|
|
*radius = min;
|
|
return FALSE;
|
|
} else {
|
|
return TRUE;
|
|
}
|
|
}
|
|
|
|
/* 800AFB00-800AFB88 .text RadiusRatio__11dCamParam_cFf */
|
|
void dCamParam_c::RadiusRatio(f32) {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800AFB88-800AFBB8 .text CenterHeight__11dCamParam_cFf */
|
|
f32 dCamParam_c::CenterHeight(f32 t) {
|
|
return ratiof(t, mpStyle->centerHeightUpper, mpStyle->centerHeightLower, mpStyle->centerHeightBase);
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800AFBB8-800AFBE8 .text Fovy__11dCamParam_cFf */
|
|
f32 dCamParam_c::Fovy(f32 t) {
|
|
return ratiof(t, mpStyle->fovyUpper, mpStyle->fovyLower, mpStyle->fovyBase);
|
|
}
|
|
|
|
/* 800AFBE8-800AFC74 .text LockonLongitude__11dCamParam_cFf */
|
|
s16 dCamParam_c::LockonLongitude(f32 t) {
|
|
cSAngle ret(mpStyle->lockonLongitudeMin);
|
|
ret += (cSAngle(mpStyle->lockonLongitudeMax) - ret) * t;
|
|
return ret.Val();
|
|
}
|
|
|
|
/* 800AFC74-800AFD00 .text LockonLatitude__11dCamParam_cFf */
|
|
s16 dCamParam_c::LockonLatitude(f32 t) {
|
|
cSAngle ret(mpStyle->lockonLatitudeMin);
|
|
ret += (cSAngle(mpStyle->lockonLatitudeMax) - ret) * t;
|
|
return ret.Val();
|
|
}
|
|
|
|
/* 800AFD00-800AFD20 .text LockonFovy__11dCamParam_cFf */
|
|
f32 dCamParam_c::LockonFovy(f32 t) {
|
|
f32 ret = mpStyle->lockonFovyMin;
|
|
ret += t * (mpStyle->lockonFovyMax - ret);
|
|
return ret;
|
|
}
|
|
|
|
/* 800AFD20-800AFD40 .text LockonCenterHeight__11dCamParam_cFf */
|
|
f32 dCamParam_c::LockonCenterHeight(f32 t) {
|
|
f32 ret = mpStyle->lockonCenterHeightMin;
|
|
ret += t * (mpStyle->lockonCenterHeightMax - ret);
|
|
return ret;
|
|
}
|
|
|
|
/* 800AFD40-800AFEE0 .text __ct__11dCamSetup_cFv */
|
|
dCamSetup_c::dCamSetup_c() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800AFEE0-800AFF40 .text __dt__11dCamSetup_cFv */
|
|
dCamSetup_c::~dCamSetup_c() {
|
|
/* Nonmatching */
|
|
}
|
|
|
|
/* 800AFF40-800AFFB0 .text CheckLatitudeRange__11dCamSetup_cFPs */
|
|
bool dCamSetup_c::CheckLatitudeRange(s16* angle) {
|
|
s16 upper = cAngle::d2s(m060);
|
|
s16 lower = cAngle::d2s(m05C);
|
|
|
|
if (*angle > upper) {
|
|
*angle = upper;
|
|
return false;
|
|
}
|
|
|
|
if (*angle < lower) {
|
|
*angle = lower;
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/* 800AFFB0-800B0004 .text FanBank__11dCamSetup_cFv */
|
|
f32 dCamSetup_c::FanBank() {
|
|
return m080 + cM_rndFX(m084) * dKyw_get_wind_pow();
|
|
}
|