mirror of
https://github.com/TwilitRealm/dusklight
synced 2026-05-28 07:54:51 -04:00
b289dece80
* fix kankyo UB
* Fix TEV Stage DL writing
BE issue
* BE Fixes in materials/shapes
* Move to Aurora GD impl
* JUTDataFileHeader
* j3d: load vertex and texture not through GD
* Endian swap vertex data (mostly)
* Just exit(0) when closing the game
Fix crashes :godo:
* fix fopAcM_ct_placement and remove memcpy
* J3D: track vertex arrays correctly, swap work
* fix visibility, turn off overridden new/delete when we call into aurora
* event: cut name be
* Default window improvements
Double size, allow OS to decide position
* survive TParse::parseHeader_next
* color swap fix
* swap endian/fixes oob function pointer
* Remove GXGetViewportv stub
Aurora has it now
* Set array pointers via GD again
Relies on https://github.com/encounter/aurora/pull/35
* Let Aurora decide graphics backend
* disable procbar drawing
* Fix TColor endianness conversion issues
Fixes the wrong color for the flashing logo
* cam param swap
* simplify vtx loading, mat/amb color fix
* endian swap stb/fvb data
* aurora stat changes
* fix storage buffer crash
dont unnecessarily reassign vertex buffers in a way that forces aurora to recache things
* set bgobj spec fix
* add camera debug, endian swap more stb data, d_a_bg_obj::spec_data_c swapped
* JKRExpHeap: fix bad allocator slowdown
* solid tex
* texture caching
* log level
* fix window aspect ratio, disable bloom, endian swap camera type data
camera is now actually playing opening cutscene!!!!
* add GXDestroyTexObj to a couple stack init'd GXTexObjs, remove some diag printfs
* endian swap joint weight envelope data
* move to dusk config
* verbose arg errors
* better stub logging (for now)
* less logging, more BE
* more stubbing, move logging stuff around
* move all logging to aurora logging
* fix STUB_LOG, __FUNCTION__ isn't a string literal, wasn't building as it
was.
* update aurora
* fix heap alignment mismatch and always head align for now
* prevent them from fucking up my shit
* forward jut warning to DuskLog
* remove report logging
* maybe and i must emphasize maybe fix JMessage parsing
* this was a dumb idea
* preserve negative alignment for JKRHeap
* use normal free on macos and linux
* ^
* fix JMAHermiteInterpolation c impl
* endian swap J2DScreen mColor (oops)
* swap more J3D anim data, remove weird pointer addr check in J3DMaterial getMaterialAnm
* typo fix
* Fix aligned_alloc() size issues on POSIX
aligned_alloc() requires its input size to be a multiple of alignment. This wasn't being upheld so there were allocation failures in init code that made the game fail to start outside Windows.
Also just cleaned up some of this code a bit and removed fallback cases that *shouldn't* get hit.
* _Exit instead of exit()
Seriously I don't want destructors to run. Let the OS reclaim that shit.
* Reapply "Isolate JKRHeap operator overloads" (#39)
This reverts commit 3623b27f37.
* Fix some oopsies
* Fix hardcoded pointer size in JUTCacheFont::allocArray
* More operator overload fixes
Add void template specialization for jkrDelete
Add new[] placement overload. Apparently.
* Fix delete macros on nullptr
TIL C++ allows that.
* fix delete[]
* fix new(std::nothrow) overload
* fix avoid ub
* swap remaining anim data needed for title logo
* get rid of op 7
* move aurora_end_frame to correct spot
* juttexture destroy tex
* j2d animation be
* shutdown crash
* link warp material fix
* mDoExt_3DlineMat1_c fix
* hacky keyboard controls
* endian swap J2DResReference, add kb_pad to files.cmake
* fix some missing endian swaps in J2D, remove addr alignment check
* Remove heap unsetting in aurora calls
Never worked properly and not the right solution even if it did
* Don't print in DC stubs
They're fine to never implement
* Fix alignment stuff again
* Compile GF from dolphin lib
Doesn't seem to break anything and shuts up some stub warnings
* j3dtexture tlut obj fix
* addTexMtxIndexInDL fix
* don't recreate null tex data every frame
* the actual fix i wanted to push
* its kinda fakematch city over here
* insert hte efb copy
* limited window size / viewport support
* IsDelete FIX
---------
Co-authored-by: madeline <qwertytrogi@gmail.com>
Co-authored-by: Jasper St. Pierre <jstpierre@mecheye.net>
Co-authored-by: Jeffrey Crowell <jeff@crowell.biz>
Co-authored-by: TakaRikka <takarikka@outlook.com>
Co-authored-by: CraftyBoss <talibabdulmaalik@gmail.com>
Co-authored-by: Lurs <2795933+Lurs@users.noreply.github.com>
559 lines
16 KiB
C++
559 lines
16 KiB
C++
#ifndef J2DANIMATION_H
|
|
#define J2DANIMATION_H
|
|
|
|
#include "JSystem/J3DGraphAnimator/J3DAnimation.h"
|
|
#include "JSystem/JUtility/JUTPalette.h"
|
|
#include "JSystem/JKernel/JKRHeap.h"
|
|
#include "JSystem/JMath/JMath.h"
|
|
|
|
class J2DScreen;
|
|
struct ResTIMG;
|
|
|
|
enum J2DAnmKind {
|
|
KIND_TRANSFORM = 0,
|
|
KIND_COLOR = 1,
|
|
KIND_TEX_PATTERN = 2,
|
|
KIND_TEXTURE_SRT = 4,
|
|
KIND_TEV_REG = 5,
|
|
KIND_VISIBILITY = 6,
|
|
KIND_VTX_COLOR = 7
|
|
};
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmBase {
|
|
public:
|
|
J2DAnmBase() {
|
|
mFrame = 0.0f;
|
|
mFrameMax = 0;
|
|
}
|
|
J2DAnmBase(s16 frameMax) {
|
|
mFrame = 0.0f;
|
|
mFrameMax = frameMax;
|
|
}
|
|
virtual ~J2DAnmBase() {}
|
|
virtual void searchUpdateMaterialID(J2DScreen*) {}
|
|
|
|
s16 getFrameMax() const { return mFrameMax; }
|
|
void setFrame(f32 frame) { mFrame = frame; }
|
|
f32 getFrame() const { return mFrame; }
|
|
J2DAnmKind getKind() const { return mKind; }
|
|
|
|
/* 0x0 */ // vtable
|
|
/* 0x4 */ u8 field_0x4;
|
|
/* 0x5 */ u8 field_0x5;
|
|
/* 0x6 */ s16 mFrameMax;
|
|
/* 0x8 */ f32 mFrame;
|
|
/* 0xC */ J2DAnmKind mKind;
|
|
}; // Size: 0x10
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmVtxColor : public J2DAnmBase {
|
|
public:
|
|
J2DAnmVtxColor() {
|
|
mKind = KIND_VTX_COLOR;
|
|
for (int i = 0; i < ARRAY_SIZE(mAnmTableNum); i++) {
|
|
mAnmTableNum[i] = 0;
|
|
}
|
|
for (int i = 0; i < ARRAY_SIZE(mVtxColorIndexData); i++) {
|
|
mVtxColorIndexData[i] = NULL;
|
|
}
|
|
}
|
|
virtual ~J2DAnmVtxColor() {}
|
|
virtual void getColor(u8, u16, GXColor*) const {}
|
|
u16 getAnmTableNum(u8 param_0) const {
|
|
J3D_PANIC(342, param_0 < 2, "Error : range over.");
|
|
return mAnmTableNum[param_0];
|
|
}
|
|
J3DAnmVtxColorIndexData* getAnmVtxColorIndexData(u8 param_1, u16 param_2) const {
|
|
J3D_PANIC(344, param_1 < 2, "Error : range over.");
|
|
J3D_PANIC(345, param_2 < mAnmTableNum[param_1], "Error : range over.");
|
|
return &mVtxColorIndexData[param_1][param_2];
|
|
}
|
|
BE(u16)* getVtxColorIndexPointer(u8 param_0) const {
|
|
J3D_PANIC(351, param_0 < 2, "Error : range over.");
|
|
return mVtxColorIndexPointer[param_0];
|
|
}
|
|
|
|
/* 0x10 */ u16 mAnmTableNum[2];
|
|
/* 0x14 */ J3DAnmVtxColorIndexData* mVtxColorIndexData[2];
|
|
/* 0x1C */ BE(u16)* mVtxColorIndexPointer[2];
|
|
}; // Size: 0x24
|
|
|
|
struct J3DTransformInfo;
|
|
struct J3DTextureSRTInfo;
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmVtxColorKey : public J2DAnmVtxColor {
|
|
public:
|
|
J2DAnmVtxColorKey() {
|
|
for (int i = 0; i < ARRAY_SIZE(mInfoTable); i++) {
|
|
mInfoTable[i] = NULL;
|
|
}
|
|
}
|
|
virtual ~J2DAnmVtxColorKey() {}
|
|
virtual void getColor(u8, u16, GXColor*) const;
|
|
|
|
/* 0x24 */ J3DAnmColorKeyTable* mInfoTable[2];
|
|
/* 0x2C */ BE(s16)* mRValues;
|
|
/* 0x30 */ BE(s16)* mGValues;
|
|
/* 0x34 */ BE(s16)* mBValues;
|
|
/* 0x38 */ BE(s16)* mAValues;
|
|
}; // Size: 0x3C
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmVtxColorFull : public J2DAnmVtxColor {
|
|
public:
|
|
J2DAnmVtxColorFull() {
|
|
for (int i = 0; i < ARRAY_SIZE(mInfoTable); i++) {
|
|
mInfoTable[i] = NULL;
|
|
}
|
|
}
|
|
virtual ~J2DAnmVtxColorFull() {}
|
|
virtual void getColor(u8, u16, GXColor*) const;
|
|
|
|
/* 0x24 */ J3DAnmColorFullTable* mInfoTable[2];
|
|
/* 0x2C */ u8* mRValues;
|
|
/* 0x30 */ u8* mGValues;
|
|
/* 0x34 */ u8* mBValues;
|
|
/* 0x38 */ u8* mAValues;
|
|
}; // Size: 0x3C
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmVisibilityFull : public J2DAnmBase {
|
|
public:
|
|
J2DAnmVisibilityFull() {
|
|
field_0x10 = 0;
|
|
mTable = NULL;
|
|
field_0x12 = 0;
|
|
mValues = NULL;
|
|
mKind = KIND_VISIBILITY;
|
|
}
|
|
virtual ~J2DAnmVisibilityFull() {}
|
|
void getVisibility(u16, u8*) const;
|
|
|
|
/* 0x10 */ u16 field_0x10;
|
|
/* 0x12 */ u16 field_0x12;
|
|
/* 0x14 */ J3DAnmVisibilityFullTable* mTable;
|
|
/* 0x18 */ u8* mValues;
|
|
}; // Size: 0x1C
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmTransform : public J2DAnmBase {
|
|
public:
|
|
J2DAnmTransform(s16 frameMax, BE(f32)* pScaleValues, BE(s16)* pRotationValues, BE(f32)* pTranslateValues) : J2DAnmBase(frameMax) {
|
|
mScaleValues = pScaleValues;
|
|
mRotationValues = pRotationValues;
|
|
mTranslateValues = pTranslateValues;
|
|
mKind = KIND_TRANSFORM;
|
|
}
|
|
virtual ~J2DAnmTransform() {}
|
|
virtual void getTransform(u16, J3DTransformInfo*) const {}
|
|
|
|
/* 0x10 */ BE(f32)* mScaleValues;
|
|
/* 0x14 */ BE(s16)* mRotationValues;
|
|
/* 0x18 */ BE(f32)* mTranslateValues;
|
|
}; // Size: 0x1C
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmTransformKey : public J2DAnmTransform {
|
|
public:
|
|
J2DAnmTransformKey() : J2DAnmTransform(0, NULL, NULL, NULL) {
|
|
field_0x24 = 0;
|
|
mInfoTable = NULL;
|
|
}
|
|
virtual ~J2DAnmTransformKey() {}
|
|
virtual void getTransform(u16 p1, J3DTransformInfo* pInfo) const {
|
|
this->calcTransform(mFrame, p1, pInfo);
|
|
}
|
|
virtual void calcTransform(f32, u16, J3DTransformInfo*) const;
|
|
|
|
/* 0x1C */ u8 field_0x1c[6];
|
|
/* 0x22 */ u16 field_0x22;
|
|
/* 0x24 */ u32 field_0x24;
|
|
/* 0x28 */ J3DAnmTransformKeyTable* mInfoTable;
|
|
};
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmTransformFull : public J2DAnmTransform {
|
|
public:
|
|
J2DAnmTransformFull() : J2DAnmTransform(0, NULL, NULL, NULL) { mTableInfo = NULL; }
|
|
virtual ~J2DAnmTransformFull() {}
|
|
virtual void getTransform(u16, J3DTransformInfo*) const;
|
|
|
|
/* 0x1C */ u8 field_0x1c[6];
|
|
/* 0x22 */ u16 field_0x22;
|
|
/* 0x24 */ J3DAnmTransformFullTable* mTableInfo;
|
|
};
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmTextureSRTKey : public J2DAnmBase {
|
|
public:
|
|
J2DAnmTextureSRTKey() {
|
|
field_0x10 = 0;
|
|
mUpdateMaterialNum = field_0x1a = field_0x1c = field_0x1e = 0;
|
|
mInfoTable = NULL;
|
|
mScaleValues = mTranslationValues = NULL;
|
|
mRotationValues = NULL;
|
|
field_0x4e = field_0x48 = field_0x4a = field_0x4c = 0;
|
|
field_0x5c = NULL;
|
|
field_0x50 = field_0x58 = NULL;
|
|
field_0x54 = NULL;
|
|
field_0x7c = 0;
|
|
mKind = KIND_TEXTURE_SRT;
|
|
}
|
|
void calcTransform(f32, u16, J3DTextureSRTInfo*) const;
|
|
|
|
virtual ~J2DAnmTextureSRTKey() {}
|
|
virtual void searchUpdateMaterialID(J2DScreen*);
|
|
u16 getUpdateMaterialNum() const { return mUpdateMaterialNum / 3; }
|
|
u16 getUpdateMaterialID(u16 i) const {
|
|
J3D_PANIC(514, i < mUpdateMaterialNum / 3 && i >= 0, "Error : range over.");
|
|
return mUpdateMaterialID[i];
|
|
}
|
|
u8 getUpdateTexMtxID(u16 i) const {
|
|
J3D_PANIC(513, i < mUpdateMaterialNum / 3 && i >= 0, "Error : range over.");
|
|
return mUpdateTexMtxID[i];
|
|
}
|
|
void getTransform(u16 param_1, J3DTextureSRTInfo* param_2) const {
|
|
calcTransform(mFrame, param_1, param_2);
|
|
}
|
|
|
|
/* 0x10 */ int field_0x10;
|
|
/* 0x14 */ J3DAnmTransformKeyTable* mInfoTable;
|
|
/* 0x18 */ u16 mUpdateMaterialNum;
|
|
/* 0x1A */ u16 field_0x1a;
|
|
/* 0x1C */ u16 field_0x1c;
|
|
/* 0x1E */ u16 field_0x1e;
|
|
/* 0x20 */ BE(f32)* mScaleValues;
|
|
/* 0x24 */ BE(s16)* mRotationValues;
|
|
/* 0x28 */ BE(f32)* mTranslationValues;
|
|
/* 0x2C */ u8* mUpdateTexMtxID;
|
|
/* 0x30 */ BE(u16)* mUpdateMaterialID;
|
|
/* 0x34 */ JUTNameTab field_0x34;
|
|
/* 0x44 */ BE(Vec)* field_0x44;
|
|
/* 0x48 */ u16 field_0x48;
|
|
/* 0x4A */ u16 field_0x4a;
|
|
/* 0x4C */ u16 field_0x4c;
|
|
/* 0x4E */ u16 field_0x4e;
|
|
/* 0x50 */ BE(f32)* field_0x50;
|
|
/* 0x54 */ BE(s16)* field_0x54;
|
|
/* 0x58 */ BE(f32)* field_0x58;
|
|
/* 0x5C */ J3DAnmTransformKeyTable* field_0x5c;
|
|
/* 0x60 */ u8* field_0x60;
|
|
/* 0x64 */ BE(u16)* field_0x64;
|
|
/* 0x68 */ JUTNameTab field_0x68;
|
|
/* 0x78 */ BE(Vec)* field_0x78;
|
|
/* 0x7C */ int field_0x7c;
|
|
};
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmTexPattern : public J2DAnmBase {
|
|
public:
|
|
struct J2DAnmTexPatternTIMGPointer {
|
|
J2DAnmTexPatternTIMGPointer() {
|
|
mRes = NULL;
|
|
mPalette = NULL;
|
|
}
|
|
~J2DAnmTexPatternTIMGPointer() {
|
|
JKR_DELETE(mPalette);
|
|
}
|
|
|
|
/* 0x0 */ ResTIMG* mRes;
|
|
/* 0x4 */ JUTPalette* mPalette;
|
|
}; // Size: 0x8
|
|
|
|
J2DAnmTexPattern() {
|
|
mValues = NULL;
|
|
mAnmTable = NULL;
|
|
mKind = KIND_TEX_PATTERN;
|
|
mUpdateMaterialNum = 0;
|
|
mUpdateMaterialID = NULL;
|
|
mTIMGPtrArray = NULL;
|
|
}
|
|
|
|
void getTexNo(u16, u16*) const;
|
|
ResTIMG* getResTIMG(u16) const;
|
|
JUTPalette* getPalette(u16) const;
|
|
|
|
virtual ~J2DAnmTexPattern() { JKR_DELETE_ARRAY(mTIMGPtrArray); }
|
|
virtual void searchUpdateMaterialID(J2DScreen*);
|
|
u16 getUpdateMaterialNum() const { return mUpdateMaterialNum; }
|
|
u16 getUpdateMaterialID(u16 i) const {
|
|
J3D_PANIC(619, i < mUpdateMaterialNum, "Error : range over.");
|
|
return mUpdateMaterialID[i];
|
|
}
|
|
J3DAnmTexPatternFullTable* getAnmTable() const { return mAnmTable; }
|
|
|
|
/* 0x10 */ BE(u16)* mValues;
|
|
/* 0x14 */ J3DAnmTexPatternFullTable* mAnmTable;
|
|
/* 0x18 */ u16 field_0x18;
|
|
/* 0x1A */ u16 mUpdateMaterialNum;
|
|
/* 0x1C */ BE(u16)* mUpdateMaterialID;
|
|
/* 0x20 */ JUTNameTab field_0x20;
|
|
/* 0x30 */ J2DAnmTexPatternTIMGPointer* mTIMGPtrArray;
|
|
};
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmTevRegKey : public J2DAnmBase {
|
|
public:
|
|
J2DAnmTevRegKey() {
|
|
mCRegUpdateMaterialNum = mKRegUpdateMaterialNum = 0;
|
|
field_0x14 = field_0x16 = field_0x18 = field_0x1a = 0;
|
|
field_0x1c = field_0x1e = field_0x20 = field_0x22 = 0;
|
|
mCRegUpdateMaterialID = mKRegUpdateMaterialID = NULL;
|
|
mCRValues = mCGValues = mCBValues = mCAValues = NULL;
|
|
mKRValues = mKGValues = mKBValues = mKAValues = NULL;
|
|
mKind = KIND_TEV_REG;
|
|
}
|
|
void getTevColorReg(u16, GXColorS10*) const;
|
|
void getTevKonstReg(u16, GXColor*) const;
|
|
|
|
virtual ~J2DAnmTevRegKey() {}
|
|
virtual void searchUpdateMaterialID(J2DScreen* pScreen);
|
|
|
|
u16 getCRegUpdateMaterialNum() const { return mCRegUpdateMaterialNum; }
|
|
u16 getCRegUpdateMaterialID(u16 i) const {
|
|
J3D_PANIC(770, i < mCRegUpdateMaterialNum, "Error : range over.");
|
|
return mCRegUpdateMaterialID[i];
|
|
}
|
|
|
|
u16 getKRegUpdateMaterialNum() const { return mKRegUpdateMaterialNum; }
|
|
u16 getKRegUpdateMaterialID(u16 i) const {
|
|
J3D_PANIC(778, i < mKRegUpdateMaterialNum, "Error : range over.");
|
|
return mKRegUpdateMaterialID[i];
|
|
}
|
|
|
|
J3DAnmCRegKeyTable* getAnmCRegKeyTable() const { return mAnmCRegKeyTable; }
|
|
J3DAnmKRegKeyTable* getAnmKRegKeyTable() const { return mAnmKRegKeyTable; }
|
|
|
|
/* 0x10 */ u16 mCRegUpdateMaterialNum;
|
|
/* 0x12 */ u16 mKRegUpdateMaterialNum;
|
|
/* 0x14 */ u16 field_0x14;
|
|
/* 0x16 */ u16 field_0x16;
|
|
/* 0x18 */ u16 field_0x18;
|
|
/* 0x1A */ u16 field_0x1a;
|
|
/* 0x1C */ u16 field_0x1c;
|
|
/* 0x1E */ u16 field_0x1e;
|
|
/* 0x20 */ u16 field_0x20;
|
|
/* 0x22 */ u16 field_0x22;
|
|
/* 0x24 */ BE(u16)* mCRegUpdateMaterialID;
|
|
/* 0x28 */ JUTNameTab mCRegNameTab;
|
|
/* 0x38 */ BE(u16)* mKRegUpdateMaterialID;
|
|
/* 0x3C */ JUTNameTab mKRegNameTab;
|
|
/* 0x4C */ J3DAnmCRegKeyTable* mAnmCRegKeyTable;
|
|
/* 0x50 */ J3DAnmKRegKeyTable* mAnmKRegKeyTable;
|
|
/* 0x54 */ BE(s16)* mCRValues;
|
|
/* 0x58 */ BE(s16)* mCGValues;
|
|
/* 0x5C */ BE(s16)* mCBValues;
|
|
/* 0x60 */ BE(s16)* mCAValues;
|
|
/* 0x64 */ BE(s16)* mKRValues;
|
|
/* 0x68 */ BE(s16)* mKGValues;
|
|
/* 0x6C */ BE(s16)* mKBValues;
|
|
/* 0x70 */ BE(s16)* mKAValues;
|
|
};
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmColor : public J2DAnmBase {
|
|
public:
|
|
J2DAnmColor() {
|
|
field_0x10 = field_0x12 = field_0x14 = field_0x16 = 0;
|
|
mUpdateMaterialNum = 0;
|
|
mUpdateMaterialID = NULL;
|
|
mKind = KIND_COLOR;
|
|
}
|
|
virtual ~J2DAnmColor() {}
|
|
virtual void searchUpdateMaterialID(J2DScreen*);
|
|
virtual void getColor(u16, GXColor*) const {}
|
|
u16 getUpdateMaterialNum() const { return mUpdateMaterialNum; }
|
|
u16 getUpdateMaterialID(u16 i) const {
|
|
J3D_PANIC(224, i < mUpdateMaterialNum, "Error : range over.");
|
|
return mUpdateMaterialID[i];
|
|
}
|
|
|
|
/* 0x10 */ u16 field_0x10;
|
|
/* 0x12 */ u16 field_0x12;
|
|
/* 0x14 */ u16 field_0x14;
|
|
/* 0x16 */ u16 field_0x16;
|
|
/* 0x18 */ u16 mUpdateMaterialNum;
|
|
/* 0x1C */ BE(u16)* mUpdateMaterialID;
|
|
/* 0x20 */ JUTNameTab field_0x20;
|
|
}; // Size: 0x30
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmColorKey : public J2DAnmColor {
|
|
public:
|
|
J2DAnmColorKey() {
|
|
mRValues = NULL;
|
|
mGValues = NULL;
|
|
mBValues = NULL;
|
|
mAValues = NULL;
|
|
mInfoTable = NULL;
|
|
}
|
|
virtual ~J2DAnmColorKey() {}
|
|
virtual void getColor(u16, GXColor*) const;
|
|
|
|
/* 0x30 */ BE(s16)* mRValues;
|
|
/* 0x34 */ BE(s16)* mGValues;
|
|
/* 0x38 */ BE(s16)* mBValues;
|
|
/* 0x3C */ BE(s16)* mAValues;
|
|
/* 0x40 */ J3DAnmColorKeyTable* mInfoTable;
|
|
};
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
struct J2DAnmColorFullInfo {
|
|
/* 0x00 */ u16 mRMaxFrame;
|
|
/* 0x02 */ u16 mROffset;
|
|
/* 0x04 */ u16 mGMaxFrame;
|
|
/* 0x06 */ u16 mGOffset;
|
|
/* 0x08 */ u16 mBMaxFrame;
|
|
/* 0x0A */ u16 mBOffset;
|
|
/* 0x0C */ u16 mAMaxFrame;
|
|
/* 0x0E */ u16 mAOffset;
|
|
}; // Size = 0x10
|
|
|
|
/**
|
|
* @ingroup jsystem-j2d
|
|
*
|
|
*/
|
|
class J2DAnmColorFull : public J2DAnmColor {
|
|
public:
|
|
J2DAnmColorFull() {
|
|
mRValues = NULL;
|
|
mGValues = NULL;
|
|
mBValues = NULL;
|
|
mAValues = NULL;
|
|
mInfoTable = NULL;
|
|
}
|
|
virtual ~J2DAnmColorFull() {}
|
|
virtual void getColor(u16, GXColor*) const;
|
|
|
|
/* 0x30 */ u8* mRValues;
|
|
/* 0x34 */ u8* mGValues;
|
|
/* 0x38 */ u8* mBValues;
|
|
/* 0x3C */ u8* mAValues;
|
|
/* 0x40 */ J3DAnmColorFullTable* mInfoTable;
|
|
};
|
|
|
|
inline f32 J2DHermiteInterpolation(f32 f1, const BE(f32)* f2, const BE(f32)* f3, const BE(f32)* f4,
|
|
const BE(f32)* f5, const BE(f32)* f6, const BE(f32)* f7) {
|
|
return JMAHermiteInterpolation(f1, *f2, *f3, *f4, *f5, *f6, *f7);
|
|
}
|
|
|
|
inline f32 J2DHermiteInterpolation(__REGISTER f32 pp1, __REGISTER BE(s16)* pp2, __REGISTER BE(s16)* pp3,
|
|
__REGISTER BE(s16)* pp4, __REGISTER BE(s16)* pp5, __REGISTER BE(s16)* pp6,
|
|
__REGISTER BE(s16)* pp7) {
|
|
#ifdef __MWERKS__
|
|
__REGISTER f32 p1 = pp1;
|
|
__REGISTER f32 ff8;
|
|
__REGISTER f32 ff7;
|
|
__REGISTER f32 ff6;
|
|
__REGISTER f32 ff5;
|
|
__REGISTER f32 ff4;
|
|
__REGISTER f32 ff3;
|
|
__REGISTER f32 ff2;
|
|
__REGISTER f32 ff0;
|
|
__REGISTER f32 fout;
|
|
__REGISTER s16* p2 = pp2;
|
|
__REGISTER s16* p3 = pp3;
|
|
__REGISTER s16* p4 = pp4;
|
|
__REGISTER s16* p5 = pp5;
|
|
__REGISTER s16* p6 = pp6;
|
|
__REGISTER s16* p7 = pp7;
|
|
// clang-format off
|
|
asm {
|
|
psq_l ff2, 0(p2), 0x1, 5
|
|
psq_l ff0, 0(p5), 0x1, 5
|
|
psq_l ff7, 0(p3), 0x1, 5
|
|
fsubs ff5, ff0, ff2
|
|
psq_l ff6, 0(p6), 0x1, 5
|
|
fsubs ff3, p1, ff2
|
|
psq_l ff0, 0(p7), 0x1, 5
|
|
fsubs ff4, ff6, ff7
|
|
fdivs ff3, ff3, ff5
|
|
psq_l fout, 0(p4), 0x1, 5
|
|
fmadds ff0, ff0, ff5, ff7
|
|
fmuls ff2, ff3, ff3
|
|
fnmsubs ff4, ff5, fout, ff4
|
|
fsubs ff0, ff0, ff6
|
|
fsubs ff0, ff0, ff4
|
|
fmuls ff0, ff2, ff0
|
|
fmadds fout, ff5, fout, ff0
|
|
fmadds fout, fout, ff3, ff7
|
|
fmadds fout, ff4, ff2, fout
|
|
fsubs fout, fout, ff0
|
|
}
|
|
// clang-format on
|
|
return fout;
|
|
#else
|
|
f32 time1 = (f32)*pp2;
|
|
f32 value1 = (f32)*pp3;
|
|
f32 tangent1 = (f32)*pp4;
|
|
f32 time2 = (f32)*pp5;
|
|
f32 value2 = (f32)*pp6;
|
|
f32 tangent2 = (f32)*pp7;
|
|
|
|
f32 duration = time2 - time1;
|
|
f32 t = (pp1 - time1) / duration;
|
|
f32 t2 = t * t;
|
|
|
|
f32 dv = value2 - value1;
|
|
f32 ff4 = dv - duration * tangent1;
|
|
|
|
f32 ff0 = tangent2 * duration + value1;
|
|
ff0 = ff0 - value2;
|
|
ff0 = ff0 - ff4;
|
|
ff0 = t2 * ff0;
|
|
|
|
f32 fout = duration * tangent1 + ff0;
|
|
fout = fout * t + value1;
|
|
fout = ff4 * t2 + fout;
|
|
fout = fout - ff0;
|
|
|
|
return fout;
|
|
#endif
|
|
}
|
|
|
|
#endif /* J2DANIMATION_H */
|