1
0
Fork 0
mirror of https://github.com/zeldaret/oot.git synced 2025-01-14 20:27:13 +00:00

Match retail z_skin.c, z_skin_awb.c, z_skin_matrix.c (#1697)

* Match retail z_skin_matrix.c

* Match retail z_skin_awb.c

* Match retail z_skin.c

* Remove same-line hacks
This commit is contained in:
cadmic 2024-02-02 10:29:58 -08:00 committed by GitHub
parent f23a05eecd
commit 67d4f0f36a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 24 additions and 22 deletions

View file

@ -21,6 +21,14 @@
#define CLAMP_MAX(x, max) ((x) > (max) ? (max) : (x)) #define CLAMP_MAX(x, max) ((x) > (max) ? (max) : (x))
#define CLAMP_MIN(x, min) ((x) < (min) ? (min) : (x)) #define CLAMP_MIN(x, min) ((x) < (min) ? (min) : (x))
#define SWAP(type, a, b) \
{ \
type _temp = (a); \
(a) = (b); \
(b) = _temp; \
} \
(void)0
#define RGBA8(r, g, b, a) ((((r) & 0xFF) << 24) | (((g) & 0xFF) << 16) | (((b) & 0xFF) << 8) | (((a) & 0xFF) << 0)) #define RGBA8(r, g, b, a) ((((r) & 0xFF) << 24) | (((g) & 0xFF) << 16) | (((b) & 0xFF) << 8) | (((a) & 0xFF) << 0))
#define GET_PLAYER(play) ((Player*)(play)->actorCtx.actorLists[ACTORCAT_PLAYER].head) #define GET_PLAYER(play) ((Player*)(play)->actorCtx.actorLists[ACTORCAT_PLAYER].head)

View file

@ -7,13 +7,14 @@ static s32 sUnused;
void Skin_UpdateVertices(MtxF* mtx, SkinVertex* skinVertices, SkinLimbModif* modifEntry, Vtx* vtxBuf, Vec3f* pos) { void Skin_UpdateVertices(MtxF* mtx, SkinVertex* skinVertices, SkinLimbModif* modifEntry, Vtx* vtxBuf, Vec3f* pos) {
Vtx* vtx; Vtx* vtx;
SkinVertex* vertexEntry; SkinVertex* vertexEntry;
for (vertexEntry = skinVertices; vertexEntry < &skinVertices[modifEntry->vtxCount]; vertexEntry++) {
f32 xwTemp; f32 xwTemp;
f32 ywTemp; f32 ywTemp;
f32 zwTemp; f32 zwTemp;
Vec3f normal; Vec3f normal;
Vec3f sp64; Vec3f sp64;
for (vertexEntry = skinVertices; vertexEntry < &skinVertices[modifEntry->vtxCount]; vertexEntry++) {
vtx = &vtxBuf[vertexEntry->index]; vtx = &vtxBuf[vertexEntry->index];
vtx->n.ob[0] = pos->x; vtx->n.ob[0] = pos->x;
@ -94,12 +95,13 @@ void Skin_ApplyLimbModifications(GraphicsContext* gfxCtx, Skin* skin, s32 limbIn
SkinMatrix_Vec3fMtxFMultXYZ(&gSkinLimbMatrices[transformationEntry->limbIndex], &spA0, &vtxPoint); SkinMatrix_Vec3fMtxFMultXYZ(&gSkinLimbMatrices[transformationEntry->limbIndex], &spA0, &vtxPoint);
} else { } else {
Vec3f phi_f20; Vec3f phi_f20;
Vec3f sp88;
phi_f20.x = phi_f20.y = phi_f20.z = 0.0f; phi_f20.x = phi_f20.y = phi_f20.z = 0.0f;
for (transformationEntry = &limbTransformations[0]; for (transformationEntry = &limbTransformations[0];
transformationEntry < &limbTransformations[transformCount]; transformationEntry++) { transformationEntry < &limbTransformations[transformCount]; transformationEntry++) {
Vec3f sp88;
scale = transformationEntry->scale * 0.01f; scale = transformationEntry->scale * 0.01f;
sp88.x = transformationEntry->x; sp88.x = transformationEntry->x;
@ -191,7 +193,7 @@ void Skin_DrawImpl(Actor* actor, PlayState* play, Skin* skin, SkinPostDraw postD
s32 segmentType; s32 segmentType;
SkinLimb** skeleton; SkinLimb** skeleton;
GraphicsContext* gfxCtx = play->state.gfxCtx; GraphicsContext* gfxCtx = play->state.gfxCtx;
s32 pad; Mtx* mtx;
OPEN_DISPS(gfxCtx, "../z_skin.c", 471); OPEN_DISPS(gfxCtx, "../z_skin.c", 471);
@ -202,8 +204,6 @@ void Skin_DrawImpl(Actor* actor, PlayState* play, Skin* skin, SkinPostDraw postD
skeleton = SEGMENTED_TO_VIRTUAL(skin->skeletonHeader->segment); skeleton = SEGMENTED_TO_VIRTUAL(skin->skeletonHeader->segment);
if (!(drawFlags & SKIN_DRAW_FLAG_CUSTOM_MATRIX)) { if (!(drawFlags & SKIN_DRAW_FLAG_CUSTOM_MATRIX)) {
Mtx* mtx;
gSPMatrix(POLY_OPA_DISP++, &gMtxClear, G_MTX_NOPUSH | G_MTX_LOAD | G_MTX_MODELVIEW); gSPMatrix(POLY_OPA_DISP++, &gMtxClear, G_MTX_NOPUSH | G_MTX_LOAD | G_MTX_MODELVIEW);
mtx = SkinMatrix_MtxFToNewMtx(gfxCtx, &skin->mtx); mtx = SkinMatrix_MtxFToNewMtx(gfxCtx, &skin->mtx);

View file

@ -20,13 +20,14 @@ void Skin_InitAnimatedLimb(PlayState* play, Skin* skin, s32 limbIndex) {
modifEntry++) { modifEntry++) {
SkinVertex* skinVertices = SEGMENTED_TO_VIRTUAL(modifEntry->skinVertices); SkinVertex* skinVertices = SEGMENTED_TO_VIRTUAL(modifEntry->skinVertices);
for (skinVtxEntry = skinVertices; skinVtxEntry < &skinVertices[modifEntry->vtxCount]; skinVtxEntry++) { for (skinVtxEntry = skinVertices; skinVtxEntry < &skinVertices[modifEntry->vtxCount];) {
Vtx* vtx = &vtxBuf[skinVtxEntry->index]; Vtx* vtx = &vtxBuf[skinVtxEntry->index];
vtx->n.flag = 0; vtx->n.flag = 0;
vtx->n.tc[0] = skinVtxEntry->s; vtx->n.tc[0] = skinVtxEntry->s;
vtx->n.tc[1] = skinVtxEntry->t; vtx->n.tc[1] = skinVtxEntry->t;
vtx->n.a = skinVtxEntry->alpha; vtx->n.a = skinVtxEntry->alpha;
skinVtxEntry++;
} }
} }
} }

View file

@ -193,21 +193,21 @@ void SkinMatrix_GetClear(MtxF** mfp) {
void SkinMatrix_Clear(MtxF* mf) { void SkinMatrix_Clear(MtxF* mf) {
mf->xx = 1.0f; mf->xx = 1.0f;
mf->yy = 1.0f;
mf->zz = 1.0f;
mf->ww = 1.0f;
mf->yx = 0.0f; mf->yx = 0.0f;
mf->zx = 0.0f; mf->zx = 0.0f;
mf->wx = 0.0f; mf->wx = 0.0f;
mf->xy = 0.0f; mf->xy = 0.0f;
mf->yy = 1.0f;
mf->zy = 0.0f; mf->zy = 0.0f;
mf->wy = 0.0f; mf->wy = 0.0f;
mf->xz = 0.0f; mf->xz = 0.0f;
mf->yz = 0.0f; mf->yz = 0.0f;
mf->zz = 1.0f;
mf->wz = 0.0f; mf->wz = 0.0f;
mf->xw = 0.0f; mf->xw = 0.0f;
mf->yw = 0.0f; mf->yw = 0.0f;
mf->zw = 0.0f; mf->zw = 0.0f;
mf->ww = 1.0f;
} }
void SkinMatrix_MtxFCopy(MtxF* src, MtxF* dest) { void SkinMatrix_MtxFCopy(MtxF* src, MtxF* dest) {
@ -237,8 +237,6 @@ void SkinMatrix_MtxFCopy(MtxF* src, MtxF* dest) {
s32 SkinMatrix_Invert(MtxF* src, MtxF* dest) { s32 SkinMatrix_Invert(MtxF* src, MtxF* dest) {
MtxF mfCopy; MtxF mfCopy;
s32 i; s32 i;
s32 pad;
f32 temp2;
f32 temp1; f32 temp1;
s32 thisCol; s32 thisCol;
s32 thisRow; s32 thisRow;
@ -264,13 +262,8 @@ s32 SkinMatrix_Invert(MtxF* src, MtxF* dest) {
// Diagonal element mf[thisCol][thisCol] is zero. // Diagonal element mf[thisCol][thisCol] is zero.
// Swap the rows thisCol and thisRow. // Swap the rows thisCol and thisRow.
for (i = 0; i < 4; i++) { for (i = 0; i < 4; i++) {
temp1 = mfCopy.mf[i][thisRow]; SWAP(f32, mfCopy.mf[i][thisRow], mfCopy.mf[i][thisCol]);
mfCopy.mf[i][thisRow] = mfCopy.mf[i][thisCol]; SWAP(f32, dest->mf[i][thisRow], dest->mf[i][thisCol]);
mfCopy.mf[i][thisCol] = temp1;
temp2 = dest->mf[i][thisRow];
dest->mf[i][thisRow] = dest->mf[i][thisCol];
dest->mf[i][thisCol] = temp2;
} }
} }