cleanup
This commit is contained in:
parent
2e69d2a58a
commit
3bbd5c370b
@ -182,16 +182,13 @@ int main() {
|
|||||||
// Mesh stuff
|
// Mesh stuff
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
long t, p, OTz, OTc, Flag, nclip; // t == vertex count, p == depth cueing interpolation value, OTz == value to create Z-ordered OT, Flag == see LibOver47.pdf, p.143
|
long t, p, OTz, OTc, Flag, nclip; // t == vertex count, p == depth cueing interpolation value, OTz == value to create Z-ordered OT, Flag == see LibOver47.pdf, p.143
|
||||||
|
|
||||||
POLY_GT3 * poly;
|
POLY_GT3 * poly;
|
||||||
DIVPOLYGON3 div = { 0 };
|
|
||||||
|
|
||||||
div.pih = SCREENXRES;
|
//~ // Poly subdiv
|
||||||
div.piv = SCREENYRES;
|
//~ DIVPOLYGON3 div = { 0 };
|
||||||
|
//~ div.pih = SCREENXRES;
|
||||||
//~ MATRIX PolyMatrix = {0};
|
//~ div.piv = SCREENYRES;
|
||||||
|
|
||||||
CVECTOR outCol ={0,0,0,0};
|
CVECTOR outCol ={0,0,0,0};
|
||||||
CVECTOR outCol1 ={0,0,0,0};
|
CVECTOR outCol1 ={0,0,0,0};
|
||||||
@ -219,56 +216,36 @@ int main() {
|
|||||||
// physics
|
// physics
|
||||||
short physics = 1;
|
short physics = 1;
|
||||||
long time = 0;
|
long time = 0;
|
||||||
long sec = 0;
|
//~ long sec = 0;
|
||||||
|
|
||||||
long d1y, d2y;
|
//~ long d1y, d2y;
|
||||||
long d1x, d2x;
|
//~ long d1x, d2x;
|
||||||
long d1z, d2z;
|
//~ long d1z, d2z;
|
||||||
|
|
||||||
//~ VECTOR gForce = {0, 0, 0, 0}; // 9.81 == 4096
|
|
||||||
VECTOR gForce = {0, 981, 100, 0}; // 9.81 == 4096
|
|
||||||
|
|
||||||
//~ modelobject_body.position = modelobject_pos;
|
|
||||||
|
|
||||||
// Actor start pos
|
// Actor start pos
|
||||||
|
|
||||||
modelobject_body.position.vx = modelobject_pos.vx = 50;
|
modelobject_body.position.vx = modelobject_pos.vx = 50;
|
||||||
//~ modelobject_body.position.vz = 0;
|
|
||||||
//~ modelobject_body.position.vy = -350;
|
|
||||||
//~ modelobject_body.position.vz = modelobject_pos.vz = 664;
|
|
||||||
//~ // Cam stuff
|
|
||||||
|
|
||||||
//~ int camMode = 0;
|
// Cam stuff
|
||||||
|
|
||||||
VECTOR posToActor = {0, 0, 0, 0}; // position of camera relative to actor
|
VECTOR posToActor = {0, 0, 0, 0}; // position of camera relative to actor
|
||||||
VECTOR theta = {0, 0, 0, 0}; // rotation angles for the camera to point at actor
|
VECTOR theta = {0, 0, 0, 0}; // rotation angles for the camera to point at actor
|
||||||
|
|
||||||
int angle = 0; //PSX units = 4096 == 360° = 2Pi
|
int angle = 0; //PSX units = 4096 == 360° = 2Pi
|
||||||
//~ int endCam = 0;
|
|
||||||
int dist = 0; //PSX units
|
int dist = 0; //PSX units
|
||||||
|
|
||||||
int lerping = 0;
|
int lerping = 0;
|
||||||
|
|
||||||
// Vertex anim
|
// Vertex anim
|
||||||
|
|
||||||
//~ SVECTOR interpCache[5];
|
//~ SVECTOR interpCache[5];
|
||||||
SVECTOR a,b,c = {0,0,0,0};
|
SVECTOR a,b,c = {0,0,0,0};
|
||||||
|
|
||||||
short timediv = 1;
|
short timediv = 1;
|
||||||
|
|
||||||
int atime = 0;
|
int atime = 0;
|
||||||
|
|
||||||
|
|
||||||
//~ if(camMode == 4){
|
|
||||||
//~ camera.pos.vx = 690;
|
|
||||||
//~ camera.pos.vz = 200;
|
|
||||||
//~ camera.pos.vy = 140;
|
|
||||||
|
|
||||||
//~ camera.pos.vx += lerp(490, -50, 128);
|
|
||||||
//~ camera.pos.vz += lerp(100, 50, 128);
|
|
||||||
//~ camera.pos.vy += lerp(100, 80, 128);
|
|
||||||
|
|
||||||
//~ }
|
|
||||||
|
|
||||||
//~ modelobject_rot.vy = -1024;
|
|
||||||
|
|
||||||
for (int k = 0; k < sizeof(meshes)/sizeof(meshes[0]); k++){
|
for (int k = 0; k < sizeof(meshes)/sizeof(meshes[0]); k++){
|
||||||
triCount += meshes[k]->tmesh->len;
|
triCount += meshes[k]->tmesh->len;
|
||||||
}
|
}
|
||||||
@ -284,40 +261,27 @@ int main() {
|
|||||||
atime ++;
|
atime ++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//~ timediv = 1;
|
//~ timediv = 1;
|
||||||
|
|
||||||
|
|
||||||
//~ getCameraXZ(&camera.x, &camera.z, modelobject_pos.vx, modelobject_pos.vz, angle, dist);
|
|
||||||
|
|
||||||
//~ if (angle > 2048 || angle < -2048){
|
|
||||||
//~ angle = 0;
|
|
||||||
//~ }
|
|
||||||
//~ if (modelobject_rot.vy > 4096 || modelobject_rot.vy < -4096){
|
|
||||||
//~ modelobject_rot.vy = 0;
|
|
||||||
//~ }
|
|
||||||
|
|
||||||
long dt;
|
long dt;
|
||||||
|
|
||||||
//~ // Physics
|
//~ // Physics
|
||||||
//~ if (time%2 == 0){
|
//~ if (time%2 == 0){
|
||||||
|
|
||||||
|
|
||||||
|
// using libgte ratan (slower)
|
||||||
//~ theta.vy = -ratan2(posToActor.vx, posToActor.vz) ;
|
//~ theta.vy = -ratan2(posToActor.vx, posToActor.vz) ;
|
||||||
//~ theta.vx = 1024 - ratan2(dist, posToActor.vy);
|
//~ theta.vx = 1024 - ratan2(dist, posToActor.vy);
|
||||||
|
|
||||||
// using atantable
|
// using atantable (faster)
|
||||||
theta.vy = patan(posToActor.vx, posToActor.vz) / 16 - 1024 ;
|
theta.vy = patan(posToActor.vx, posToActor.vz) / 16 - 1024 ;
|
||||||
theta.vx = patan(dist, posToActor.vy)/16;
|
theta.vx = patan(dist, posToActor.vy)/16;
|
||||||
|
|
||||||
if(camMode != 2){
|
if(camMode != 2){
|
||||||
|
|
||||||
camera.rot.vy = theta.vy;
|
camera.rot.vy = theta.vy;
|
||||||
// using csin/ccos, no need for theta
|
// using csin/ccos, no need for theta
|
||||||
// camera.rot.vy = angle;
|
//~ camera.rot.vy = angle;
|
||||||
camera.rot.vx = theta.vx;
|
camera.rot.vx = theta.vx;
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -332,16 +296,7 @@ int main() {
|
|||||||
//~ camera.pos.vy = -(camera.y/ONE);
|
//~ camera.pos.vy = -(camera.y/ONE);
|
||||||
camera.pos.vz = -(camera.z/ONE);
|
camera.pos.vz = -(camera.z/ONE);
|
||||||
|
|
||||||
//~ modelobject_rot.vy = -1024;
|
|
||||||
|
|
||||||
// mode 0 : Camera rotates to pos with easeout
|
|
||||||
getCameraXZ(&camera.x, &camera.z, modelobject_pos.vx, modelobject_pos.vz, angle, dist);
|
getCameraXZ(&camera.x, &camera.z, modelobject_pos.vx, modelobject_pos.vz, angle, dist);
|
||||||
//~ angle += lerp(camera.rot.vy, 2088, 64);
|
|
||||||
//~ if (modelobject_rot.vy - camera.rot.vy < 4096){
|
|
||||||
//~ endCam = modelobject_rot.vy;
|
|
||||||
//~ } else {
|
|
||||||
//~ endCam = camera.rot.vy;
|
|
||||||
//~ }
|
|
||||||
|
|
||||||
angle += lerp(camera.rot.vy, modelobject_rot.vy, 128);
|
angle += lerp(camera.rot.vy, modelobject_rot.vy, 128);
|
||||||
|
|
||||||
@ -356,13 +311,14 @@ int main() {
|
|||||||
|
|
||||||
getCameraXZ(&camera.x, &camera.z, modelobject_pos.vx, modelobject_pos.vz, angle, dist);
|
getCameraXZ(&camera.x, &camera.z, modelobject_pos.vx, modelobject_pos.vz, angle, dist);
|
||||||
angle += 10;
|
angle += 10;
|
||||||
//~ angle = -modelobject_rot.vy / 2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (camMode == 3){ // mode 3 : Fixed Camera with actor tracking
|
if (camMode == 3){ // mode 3 : Fixed Camera with actor tracking
|
||||||
|
|
||||||
|
// Using libgte sqrt ( slower)
|
||||||
//~ dist = SquareRoot0( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
//~ dist = SquareRoot0( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
||||||
|
|
||||||
|
// Using precalc sqrt
|
||||||
dist = psqrt( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
dist = psqrt( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
||||||
|
|
||||||
camera.pos.vx = 290;
|
camera.pos.vx = 290;
|
||||||
@ -373,13 +329,7 @@ int main() {
|
|||||||
if (camMode == 2){ // mode 2 : Fixed Camera
|
if (camMode == 2){ // mode 2 : Fixed Camera
|
||||||
|
|
||||||
setCameraPos(camStartPos.pos, camStartPos.rot);
|
setCameraPos(camStartPos.pos, camStartPos.rot);
|
||||||
//~ camera.pos.vx = camStartPos.pos.vx;
|
|
||||||
//~ camera.pos.vy = camStartPos.pos.vy;
|
|
||||||
//~ camera.pos.vz = camStartPos.pos.vz;
|
|
||||||
|
|
||||||
|
|
||||||
//~ camera.rot.vx = camStartPos.rot.vx;
|
|
||||||
//~ camera.rot.vy = camStartPos.rot.vy;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(camMode == 4){ // Flyby mode from camStart to camEnd
|
if(camMode == 4){ // Flyby mode from camStart to camEnd
|
||||||
@ -393,10 +343,6 @@ int main() {
|
|||||||
|
|
||||||
lerping = 1;
|
lerping = 1;
|
||||||
}
|
}
|
||||||
// Find distance between cam and actor
|
|
||||||
|
|
||||||
// Psyq sqrt func
|
|
||||||
//~ dist = SquareRoot0( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
|
||||||
|
|
||||||
// Pre calculated sqrt ( see psqrt() )
|
// Pre calculated sqrt ( see psqrt() )
|
||||||
dist = psqrt( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
dist = psqrt( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
||||||
@ -405,6 +351,7 @@ int main() {
|
|||||||
short s = camPath.points[camPath.cursor+1].vy - camera.pos.vy;
|
short s = camPath.points[camPath.cursor+1].vy - camera.pos.vy;
|
||||||
short t = camPath.points[camPath.cursor+1].vz - camera.pos.vz;
|
short t = camPath.points[camPath.cursor+1].vz - camera.pos.vz;
|
||||||
|
|
||||||
|
// FIXME : the lerp function is incorrect
|
||||||
//~ camera.pos.vx += lerp(camPath.points[camPath.cursor].vx, camPath.points[camPath.cursor+1].vx, 64);
|
//~ camera.pos.vx += lerp(camPath.points[camPath.cursor].vx, camPath.points[camPath.cursor+1].vx, 64);
|
||||||
//~ camera.pos.vy += lerp(camPath.points[camPath.cursor].vy, camPath.points[camPath.cursor+1].vy, 64);
|
//~ camera.pos.vy += lerp(camPath.points[camPath.cursor].vy, camPath.points[camPath.cursor+1].vy, 64);
|
||||||
//~ camera.pos.vz += lerp(camPath.points[camPath.cursor].vz, camPath.points[camPath.cursor+1].vz, 64);
|
//~ camera.pos.vz += lerp(camPath.points[camPath.cursor].vz, camPath.points[camPath.cursor+1].vz, 64);
|
||||||
@ -419,6 +366,7 @@ int main() {
|
|||||||
//~ camera.pos.vz <= camPath.points[camPath.cursor+1].vz){
|
//~ camera.pos.vz <= camPath.points[camPath.cursor+1].vz){
|
||||||
//~ camPath.cursor ++;
|
//~ camPath.cursor ++;
|
||||||
//~ }
|
//~ }
|
||||||
|
|
||||||
if ( camera.pos.vx + r == camPath.points[camPath.cursor+1].vx &&
|
if ( camera.pos.vx + r == camPath.points[camPath.cursor+1].vx &&
|
||||||
camera.pos.vy + s == camPath.points[camPath.cursor+1].vy &&
|
camera.pos.vy + s == camPath.points[camPath.cursor+1].vy &&
|
||||||
camera.pos.vz + t == camPath.points[camPath.cursor+1].vz){
|
camera.pos.vz + t == camPath.points[camPath.cursor+1].vz){
|
||||||
@ -434,16 +382,6 @@ int main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Testing stuff
|
|
||||||
|
|
||||||
//~ if (modelobject_rot.vy < 2048 || modelobject_rot.vy > -2048){
|
|
||||||
//~ if (time % 240 == 0){
|
|
||||||
//~ modelobject_rot.vy += 1024 ;
|
|
||||||
//~ }
|
|
||||||
//~ modelobject_body.position.vx ++;
|
|
||||||
//~ dist += 10;
|
|
||||||
|
|
||||||
|
|
||||||
//~ dt = time/180+1 - time/180;
|
//~ dt = time/180+1 - time/180;
|
||||||
if (physics){
|
if (physics){
|
||||||
if(time%2 == 0){
|
if(time%2 == 0){
|
||||||
@ -451,100 +389,51 @@ int main() {
|
|||||||
|
|
||||||
if ( *meshes[k]->isRigidBody == 1 ) {
|
if ( *meshes[k]->isRigidBody == 1 ) {
|
||||||
|
|
||||||
//~ dt = 1;
|
|
||||||
|
|
||||||
//~ VECTOR acceleration = {meshes[k]->body->gForce.vx / meshes[k]->body->mass, meshes[k]->body->gForce.vy / meshes[k]->body->mass, meshes[k]->body->gForce.vz / meshes[k]->body->mass};
|
|
||||||
|
|
||||||
//~ meshes[k]->body->velocity.vx += acceleration.vx * dt;
|
|
||||||
//~ meshes[k]->body->velocity.vy += acceleration.vy * dt;
|
|
||||||
//~ meshes[k]->body->velocity.vz += acceleration.vz * dt;
|
|
||||||
|
|
||||||
//~ meshes[k]->body->position.vx += meshes[k]->body->velocity.vx * dt;
|
|
||||||
//~ meshes[k]->body->position.vy += meshes[k]->body->velocity.vy * dt;
|
|
||||||
//~ meshes[k]->body->position.vz += meshes[k]->body->velocity.vz * dt;
|
|
||||||
|
|
||||||
//~ d1x = (meshes[k]->body->position.vx - meshes[k]->body->max.vx) - (modelgnd_body.position.vx + modelgnd_body.min.vx);
|
|
||||||
//~ d1y = (meshes[k]->body->position.vy - meshes[k]->body->min.vy) - (modelgnd_body.position.vy + modelgnd_body.min.vy);
|
|
||||||
//~ d1z = (meshes[k]->body->position.vz - meshes[k]->body->max.vz) - (modelgnd_body.position.vz + modelgnd_body.min.vz);
|
|
||||||
|
|
||||||
//~ d2x = (modelgnd_body.position.vx + modelgnd_body.max.vx) - (meshes[k]->body->position.vx + meshes[k]->body->max.vx);
|
|
||||||
//~ d2y = (modelgnd_body.position.vy + modelgnd_body.max.vy) - (meshes[k]->body->position.vy + meshes[k]->body->max.vy);
|
|
||||||
//~ d2z = (modelgnd_body.position.vz + modelgnd_body.max.vz) - (meshes[k]->body->position.vz + meshes[k]->body->max.vz);
|
|
||||||
applyAcceleration(meshes[k]->body);
|
applyAcceleration(meshes[k]->body);
|
||||||
|
|
||||||
VECTOR col;
|
VECTOR col;
|
||||||
|
|
||||||
|
// Get col with level ( modelgnd_body )
|
||||||
col = getCollision( *meshes[k]->body , modelgnd_body);
|
col = getCollision( *meshes[k]->body , modelgnd_body);
|
||||||
|
|
||||||
//~ if (d1x >= 0 || d2x >= 0){//Touching}
|
// If !col, keep moving
|
||||||
//~ if (d1z >= 0 || d2z >= 0){//Touching}
|
|
||||||
//~ if (d1y >= 0 || d2y >= 0){//Touching}
|
|
||||||
|
|
||||||
//~ if (d1x >= 0 && d2x >= 0){
|
if ( !col.vx ){ meshes[k]->pos->vx = meshes[k]->body->position.vx; }
|
||||||
if (col.vx){
|
|
||||||
|
|
||||||
meshes[k]->pos->vx = meshes[k]->body->position.vx;
|
if ( !col.vy ){ meshes[k]->pos->vy = meshes[k]->body->position.vy + 15; } // FIXME : Why the 15px offset ?
|
||||||
//~ modelobject_pos.vx = modelobject_body.position.vx;
|
|
||||||
}
|
|
||||||
|
|
||||||
//~ if (d1y >= 0 && d2y >= 0){
|
if ( !col.vz ){ meshes[k]->pos->vz = meshes[k]->body->position.vz; }
|
||||||
if (col.vy){
|
|
||||||
|
|
||||||
meshes[k]->pos->vy = meshes[k]->body->position.vy + 15;
|
// If col with wall, change direction
|
||||||
//modelobject_pos.vy = modelobject_body.position.vy;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (col.vz){
|
if ( col.vx ) { meshes[k]->body->gForce.vx *= -1; }
|
||||||
|
|
||||||
meshes[k]->pos->vz = meshes[k]->body->position.vz;
|
if ( col.vy ) { meshes[k]->body->gForce.vy *= -1; }
|
||||||
//~ modelobject_pos.vz = meshes[k]->body->position.vz;
|
|
||||||
//~ modelobject_pos.vz = modelobject_body.position.vz;
|
|
||||||
}
|
|
||||||
|
|
||||||
//~ if ( d1x < 0 || d2x < 0 ) { gForce.vx *= -1; }
|
if ( col.vz ) { meshes[k]->body->gForce.vz *= -1; }
|
||||||
|
|
||||||
//~ if ( d1y < 0 || d2y < 0 ) { gForce.vy *= -1; }
|
// If col, reset velocity
|
||||||
|
|
||||||
//~ if ( d1z < 0 || d2z < 0 ) { gForce.vz *= -1; }
|
if ( col.vx ||
|
||||||
|
col.vy ||
|
||||||
if ( !(col.vx) ) { meshes[k]->body->gForce.vx *= -1; }
|
col.vz
|
||||||
|
|
||||||
if ( !(col.vy) ) { meshes[k]->body->gForce.vy *= -1; }
|
|
||||||
|
|
||||||
if ( !(col.vz) ) { meshes[k]->body->gForce.vz *= -1; }
|
|
||||||
|
|
||||||
//~ if ( d1y < 0 || d2y < 0 ||
|
|
||||||
//~ d1z < 0 || d2z < 0 ||
|
|
||||||
//~ d1x < 0 || d2x < 0 ) {
|
|
||||||
|
|
||||||
if ( !(col.vx) ||
|
|
||||||
!(col.vy) ||
|
|
||||||
!(col.vz)
|
|
||||||
) {
|
) {
|
||||||
meshes[k]->body->velocity.vy = meshes[k]->body->velocity.vx = meshes[k]->body->velocity.vz = 0;
|
meshes[k]->body->velocity.vy = meshes[k]->body->velocity.vx = meshes[k]->body->velocity.vz = 0;
|
||||||
//~ meshes[k]->pos->vy = meshes[k]->body->position.vy = -40 ;
|
|
||||||
//~ modelobject_pos.vy = meshes[k]->body->position.vy = 96;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//~ d1y = d2y = d1x = d2x = d1z = d2z = 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Camera setup
|
// Camera setup
|
||||||
|
|
||||||
//~ camera.pos.vx = -(camera.x/ONE);
|
|
||||||
//~ camera.pos.vy = -(camera.y/ONE);
|
|
||||||
//~ camera.pos.vz = -(camera.z/ONE);
|
|
||||||
|
|
||||||
// position of cam relative to actor
|
// position of cam relative to actor
|
||||||
//~ if (DposToActor.vx - posToActor.vx || DposToActor.vy - posToActor.vy || DposToActor.vz - posToActor.vz ){
|
|
||||||
posToActor.vx = modelobject_pos.vx + camera.pos.vx;
|
posToActor.vx = modelobject_pos.vx + camera.pos.vx;
|
||||||
posToActor.vz = modelobject_pos.vz + camera.pos.vz;
|
posToActor.vz = modelobject_pos.vz + camera.pos.vz;
|
||||||
posToActor.vy = modelobject_pos.vy + camera.pos.vy;
|
posToActor.vy = modelobject_pos.vy + camera.pos.vy;
|
||||||
|
|
||||||
//~ DposToActor = posToActor;
|
|
||||||
//~ };
|
|
||||||
// find dist between actor and cam
|
// find dist between actor and cam
|
||||||
//~ dist = csqrt((posToActor.vx * posToActor.vx * 4096) + (posToActor.vz * posToActor.vz * 4096));
|
//~ dist = csqrt((posToActor.vx * posToActor.vx * 4096) + (posToActor.vz * posToActor.vz * 4096));
|
||||||
//~ dist = SquareRoot0( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
//~ dist = SquareRoot0( (posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz) );
|
||||||
@ -570,14 +459,16 @@ int main() {
|
|||||||
// Render the sample vector model
|
// Render the sample vector model
|
||||||
t=0;
|
t=0;
|
||||||
|
|
||||||
|
// If rigidbdy, apply rot/transform matrix
|
||||||
if (*meshes[k]->isRigidBody){
|
if (*meshes[k]->isRigidBody){
|
||||||
|
|
||||||
//~ PushMatrix(); // Push current matrix on the stack
|
//~ PushMatrix(); // Push current matrix on the stack (real slow -> dma transfer )
|
||||||
//~ SetColorMatrix(&camera.mat);
|
|
||||||
|
|
||||||
RotMatrix_gte(meshes[k]->rot, meshes[k]->mat); // Apply rotation matrix
|
RotMatrix_gte(meshes[k]->rot, meshes[k]->mat); // Apply rotation matrix
|
||||||
|
|
||||||
TransMatrix(meshes[k]->mat, meshes[k]->pos); // Apply translation matrix
|
TransMatrix(meshes[k]->mat, meshes[k]->pos); // Apply translation matrix
|
||||||
|
|
||||||
|
//~ MulMatrix0(&camera.mat, meshes[k]->mat, meshes[k]->mat);
|
||||||
CompMatrix(&camera.mat, meshes[k]->mat, meshes[k]->mat); // Was using &PolyMatrix instead of meshes[k]->mat
|
CompMatrix(&camera.mat, meshes[k]->mat, meshes[k]->mat); // Was using &PolyMatrix instead of meshes[k]->mat
|
||||||
|
|
||||||
SetRotMatrix(meshes[k]->mat); // Set default rotation matrix - Was using &PolyMatrix instead of meshes[k]->mat
|
SetRotMatrix(meshes[k]->mat); // Set default rotation matrix - Was using &PolyMatrix instead of meshes[k]->mat
|
||||||
@ -598,11 +489,14 @@ int main() {
|
|||||||
//~ RotMeshPrimS_GCT3();
|
//~ RotMeshPrimS_GCT3();
|
||||||
|
|
||||||
if (*meshes[k]->isPrism){
|
if (*meshes[k]->isPrism){
|
||||||
|
|
||||||
|
// Use current DRAWENV clip as TPAGE
|
||||||
((POLY_GT3 *)poly)->tpage = getTPage(meshes[k]->tim->mode&0x3, 0,
|
((POLY_GT3 *)poly)->tpage = getTPage(meshes[k]->tim->mode&0x3, 0,
|
||||||
draw[!db].clip.x,
|
draw[db].clip.x,
|
||||||
draw[!db].clip.y
|
draw[db].clip.y
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Use projected coordinates (results from RotAverage...) as UV coords and clamp them to 0-255,0-224
|
||||||
setUV3(poly, (poly->x0 < 0? 0 : poly->x0 > 255? 255 : poly->x0),
|
setUV3(poly, (poly->x0 < 0? 0 : poly->x0 > 255? 255 : poly->x0),
|
||||||
(poly->y0 < 0? 0 : poly->y0 > 224? 224 : poly->y0),
|
(poly->y0 < 0? 0 : poly->y0 > 224? 224 : poly->y0),
|
||||||
(poly->x1 < 0? 0 : poly->x1 > 255? 255 : poly->x1),
|
(poly->x1 < 0? 0 : poly->x1 > 255? 255 : poly->x1),
|
||||||
@ -612,42 +506,26 @@ int main() {
|
|||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
// Use regular TPAGE
|
||||||
((POLY_GT3 *)poly)->tpage = getTPage(meshes[k]->tim->mode&0x3, 0,
|
((POLY_GT3 *)poly)->tpage = getTPage(meshes[k]->tim->mode&0x3, 0,
|
||||||
meshes[k]->tim->prect->x,
|
meshes[k]->tim->prect->x,
|
||||||
meshes[k]->tim->prect->y
|
meshes[k]->tim->prect->y
|
||||||
);
|
);
|
||||||
|
|
||||||
|
// Use model UV coordinates
|
||||||
setUV3(poly, meshes[k]->tmesh->u[i].vx , meshes[k]->tmesh->u[i].vy + meshes[k]->tim->prect->y,
|
setUV3(poly, meshes[k]->tmesh->u[i].vx , meshes[k]->tmesh->u[i].vy + meshes[k]->tim->prect->y,
|
||||||
meshes[k]->tmesh->u[i+1].vx, meshes[k]->tmesh->u[i+1].vy + meshes[k]->tim->prect->y,
|
meshes[k]->tmesh->u[i+1].vx, meshes[k]->tmesh->u[i+1].vy + meshes[k]->tim->prect->y,
|
||||||
meshes[k]->tmesh->u[i+2].vx, meshes[k]->tmesh->u[i+2].vy + meshes[k]->tim->prect->y);
|
meshes[k]->tmesh->u[i+2].vx, meshes[k]->tmesh->u[i+2].vy + meshes[k]->tim->prect->y);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
//~ setUV3(0, 0, 32, 0, 32, 32);
|
|
||||||
|
|
||||||
//~ setUV3(poly, meshes[k]->tmesh->u[i].vx , meshes[k]->tmesh->u[i].vy + meshes[k]->tim->prect->y,
|
|
||||||
//~ meshes[k]->tmesh->u[i+1].vx, meshes[k]->tmesh->u[i+1].vy + meshes[k]->tim->prect->y,
|
|
||||||
//~ meshes[k]->tmesh->u[i+2].vx, meshes[k]->tmesh->u[i+2].vy + meshes[k]->tim->prect->y);
|
|
||||||
|
|
||||||
|
|
||||||
// Rotate, translate, and project the vectors and output the results into a primitive
|
|
||||||
|
|
||||||
//~ OTz = RotTransPers(&meshes[k]->tmesh->v[meshes[k]->index[t]] , (long*)&poly->x0, meshes[k]->p, &Flag);
|
|
||||||
//~ OTz += RotTransPers(&meshes[k]->tmesh->v[meshes[k]->index[t+1]], (long*)&poly->x1, meshes[k]->p, &Flag);
|
|
||||||
//~ OTz += RotTransPers(&meshes[k]->tmesh->v[meshes[k]->index[t+2]], (long*)&poly->x2, meshes[k]->p, &Flag);
|
|
||||||
|
|
||||||
//~ for (int i = 0; i < 1; i++ ){
|
|
||||||
//~ for (int j = 0; j < modelCylindre_anim.nvert; j++){
|
|
||||||
//~ FntPrint("%d - ",modelCylindre_anim.data[i * modelCylindre_anim.nvert + j].vx);
|
|
||||||
//~ }
|
|
||||||
//~ }
|
|
||||||
|
|
||||||
|
// If Vertex Anim flag
|
||||||
if (*meshes[k]->isAnim){
|
if (*meshes[k]->isAnim){
|
||||||
|
|
||||||
|
// FIXME : SLERP VERTEX ANIM
|
||||||
|
|
||||||
//~ SVECTOR a,b,c = {0,0,0,0};
|
//~ SVECTOR a,b,c = {0,0,0,0};
|
||||||
|
|
||||||
@ -692,11 +570,15 @@ int main() {
|
|||||||
|
|
||||||
//~ FntPrint("%d %d %d\n", a.vx, b.vx, c.vx);
|
//~ FntPrint("%d %d %d\n", a.vx, b.vx, c.vx);
|
||||||
|
|
||||||
// TODO: export normals too
|
// Rotate, translate, and project the vectors and output the results into a primitive
|
||||||
|
|
||||||
|
//~ OTz = RotTransPers(&meshes[k]->tmesh->v[meshes[k]->index[t]] , (long*)&poly->x0, meshes[k]->p, &Flag);
|
||||||
|
//~ OTz += RotTransPers(&meshes[k]->tmesh->v[meshes[k]->index[t+1]], (long*)&poly->x1, meshes[k]->p, &Flag);
|
||||||
|
//~ OTz += RotTransPers(&meshes[k]->tmesh->v[meshes[k]->index[t+2]], (long*)&poly->x2, meshes[k]->p, &Flag);
|
||||||
|
|
||||||
|
// Use anim vertex's positions
|
||||||
|
|
||||||
OTz = RotAverage3(
|
OTz = RotAverage3(
|
||||||
//~ &a,&b,&c,
|
|
||||||
&meshes[k]->anim->data[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t]],
|
&meshes[k]->anim->data[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t]],
|
||||||
&meshes[k]->anim->data[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t+1]],
|
&meshes[k]->anim->data[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t+1]],
|
||||||
&meshes[k]->anim->data[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t+2]],
|
&meshes[k]->anim->data[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t+2]],
|
||||||
@ -708,6 +590,7 @@ int main() {
|
|||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
// Use model's regular vertex pos
|
||||||
OTz = RotAverage3(
|
OTz = RotAverage3(
|
||||||
&meshes[k]->tmesh->v[meshes[k]->index[t]],
|
&meshes[k]->tmesh->v[meshes[k]->index[t]],
|
||||||
&meshes[k]->tmesh->v[meshes[k]->index[t+1]],
|
&meshes[k]->tmesh->v[meshes[k]->index[t+1]],
|
||||||
@ -717,6 +600,9 @@ int main() {
|
|||||||
&Flag
|
&Flag
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// FIXME : Polygon subdiv
|
||||||
|
|
||||||
//~ OTc = OTz>>4;
|
//~ OTc = OTz>>4;
|
||||||
|
|
||||||
//~ if (OTc < 15) {
|
//~ if (OTc < 15) {
|
||||||
@ -749,31 +635,10 @@ int main() {
|
|||||||
|
|
||||||
//~ }
|
//~ }
|
||||||
|
|
||||||
// Light source stages
|
|
||||||
// 1 . Normal vector N (meshes[k]->tmesh->n) x World matrix ( meshes[k]->mat ) => vector(NW)
|
|
||||||
// 2 . Light source vector (light->dir) x Normal World coords NW => vector(L)
|
|
||||||
// 3 . Light source effect L x Light source color (light->color) => vector(LI)
|
|
||||||
// 4 . LI + BK = LT
|
|
||||||
// 5 . Vertex color ( &meshes[k]->tmesh->c[i] ) * LT
|
|
||||||
|
|
||||||
// Stages 1,2,3 : L = OuterProduct0( (VECTOR)light->dir, ApplyMatrix( (MATRIX)meshes[k]->mat, (VECTOR)meshes[k]->tmesh->n[] ) )
|
|
||||||
//
|
|
||||||
// Lij = ApplyMatrix( (MATRIX)meshes[k]->mat, (VECTOR)light->dir)
|
|
||||||
// SetLocalLightMatrix(Lij)
|
|
||||||
// L = ApplyMatrix( Lij, (VECTOR)meshes[k]->tmesh->n[] )
|
|
||||||
//~ // NormalColorDpq3()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Interpolate a primary color vector and far color
|
// Interpolate a primary color vector and far color
|
||||||
|
|
||||||
//~ NormalColorDpq3(&meshes[k]->tmesh->n[i],
|
// If vertex anim has updated normals
|
||||||
//~ &meshes[k]->tmesh->n[i+1],
|
|
||||||
//~ &meshes[k]->tmesh->n[i+2],
|
|
||||||
//~ &meshes[k]->tmesh->c[i],
|
|
||||||
//~ *meshes[k]->p,
|
|
||||||
//~ &outCol,&outCol1,&outCol2
|
|
||||||
//~ );
|
|
||||||
//~ if (*meshes[k]->isAnim){
|
//~ if (*meshes[k]->isAnim){
|
||||||
//~ NormalColorDpq(&meshes[k]->anim->normals[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t]], &meshes[k]->tmesh->c[meshes[k]->index[t]], *meshes[k]->p, &outCol);
|
//~ NormalColorDpq(&meshes[k]->anim->normals[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t]], &meshes[k]->tmesh->c[meshes[k]->index[t]], *meshes[k]->p, &outCol);
|
||||||
//~ NormalColorDpq(&meshes[k]->anim->normals[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t+1]], &meshes[k]->tmesh->c[meshes[k]->index[t+1]], *meshes[k]->p, &outCol1);
|
//~ NormalColorDpq(&meshes[k]->anim->normals[ atime%19 * modelCylindre_anim.nvert + meshes[k]->index[t+1]], &meshes[k]->tmesh->c[meshes[k]->index[t+1]], *meshes[k]->p, &outCol1);
|
||||||
@ -785,14 +650,26 @@ int main() {
|
|||||||
NormalColorDpq(&meshes[k]->tmesh->n[meshes[k]->index[t+2]], &meshes[k]->tmesh->c[meshes[k]->index[t+2]], *meshes[k]->p, &outCol2);
|
NormalColorDpq(&meshes[k]->tmesh->n[meshes[k]->index[t+2]], &meshes[k]->tmesh->c[meshes[k]->index[t+2]], *meshes[k]->p, &outCol2);
|
||||||
//~ }
|
//~ }
|
||||||
|
|
||||||
|
// Other methods
|
||||||
|
|
||||||
|
//~ NormalColorDpq3(&meshes[k]->tmesh->n[i],
|
||||||
|
//~ &meshes[k]->tmesh->n[i+1],
|
||||||
|
//~ &meshes[k]->tmesh->n[i+2],
|
||||||
|
//~ &meshes[k]->tmesh->c[i],
|
||||||
|
//~ *meshes[k]->p,
|
||||||
|
//~ &outCol,&outCol1,&outCol2
|
||||||
|
//~ );
|
||||||
|
|
||||||
//~ DpqColor3(&meshes[k]->tmesh->c[i],
|
//~ DpqColor3(&meshes[k]->tmesh->c[i],
|
||||||
//~ &meshes[k]->tmesh->c[i+1],
|
//~ &meshes[k]->tmesh->c[i+1],
|
||||||
//~ &meshes[k]->tmesh->c[i+2],
|
//~ &meshes[k]->tmesh->c[i+2],
|
||||||
//~ *meshes[k]->p,
|
//~ *meshes[k]->p,
|
||||||
//~ &outCol,&outCol1,&outCol2
|
//~ &outCol,&outCol1,&outCol2
|
||||||
//~ );
|
//~ );
|
||||||
|
|
||||||
if (*meshes[k]->isPrism){
|
if (*meshes[k]->isPrism){
|
||||||
|
|
||||||
|
// Use un-interpolated (i.e: no light, no fog) colors
|
||||||
setRGB0(poly, meshes[k]->tmesh->c[i].r, meshes[k]->tmesh->c[i+1].g, meshes[k]->tmesh->c[i+2].b);
|
setRGB0(poly, meshes[k]->tmesh->c[i].r, meshes[k]->tmesh->c[i+1].g, meshes[k]->tmesh->c[i+2].b);
|
||||||
setRGB1(poly, meshes[k]->tmesh->c[i+1].r, meshes[k]->tmesh->c[i+1].g, meshes[k]->tmesh->c[i+1].b);
|
setRGB1(poly, meshes[k]->tmesh->c[i+1].r, meshes[k]->tmesh->c[i+1].g, meshes[k]->tmesh->c[i+1].b);
|
||||||
setRGB2(poly, meshes[k]->tmesh->c[i+2].r, meshes[k]->tmesh->c[i+2].g, meshes[k]->tmesh->c[i+2].b);
|
setRGB2(poly, meshes[k]->tmesh->c[i+2].r, meshes[k]->tmesh->c[i+2].g, meshes[k]->tmesh->c[i+2].b);
|
||||||
@ -810,6 +687,7 @@ int main() {
|
|||||||
|
|
||||||
// Sort the primitive into the OT
|
// Sort the primitive into the OT
|
||||||
//~ OTz /= 3;
|
//~ OTz /= 3;
|
||||||
|
|
||||||
// cliptest3((short *)&meshes[k]->tmesh->v[meshes[k]->index[t]])
|
// cliptest3((short *)&meshes[k]->tmesh->v[meshes[k]->index[t]])
|
||||||
|
|
||||||
//~ if ((OTz > 0) && (OTz < OTLEN) && (*meshes[k]->p < 2048)){
|
//~ if ((OTz > 0) && (OTz < OTLEN) && (*meshes[k]->p < 2048)){
|
||||||
@ -820,31 +698,21 @@ int main() {
|
|||||||
t+=3;
|
t+=3;
|
||||||
|
|
||||||
//~ if (*meshes[k]->isRigidBody){
|
//~ if (*meshes[k]->isRigidBody){
|
||||||
//~ PopMatrix(); // Pull previous matrix from stack
|
//~ PopMatrix(); // Pull previous matrix from stack (slow)
|
||||||
//~ }
|
//~ }
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Find and apply light rotation matrix
|
||||||
RotMatrix(&lgtang, &rotlgt);
|
RotMatrix(&lgtang, &rotlgt);
|
||||||
// MulMatrix(&rotlgt, &rottrans);
|
|
||||||
MulMatrix0(&lgtmat, &rotlgt, &light);
|
MulMatrix0(&lgtmat, &rotlgt, &light);
|
||||||
SetLightMatrix(&light);
|
SetLightMatrix(&light);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//~ if (*meshes[k]->isRigidBody){
|
|
||||||
|
|
||||||
//~ SetRotMatrix(&camera.mat);
|
|
||||||
//~ SetTransMatrix(&camera.mat);
|
|
||||||
//~ }
|
|
||||||
applyCamera(&camera);
|
applyCamera(&camera);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//~ applyCamera(&camera);
|
|
||||||
|
|
||||||
FntPrint("Time : %d %d dt :%d\n",time, atime, dt);
|
FntPrint("Time : %d %d dt :%d\n",time, atime, dt);
|
||||||
FntPrint("Tricount: %d OTz: %d\nOTc: %d, p: %d\n",triCount, OTz, OTc, *meshes[2]->p);
|
FntPrint("Tricount: %d OTz: %d\nOTc: %d, p: %d\n",triCount, OTz, OTc, *meshes[2]->p);
|
||||||
|
|
||||||
@ -854,51 +722,6 @@ int main() {
|
|||||||
FntPrint("L2: %d %d %d\n", light.m[1][0],light.m[1][1],light.m[1][2]);
|
FntPrint("L2: %d %d %d\n", light.m[1][0],light.m[1][1],light.m[1][2]);
|
||||||
FntPrint("L3: %d %d %d\n", light.m[2][0],light.m[2][1],light.m[2][2]);
|
FntPrint("L3: %d %d %d\n", light.m[2][0],light.m[2][1],light.m[2][2]);
|
||||||
|
|
||||||
//~ FntPrint("Ligt angle = %d,%d,%d\n", lgtang.vx, lgtang.vy, lgtang.vz);
|
|
||||||
//~ FntPrint("NW : %d %d %d", NW.vx, NW.vy, NW.vz);
|
|
||||||
|
|
||||||
//~ FntPrint("Lerping : %d - %d\n", lerping, camPath.cursor);
|
|
||||||
|
|
||||||
//~ FntPrint("Cam x: %d, %d\n", camera.pos.vx , camPath.points[1].vx);
|
|
||||||
//~ FntPrint("Cam y: %d, %d\n", camera.pos.vy , camPath.points[1].vy);
|
|
||||||
//~ FntPrint("Cam z: %d, %d\n", camera.pos.vz , camPath.points[1].vz);
|
|
||||||
|
|
||||||
//~ FntPrint("%d %d \n", (meshes[2]->body->position.vy + meshes[2]->body->min.vz) , (modelgnd_body.position.vz + modelgnd_body.min.vz));
|
|
||||||
//~ FntPrint("%d \n", (meshes[2]->body->position.vz + meshes[2]->body->min.vz) - (modelgnd_body.position.vz + modelgnd_body.min.vz));
|
|
||||||
|
|
||||||
//~ FntPrint("%d %d \n", (meshes[2]->body->position.vz + meshes[2]->body->max.vz) , (modelgnd_body.position.vz + modelgnd_body.max.vz));
|
|
||||||
//~ FntPrint("%d", (modelgnd_body.position.vz + modelgnd_body.max.vz) - (meshes[2]->body->position.vz + meshes[2]->body->max.vz));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//~ for (int i = 0; i < modelCylindre_anim.nframes; i++ ){
|
|
||||||
//~ for (int i = 0; i < 1; i++ ){
|
|
||||||
//~ for (int j = 0; j < modelCylindre_anim.nvert; j++){
|
|
||||||
//~ FntPrint("%d - ",modelCylindre_anim.data[i * modelCylindre_anim.nvert + j].vx);
|
|
||||||
//~ }
|
|
||||||
//~ }
|
|
||||||
|
|
||||||
//~ FntPrint("%d",modelCylindre_anim.data[2 * modelCylindre_anim.nvert + 0].vx);
|
|
||||||
//~ FntPrint("Act pos: %d, %d,%d\n", modelobject_pos.vx, modelobject_pos.vz, modelobject_pos.vy);
|
|
||||||
//~ // Camera
|
|
||||||
//~ FntPrint("Angle : %d\nDist : %d\n", angle, dist);
|
|
||||||
|
|
||||||
//~ FntPrint("Dist : %d\n", psqrt((posToActor.vx * posToActor.vx ) + (posToActor.vz * posToActor.vz)));
|
|
||||||
//~ FntPrint("Cam pos: %d, %d, %d\n", camera.pos.vx, camera.pos.vz, camera.pos.vy);
|
|
||||||
//~ FntPrint("CamRot : %d \n", camera.rot.vy);
|
|
||||||
//~ FntPrint("Act Rot: %d\n", modelobject_rot.vy);
|
|
||||||
//~ FntPrint("LookAt x: %d\n z: %d\n", posToActor.vx, posToActor.vz);
|
|
||||||
//~ FntPrint("Theta y: %d x: %d\n", theta.vy, theta.vx);
|
|
||||||
//~ FntPrint("ThetaD %d\n", modelobject_rot.vy - camera.rot.vy);
|
|
||||||
//~ FntPrint("Nsin : %d, Ncos: %d\n", nsin(angle), ncos(angle));
|
|
||||||
|
|
||||||
// Physics
|
|
||||||
//~ FntPrint("d1 : %d, %d, %d\n", d1x, d1z, d1y);
|
|
||||||
//~ FntPrint("d2 : %d, %d, %d\n", d2x, d2z, d2y);
|
|
||||||
|
|
||||||
//~ FntPrint("Lerp : %d\n", lerp(490, -50, 160));
|
|
||||||
//~ FntPrint("CamMode : %d %d\n", camMode, pressed);
|
|
||||||
//~ FntPrint("short %d", sizeof(short));
|
|
||||||
FntFlush(-1);
|
FntFlush(-1);
|
||||||
|
|
||||||
display();
|
display();
|
||||||
@ -1062,10 +885,9 @@ VECTOR getCollision(BODY one, BODY two){
|
|||||||
d2.vy = (two.position.vy + two.max.vy) - (one.position.vy + one.max.vy);
|
d2.vy = (two.position.vy + two.max.vy) - (one.position.vy + one.max.vy);
|
||||||
d2.vz = (two.position.vz + two.max.vz) - (one.position.vz + one.max.vz);
|
d2.vz = (two.position.vz + two.max.vz) - (one.position.vz + one.max.vz);
|
||||||
|
|
||||||
|
col.vx = !(d1.vx >= 0 && d2.vx >= 0);
|
||||||
col.vx = d1.vx >= 0 && d2.vx >= 0;
|
col.vy = !(d1.vy >= 0 && d2.vy >= 0);
|
||||||
col.vy = d1.vy >= 0 && d2.vy >= 0;
|
col.vz = !(d1.vz >= 0 && d2.vz >= 0);
|
||||||
col.vz = d1.vz >= 0 && d2.vz >= 0;
|
|
||||||
|
|
||||||
return col;
|
return col;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user