This commit is contained in:
ABelliqueux 2021-02-03 16:20:34 +01:00
parent 2e69d2a58a
commit 3bbd5c370b

View File

@ -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;