tww/src/JSystem/J3DGraphBase/J3DShapeMtx.cpp

433 lines
16 KiB
C++

//
// Generated by dtk
// Translation Unit: J3DShapeMtx.cpp
//
#include "JSystem/JSystem.h" // IWYU pragma: keep
#include "JSystem/J3DGraphBase/J3DShapeMtx.h"
#include "JSystem/J3DGraphBase/J3DGD.h"
#include "JSystem/J3DGraphBase/J3DPacket.h"
#include "JSystem/J3DGraphBase/J3DShapeDraw.h"
#include "JSystem/J3DGraphBase/J3DSys.h"
#include "JSystem/J3DGraphBase/J3DTransform.h"
#include "JSystem/J3DGraphAnimator/J3DModel.h"
#include "JSystem/J3DGraphAnimator/J3DModelData.h"
extern void J3DFifoLoadNrmMtxImm(Mtx, u32);
extern void J3DFifoLoadNrmMtxImm3x3(Mtx33, u32);
extern void J3DFifoLoadPosMtxImm(Mtx, u32);
u32 J3DShapeMtx::sCurrentPipeline;
/* 802DB9D8-802DBA1C .text loadMtxIndx_PNGP__11J3DShapeMtxCFiUs */
void J3DShapeMtx::loadMtxIndx_PNGP(int mtxNo, u16 index) const {
J3DFifoLoadIndx(GX_CMD_LOAD_INDX_A, index, 0xB000 | ((u16)(mtxNo * 0x0C)));
J3DFifoLoadIndx(GX_CMD_LOAD_INDX_B, index, 0x8000 | ((u16)((mtxNo * 0x09) + 0x400)));
}
/* 802DBA1C-802DBA7C .text loadMtxIndx_PCPU__11J3DShapeMtxCFiUs */
void J3DShapeMtx::loadMtxIndx_PCPU(int mtxNo, u16 index) const {
J3DFifoLoadPosMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
j3dSys.loadNrmMtxIndx(mtxNo, index);
}
/* 802DBA7C-802DBAC8 .text loadMtxIndx_NCPU__11J3DShapeMtxCFiUs */
void J3DShapeMtx::loadMtxIndx_NCPU(int mtxNo, u16 index) const {
j3dSys.loadPosMtxIndx(mtxNo, index);
J3DFifoLoadNrmMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
}
/* 802DBAC8-802DBB20 .text loadMtxIndx_PNCPU__11J3DShapeMtxCFiUs */
void J3DShapeMtx::loadMtxIndx_PNCPU(int mtxNo, u16 index) const {
J3DFifoLoadPosMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
J3DFifoLoadNrmMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
}
/* 802DBB20-802DBB94 .text loadMtxImm_PNGP__14J3DShapeMtxImmCFiUs */
void J3DShapeMtxImm::loadMtxImm_PNGP(int mtxNo, u16 index) const {
J3DFifoLoadPosMtxImm(j3dSys.getModelDrawMtx(index), mtxNo * 3);
loadNrmMtx(mtxNo, index);
}
/* 802DBB94-802DBC00 .text loadMtxImm_PCPU__14J3DShapeMtxImmCFiUs */
void J3DShapeMtxImm::loadMtxImm_PCPU(int mtxNo, u16 index) const {
J3DFifoLoadPosMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
loadNrmMtx(mtxNo, index);
}
/* 802DBC00-802DBC60 .text loadMtxImm_NCPU__14J3DShapeMtxImmCFiUs */
void J3DShapeMtxImm::loadMtxImm_NCPU(int mtxNo, u16 index) const {
J3DFifoLoadPosMtxImm(j3dSys.getModelDrawMtx(index), mtxNo * 3);
J3DFifoLoadNrmMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
}
/* 802DBC60-802DBCB8 .text loadMtxImm_PNCPU__14J3DShapeMtxImmCFiUs */
void J3DShapeMtxImm::loadMtxImm_PNCPU(int mtxNo, u16 index) const {
J3DFifoLoadPosMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
J3DFifoLoadNrmMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
}
/* 802DBCB8-802DBD44 .text loadMtxConcatView_PNGP__21J3DShapeMtxConcatViewCFiUs */
void J3DShapeMtxConcatView::loadMtxConcatView_PNGP(int mtxNo, u16 index) const {
Mtx mtx;
MTXConcat(*j3dSys.getShapePacket()->getBaseMtxPtr(), j3dSys.getModelDrawMtx(index), mtx);
J3DFifoLoadPosMtxImm(mtx, mtxNo * 3);
loadNrmMtx(mtxNo, index, mtx);
}
/* 802DBD44-802DBDD4 .text loadMtxConcatView_PCPU__21J3DShapeMtxConcatViewCFiUs */
void J3DShapeMtxConcatView::loadMtxConcatView_PCPU(int mtxNo, u16 index) const {
Mtx mtx;
MTXConcat(*j3dSys.getShapePacket()->getBaseMtxPtr(), j3dSys.getModelDrawMtx(index), mtx);
J3DFifoLoadPosMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
loadNrmMtx(mtxNo, index, mtx);
}
/* 802DBDD4-802DBE4C .text loadMtxConcatView_NCPU__21J3DShapeMtxConcatViewCFiUs */
void J3DShapeMtxConcatView::loadMtxConcatView_NCPU(int mtxNo, u16 index) const {
Mtx mtx;
MTXConcat(*j3dSys.getShapePacket()->getBaseMtxPtr(), j3dSys.getModelDrawMtx(index), mtx);
J3DFifoLoadPosMtxImm(mtx, mtxNo * 3);
J3DFifoLoadNrmMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
}
/* 802DBE4C-802DBEA4 .text loadMtxConcatView_PNCPU__21J3DShapeMtxConcatViewCFiUs */
void J3DShapeMtxConcatView::loadMtxConcatView_PNCPU(int mtxNo, u16 index) const {
J3DFifoLoadPosMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
J3DFifoLoadNrmMtxImm(*j3dSys.getShapePacket()->getBaseMtxPtr(), mtxNo * 3);
}
J3DShapeMtx::MtxLoadIndx J3DShapeMtx::sMtxLoadPipeline[] = {
&J3DShapeMtx::loadMtxIndx_PNGP,
&J3DShapeMtx::loadMtxIndx_PCPU,
&J3DShapeMtx::loadMtxIndx_NCPU,
&J3DShapeMtx::loadMtxIndx_PNCPU,
};
/* 802DBEA4-802DBF00 .text load__11J3DShapeMtxCFv */
void J3DShapeMtx::load() const {
MtxLoadIndx f = sMtxLoadPipeline[sCurrentPipeline];
(this->*f)(0, mUseMtxIndex);
}
/* 802DBF00-802DBF60 .text calcNBTScale__11J3DShapeMtxFRC3VecPA3_A3_fPA3_A3_f */
void J3DShapeMtx::calcNBTScale(const Vec& scale, Mtx33* pSrc, Mtx33* pDst) {
J3DPSMtx33Copy(pSrc[mUseMtxIndex], pDst[mUseMtxIndex]);
J3DScaleNrmMtx33(pDst[mUseMtxIndex], scale);
}
J3DShapeMtxImm::MtxLoadImm J3DShapeMtxImm::sMtxLoadPipeline[] = {
&J3DShapeMtxImm::loadMtxImm_PNGP,
&J3DShapeMtxImm::loadMtxImm_PCPU,
&J3DShapeMtxImm::loadMtxImm_NCPU,
&J3DShapeMtxImm::loadMtxImm_PNCPU,
};
/* 802DBF60-802DBFBC .text load__14J3DShapeMtxImmCFv */
void J3DShapeMtxImm::load() const {
MtxLoadImm f = sMtxLoadPipeline[sCurrentPipeline];
(this->*f)(0, mUseMtxIndex);
}
J3DShapeMtxConcatView::MtxLoadConcatView J3DShapeMtxConcatView::sMtxLoadPipeline[] = {
&J3DShapeMtxConcatView::loadMtxConcatView_PNGP,
&J3DShapeMtxConcatView::loadMtxConcatView_PCPU,
&J3DShapeMtxConcatView::loadMtxConcatView_NCPU,
&J3DShapeMtxConcatView::loadMtxConcatView_PNCPU,
};
u8* J3DShapeMtx::sCurrentScaleFlag;
u8 J3DShapeMtx::sNBTFlag;
Mtx * J3DShapeMtxConcatView::sMtxPtrTbl[2];
/* 802DBFBC-802DC08C .text load__21J3DShapeMtxConcatViewCFv */
void J3DShapeMtxConcatView::load() const {
sMtxPtrTbl[0] = (Mtx*)j3dSys.getModel()->getAnmMtx(0);
sMtxPtrTbl[1] = (Mtx*)j3dSys.getModel()->getWeightAnmMtx(0);
MtxLoadConcatView f = sMtxLoadPipeline[sCurrentPipeline];
j3dSys.setModelDrawMtx(sMtxPtrTbl[j3dSys.getModel()->getModelData()->getDrawMtxFlag(mUseMtxIndex)]);
(this->*f)(0, j3dSys.getModel()->getModelData()->getDrawMtxIndex(mUseMtxIndex));
}
/* 802DC08C-802DC184 .text loadNrmMtx__14J3DShapeMtxImmCFiUs */
void J3DShapeMtxImm::loadNrmMtx(int mtxNo, u16 index) const {
if (J3DShapeMtx::sCurrentScaleFlag[index] == 1) {
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(j3dSys.getModelDrawMtx(index), 0);
} else {
Mtx33 mtx33;
Vec* scale = j3dSys.getNBTScale();
J3DPSMtx33CopyFrom34(j3dSys.getModelDrawMtx(index), mtx33);
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
} else {
Mtx33 mtx33;
J3DPSCalcInverseTranspose(j3dSys.getModelDrawMtx(index), mtx33);
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
}
}
/* 802DC184-802DC254 .text loadNrmMtx__21J3DShapeMtxConcatViewCFiUsPA4_f */
void J3DShapeMtxConcatView::loadNrmMtx(int mtxNo, u16 index, Mtx mtx) const {
if (J3DShapeMtx::sCurrentScaleFlag[index] == 1) {
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(mtx, 0);
} else {
Mtx33 mtx33;
Vec* scale = j3dSys.getNBTScale();
J3DPSMtx33CopyFrom34(mtx, mtx33);
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
} else {
Mtx33 mtx33;
J3DPSCalcInverseTranspose(mtx, mtx33);
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
}
}
/* 802DC254-802DC2F4 .text load__16J3DShapeMtxMultiCFv */
void J3DShapeMtxMulti::load() const {
MtxLoadIndx f = sMtxLoadPipeline[sCurrentPipeline];
for (s32 i = 0; i < mUseMtxNum; i++) {
if (mUseMtxIndexTable[i] != 0xFFFF) {
(this->*f)(i, mUseMtxIndexTable[i]);
}
}
}
/* 802DC2F4-802DC388 .text calcNBTScale__16J3DShapeMtxMultiFRC3VecPA3_A3_fPA3_A3_f */
void J3DShapeMtxMulti::calcNBTScale(const Vec& param_0, Mtx33* param_1, Mtx33* param_2) {
for (int i = 0; i < mUseMtxNum; i++) {
if (mUseMtxIndexTable[i] != 0xFFFF) {
J3DPSMtx33Copy(param_1[mUseMtxIndexTable[i]], param_2[mUseMtxIndexTable[i]]);
J3DScaleNrmMtx33(param_2[mUseMtxIndexTable[i]], param_0);
}
}
}
/* 802DC388-802DC428 .text load__19J3DShapeMtxMultiImmCFv */
void J3DShapeMtxMultiImm::load() const {
MtxLoadImm f = sMtxLoadPipeline[sCurrentPipeline];
for (s32 i = 0; i < mUseMtxNum; i++) {
if (mUseMtxIndexTable[i] != 0xFFFF) {
(this->*f)(i, mUseMtxIndexTable[i]);
}
}
}
/* 802DC428-802DC524 .text load__26J3DShapeMtxMultiConcatViewCFv */
void J3DShapeMtxMultiConcatView::load() const {
sMtxPtrTbl[0] = (Mtx*)j3dSys.getModel()->getAnmMtx(0);
sMtxPtrTbl[1] = (Mtx*)j3dSys.getModel()->getWeightAnmMtx(0);
MtxLoadConcatView f = sMtxLoadPipeline[sCurrentPipeline];
for (s32 i = 0; i < mUseMtxNum; i++) {
u16 useMtxIndex = mUseMtxIndexTable[i];
if (useMtxIndex != 0xFFFF) {
u16 drawMtxIndex = j3dSys.getModel()->getModelData()->getDrawMtxIndex(useMtxIndex);
j3dSys.setModelDrawMtx(sMtxPtrTbl[j3dSys.getModel()->getModelData()->getDrawMtxFlag(useMtxIndex)]);
(this->*f)(i, drawMtxIndex);
}
}
}
/* 802DC524-802DC620 .text loadNrmMtx__19J3DShapeMtxMultiImmCFiUs */
void J3DShapeMtxMultiImm::loadNrmMtx(int mtxNo, u16 index) const {
if (J3DShapeMtx::sCurrentScaleFlag[index] == 1) {
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(j3dSys.getModelDrawMtx(index), mtxNo * 3);
} else {
Mtx33 mtx33;
Vec* scale = j3dSys.getNBTScale();
J3DPSMtx33CopyFrom34(j3dSys.getModelDrawMtx(index), mtx33);
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
} else {
Mtx33 mtx33;
J3DPSCalcInverseTranspose(j3dSys.getModelDrawMtx(index), mtx33);
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm3x3(mtx33, mtxNo * 3);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, mtxNo * 3);
}
}
}
/* 802DC620-802DC6F4 .text loadNrmMtx__26J3DShapeMtxMultiConcatViewCFiUsPA4_f */
void J3DShapeMtxMultiConcatView::loadNrmMtx(int mtxNo, u16 index, Mtx mtx) const {
if (J3DShapeMtx::sCurrentScaleFlag[index] == 1) {
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(mtx, mtxNo * 3);
} else {
Mtx33 mtx33;
Vec* scale = j3dSys.getNBTScale();
J3DPSMtx33CopyFrom34(mtx, mtx33);
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
} else {
Mtx33 mtx33;
J3DPSCalcInverseTranspose(mtx, mtx33);
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm3x3(mtx33, mtxNo * 3);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, mtxNo * 3);
}
}
}
/* 802DC6F4-802DC7B8 .text load__20J3DShapeMtxBBoardImmCFv */
void J3DShapeMtxBBoardImm::load() const {
Mtx mtx;
MTXCopy(j3dSys.getModelDrawMtx(mUseMtxIndex), mtx);
J3DCalcBBoardMtx(mtx);
J3DFifoLoadPosMtxImm(mtx, 0);
mtx[0][0] = 1.0f / mtx[0][0];
mtx[1][1] = 1.0f / mtx[1][1];
mtx[2][2] = 1.0f / mtx[2][2];
mtx[0][3] = 0.0f;
mtx[1][3] = 0.0f;
mtx[2][3] = 0.0f;
if (sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(mtx, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx(mtx, *scale);
J3DFifoLoadNrmMtxImm(mtx, 0);
}
}
/* 802DC7B8-802DC8C0 .text load__27J3DShapeMtxBBoardConcatViewCFv */
void J3DShapeMtxBBoardConcatView::load() const {
u16 drawMtxIndex = j3dSys.getModel()->getModelData()->getDrawMtxIndex(mUseMtxIndex);
Mtx mtx;
if (j3dSys.getModel()->getModelData()->getDrawMtxFlag(mUseMtxIndex) == 0) {
MtxP anmMtx = j3dSys.getModel()->getAnmMtx(drawMtxIndex);
MTXConcat(j3dSys.getViewMtx(), anmMtx, mtx);
} else {
MtxP weightMtx = j3dSys.getModel()->getWeightAnmMtx(drawMtxIndex);
MTXConcat(j3dSys.getViewMtx(), weightMtx, mtx);
}
J3DCalcBBoardMtx(mtx);
J3DFifoLoadPosMtxImm(mtx, 0);
mtx[0][0] = 1.0f / mtx[0][0];
mtx[1][1] = 1.0f / mtx[1][1];
mtx[2][2] = 1.0f / mtx[2][2];
mtx[0][3] = 0.0f;
mtx[1][3] = 0.0f;
mtx[2][3] = 0.0f;
if (sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(mtx, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx(mtx, *scale);
J3DFifoLoadNrmMtxImm(mtx, 0);
}
}
/* 802DC8C0-802DC9B8 .text load__21J3DShapeMtxYBBoardImmCFv */
void J3DShapeMtxYBBoardImm::load() const {
Mtx mtx;
MTXCopy(j3dSys.getModelDrawMtx(mUseMtxIndex), mtx);
J3DCalcYBBoardMtx(mtx);
J3DFifoLoadPosMtxImm(mtx, 0);
if (J3DShapeMtx::sCurrentScaleFlag[mUseMtxIndex] == 1) {
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(mtx, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx(mtx, *scale);
J3DFifoLoadNrmMtxImm(mtx, 0);
}
} else {
Mtx33 mtx33;
J3DPSCalcInverseTranspose(mtx, mtx33);
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
}
}
/* 802DC9B8-802DCAEC .text load__28J3DShapeMtxYBBoardConcatViewCFv */
void J3DShapeMtxYBBoardConcatView::load() const {
u16 drawMtxIndex = j3dSys.getModel()->getModelData()->getDrawMtxIndex(mUseMtxIndex);
Mtx mtx;
if (j3dSys.getModel()->getModelData()->getDrawMtxFlag(mUseMtxIndex) == 0) {
MtxP anmMtx = j3dSys.getModel()->getAnmMtx(drawMtxIndex);
MTXConcat(j3dSys.getViewMtx(), anmMtx, mtx);
} else {
MtxP weightMtx = j3dSys.getModel()->getWeightAnmMtx(drawMtxIndex);
MTXConcat(j3dSys.getViewMtx(), weightMtx, mtx);
}
J3DCalcYBBoardMtx(mtx);
J3DFifoLoadPosMtxImm(mtx, 0);
if (J3DShapeMtx::sCurrentScaleFlag[mUseMtxIndex] == 1) {
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm(mtx, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx(mtx, *scale);
J3DFifoLoadNrmMtxImm(mtx, 0);
}
} else {
Mtx33 mtx33;
J3DPSCalcInverseTranspose(mtx, mtx33);
if (J3DShapeMtx::sNBTFlag == 0) {
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
} else {
Vec* scale = j3dSys.getNBTScale();
J3DScaleNrmMtx33(mtx33, *scale);
J3DFifoLoadNrmMtxImm3x3(mtx33, 0);
}
}
}
/* 802DCAEC-802DCB04 .text __ct__12J3DShapeDrawFPCUcUl */
J3DShapeDraw::J3DShapeDraw(const u8* pDL, u32 size) {
mDisplayList = (void*) pDL;
mDisplayListSize = size;
}
/* 802DCB04-802DCB30 .text draw__12J3DShapeDrawCFv */
void J3DShapeDraw::draw() const {
GXCallDisplayList(mDisplayList, mDisplayListSize);
}