sm64pc/lib/src/guOrthoF.c

28 lines
829 B
C
Raw Normal View History

2019-08-25 04:46:40 +00:00
#include "libultra_internal.h"
void guOrthoF(float m[4][4], float left, float right, float bottom, float top, float near, float far,
float scale) {
int row;
int col;
guMtxIdentF(m);
m[0][0] = 2 / (right - left);
m[1][1] = 2 / (top - bottom);
m[2][2] = -2 / (far - near);
m[3][0] = -(right + left) / (right - left);
m[3][1] = -(top + bottom) / (top - bottom);
m[3][2] = -(far + near) / (far - near);
m[3][3] = 1;
for (row = 0; row < 4; row++) {
2019-09-01 19:50:50 +00:00
for (col = 0; col < 4; col++) {
2019-08-25 04:46:40 +00:00
m[row][col] *= scale;
2019-09-01 19:50:50 +00:00
}
2019-08-25 04:46:40 +00:00
}
}
void guOrtho(Mtx *m, float left, float right, float bottom, float top, float near, float far,
float scale) {
float sp28[4][4];
guOrthoF(sp28, left, right, bottom, top, near, far, scale);
guMtxF2L(sp28, m);
}