2020-10-03 17:22:44 +02:00
|
|
|
#include "global.h"
|
2020-05-27 00:48:07 -07:00
|
|
|
|
|
|
|
void guOrthoF(f32 mf[4][4], f32 left, f32 right, f32 bottom, f32 top, f32 near, f32 far, f32 scale) {
|
|
|
|
s32 i, j;
|
|
|
|
|
|
|
|
guMtxIdentF(mf);
|
|
|
|
|
|
|
|
mf[0][0] = 2 / (right - left);
|
|
|
|
mf[1][1] = 2 / (top - bottom);
|
|
|
|
mf[2][2] = -2 / (far - near);
|
|
|
|
mf[3][0] = -(right + left) / (right - left);
|
|
|
|
mf[3][1] = -(top + bottom) / (top - bottom);
|
|
|
|
mf[3][2] = -(far + near) / (far - near);
|
|
|
|
mf[3][3] = 1;
|
|
|
|
|
|
|
|
for (i = 0; i < 4; i++) {
|
|
|
|
for (j = 0; j < 4; j++) {
|
|
|
|
mf[i][j] *= scale;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void guOrtho(Mtx* mtx, f32 left, f32 right, f32 bottom, f32 top, f32 near, f32 far, f32 scale) {
|
2021-02-14 00:49:40 +00:00
|
|
|
f32 mf[4][4];
|
2020-05-27 00:48:07 -07:00
|
|
|
|
|
|
|
guOrthoF(mf, left, right, bottom, top, near, far, scale);
|
|
|
|
|
2021-02-14 00:49:40 +00:00
|
|
|
guMtxF2L((MtxF*)mf, mtx);
|
2020-05-27 00:48:07 -07:00
|
|
|
}
|