Move SetDispMask() to init()
This commit is contained in:
parent
c46162d943
commit
7167b9c082
@ -102,6 +102,8 @@ void init(void)
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
|
|
||||||
@ -124,8 +126,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -67,6 +67,7 @@ void init(){
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
setRGB0(&draw[0], 0, 128, 255);
|
setRGB0(&draw[0], 0, 128, 255);
|
||||||
setRGB0(&draw[1], 0, 128, 255);
|
setRGB0(&draw[1], 0, 128, 255);
|
||||||
draw[0].isbg = 1;
|
draw[0].isbg = 1;
|
||||||
@ -82,7 +83,6 @@ void display(void){
|
|||||||
VSync(0);
|
VSync(0);
|
||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
SetDispMask(1);
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
db = !db;
|
db = !db;
|
||||||
nextpri = primbuff[db];
|
nextpri = primbuff[db];
|
||||||
|
@ -92,6 +92,8 @@ void init(){
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetDispMask(1);
|
||||||
|
|
||||||
setRGB0(&draw[0], 0, 0, 255);
|
setRGB0(&draw[0], 0, 0, 255);
|
||||||
setRGB0(&draw[1], 0, 0, 255);
|
setRGB0(&draw[1], 0, 0, 255);
|
||||||
|
|
||||||
@ -115,8 +117,6 @@ void display(void){
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -83,7 +83,6 @@ void display(void)
|
|||||||
// Flip DISP and DRAW env
|
// Flip DISP and DRAW env
|
||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
//~ SetDispMask(1);
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
// Flip db index
|
// Flip db index
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -95,6 +95,7 @@ void init(){
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1);
|
||||||
// Set light env
|
// Set light env
|
||||||
// Set far color
|
// Set far color
|
||||||
SetFarColor( BGc.r, BGc.g, BGc.b );
|
SetFarColor( BGc.r, BGc.g, BGc.b );
|
||||||
@ -119,7 +120,6 @@ void display(void){
|
|||||||
VSync(0);
|
VSync(0);
|
||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
SetDispMask(1);
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
db = !db;
|
db = !db;
|
||||||
nextpri = primbuff[db];
|
nextpri = primbuff[db];
|
||||||
|
@ -127,6 +127,8 @@ void initGraph(void)
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
|
|
||||||
@ -149,8 +151,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -51,6 +51,7 @@ void init(void)
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
@ -74,8 +75,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -88,7 +88,7 @@ void init(void)
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
|
|
||||||
@ -111,8 +111,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -107,6 +107,7 @@ void init(void)
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 128, 128, 128);
|
setRGB0(&draw[0], 128, 128, 128);
|
||||||
setRGB0(&draw[1], 128, 128, 128);
|
setRGB0(&draw[1], 128, 128, 128);
|
||||||
@ -130,8 +131,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -83,6 +83,7 @@ void init(void)
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], BgColor->r, BgColor->g, BgColor->b);
|
setRGB0(&draw[0], BgColor->r, BgColor->g, BgColor->b);
|
||||||
setRGB0(&draw[1], BgColor->r, BgColor->g, BgColor->b);
|
setRGB0(&draw[1], BgColor->r, BgColor->g, BgColor->b);
|
||||||
@ -106,8 +107,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -108,7 +108,7 @@ void init(void)
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
setRGB0(&draw[0], 128, 128, 128);
|
setRGB0(&draw[0], 128, 128, 128);
|
||||||
setRGB0(&draw[1], 128, 128, 128);
|
setRGB0(&draw[1], 128, 128, 128);
|
||||||
|
|
||||||
@ -131,8 +131,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -108,6 +108,7 @@ void init(void)
|
|||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 128, 128, 128);
|
setRGB0(&draw[0], 128, 128, 128);
|
||||||
setRGB0(&draw[1], 128, 128, 128);
|
setRGB0(&draw[1], 128, 128, 128);
|
||||||
@ -131,8 +132,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -59,7 +59,6 @@ void init(void)
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
SetDispMask(1);
|
SetDispMask(1);
|
||||||
|
|
||||||
// Set background color
|
// Set background color
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
@ -80,7 +79,6 @@ void display(void)
|
|||||||
// Flip DISP and DRAW env
|
// Flip DISP and DRAW env
|
||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
//~ SetDispMask(1);
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
// Flip db index
|
// Flip db index
|
||||||
db = !db;
|
db = !db;
|
||||||
|
226
hello_poly_subdiv/hello_poly_subdiv.c
Normal file
226
hello_poly_subdiv/hello_poly_subdiv.c
Normal file
@ -0,0 +1,226 @@
|
|||||||
|
// Hello poly ! Inline / DMPSX version
|
||||||
|
//
|
||||||
|
// Ref : /psyq/DOCS/Devrefs/Inlinref.pdf, p.18
|
||||||
|
// https://psx-spx.consoledev.net/geometrytransformationenginegte/
|
||||||
|
// PSX / Z+
|
||||||
|
// screen /
|
||||||
|
//coordinate +-----X+
|
||||||
|
//system / |
|
||||||
|
// eye | Y+
|
||||||
|
//
|
||||||
|
// Credits, thanks : Nicolas Noble, Sickle, Lameguy64 @ psxdev discord : https://discord.com/invite/N2mmwp
|
||||||
|
// https://discord.com/channels/642647820683444236/663664210525290507/834831466100949002
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <libetc.h>
|
||||||
|
#include <libgte.h>
|
||||||
|
#include <libgpu.h>
|
||||||
|
// OldWorld PsyQ has a inline_c.h file for inline GTE functions. We have to use the one at https://github.com/grumpycoders/pcsx-redux/blob/07f9b02d1dbb68f57a9f5b9773041813c55a4913/src/mips/psyq/include/inline_n.h
|
||||||
|
// because the real GTE commands are needed in nugget : https://psx-spx.consoledev.net/geometrytransformationenginegte/#gte-coordinate-calculation-commands
|
||||||
|
#include <inline_n.h>
|
||||||
|
//~ #include <gtemac.h> // gtemac contains macro versions of the libgte functions, worth checking out to see the operations order.
|
||||||
|
|
||||||
|
#define VMODE 0 // Video Mode : 0 : NTSC, 1: PAL
|
||||||
|
#define SCREENXRES 320 // Screen width
|
||||||
|
#define SCREENYRES 240 + (VMODE << 4) // Screen height : If VMODE is 0 = 240, if VMODE is 1 = 256
|
||||||
|
#define CENTERX ( SCREENXRES >> 1 ) // Center of screen on x
|
||||||
|
#define CENTERY ( SCREENYRES >> 1 ) // Center of screen on y
|
||||||
|
#define MARGINX 0 // margins for text display
|
||||||
|
#define MARGINY 32
|
||||||
|
#define FONTSIZE 8 * 7 // Text Field Height
|
||||||
|
#define OTLEN 10 // Ordering Table Length
|
||||||
|
|
||||||
|
DISPENV disp[2]; // Double buffered DISPENV and DRAWENV
|
||||||
|
DRAWENV draw[2];
|
||||||
|
u_long ot[2][OTLEN]; // double ordering table of length 8 * 32 = 256 bits / 32 bytes
|
||||||
|
char primbuff[2][32768] = {1}; // double primitive buffer of length 32768 * 8 = 262.144 bits / 32,768 Kbytes
|
||||||
|
char *nextpri = primbuff[0]; // pointer to the next primitive in primbuff. Initially, points to the first bit of primbuff[0]
|
||||||
|
short db = 0; // index of which buffer is used, values 0, 1
|
||||||
|
|
||||||
|
short subdiv = 1;
|
||||||
|
|
||||||
|
void init(void)
|
||||||
|
{
|
||||||
|
ResetGraph(0);
|
||||||
|
// Initialize and setup the GTE
|
||||||
|
InitGeom();
|
||||||
|
//~ SetGeomOffset(CENTERX,CENTERY);
|
||||||
|
gte_SetGeomOffset(CENTERX,CENTERY);
|
||||||
|
gte_SetGeomScreen(CENTERX);
|
||||||
|
// Set display environment
|
||||||
|
SetDefDispEnv(&disp[0], 0, 0, SCREENXRES, SCREENYRES);
|
||||||
|
SetDefDispEnv(&disp[1], 0, SCREENYRES, SCREENXRES, SCREENYRES);
|
||||||
|
// Set draw environment
|
||||||
|
SetDefDrawEnv(&draw[0], 0, SCREENYRES, SCREENXRES, SCREENYRES);
|
||||||
|
SetDefDrawEnv(&draw[1], 0, 0, SCREENXRES, SCREENYRES);
|
||||||
|
// If PAL, use 320x256, hence 256 - 240 = 16 / 2 = 8 px vertical offset
|
||||||
|
if (VMODE)
|
||||||
|
{
|
||||||
|
SetVideoMode(MODE_PAL);
|
||||||
|
disp[0].screen.y += 8;
|
||||||
|
disp[1].screen.y += 8;
|
||||||
|
}
|
||||||
|
SetDispMask(1);
|
||||||
|
// Set background color
|
||||||
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
|
draw[0].isbg = 1;
|
||||||
|
draw[1].isbg = 1;
|
||||||
|
PutDispEnv(&disp[db]);
|
||||||
|
PutDrawEnv(&draw[db]);
|
||||||
|
FntLoad(960, 0);
|
||||||
|
FntOpen(MARGINX, SCREENYRES - MARGINY - FONTSIZE, SCREENXRES - MARGINX * 2, FONTSIZE, 0, 280 );
|
||||||
|
}
|
||||||
|
|
||||||
|
void display(void)
|
||||||
|
{
|
||||||
|
// Wait for drawing
|
||||||
|
DrawSync(0);
|
||||||
|
// Wait for vsync
|
||||||
|
VSync(0);
|
||||||
|
// Flip DISP and DRAW env
|
||||||
|
PutDispEnv(&disp[db]);
|
||||||
|
PutDrawEnv(&draw[db]);
|
||||||
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
// Flip db index
|
||||||
|
db = !db;
|
||||||
|
// Get next primitive in buffer
|
||||||
|
nextpri = primbuff[db];
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
long p, flag, OTz;
|
||||||
|
SVECTOR rotVector = {0};
|
||||||
|
SVECTOR rotVector4 = {0}; // Initialize rotation vector {x, y, z}
|
||||||
|
VECTOR transVector = {0, 0, CENTERX, 0}; // Initialize translation vector {x, y, z}
|
||||||
|
SVECTOR vertPos[4] = { // 0 ______ 1
|
||||||
|
{ -64, -32, 0, 0 }, // Vert 1 | |
|
||||||
|
{ 32, -32, 0, 0 }, // Vert 2 | _______|
|
||||||
|
{ -32, 48, 0, 0 }, // 2 3
|
||||||
|
{ 22, 50, 0, 0 }
|
||||||
|
}; // Vert 3
|
||||||
|
MATRIX workMatrix = {0};
|
||||||
|
POLY_F4 * poly = {0}; // pointer to a POLY_F4
|
||||||
|
POLY_F4 * poly4 = {0}; // pointer to a POLY_F4
|
||||||
|
POLY_F4 * polySub[4] = {0}; // pointer to a POLY_F4
|
||||||
|
init();
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
// Set Ordering table
|
||||||
|
ClearOTagR(ot[db], OTLEN);
|
||||||
|
rotVector.vz += 4;
|
||||||
|
// Find rotation matrix from vector, store in
|
||||||
|
RotMatrix_gte(&rotVector, &workMatrix);
|
||||||
|
// Ditto for translation
|
||||||
|
TransMatrix(&workMatrix, &transVector);
|
||||||
|
// Set the matrices we just found
|
||||||
|
gte_SetRotMatrix(&workMatrix);
|
||||||
|
gte_SetTransMatrix(&workMatrix);
|
||||||
|
|
||||||
|
poly4 = (POLY_F4 *)nextpri;
|
||||||
|
nextpri += sizeof(POLY_F4); // increment nextpri address with size of a POLY_F3 struct
|
||||||
|
|
||||||
|
polySub[0] = (POLY_F4 *)nextpri;
|
||||||
|
nextpri += sizeof(POLY_F4);
|
||||||
|
polySub[1] = (POLY_F4 *)nextpri;
|
||||||
|
nextpri += sizeof(POLY_F4);
|
||||||
|
polySub[2] = (POLY_F4 *)nextpri;
|
||||||
|
nextpri += sizeof(POLY_F4);
|
||||||
|
polySub[3] = (POLY_F4 *)nextpri;
|
||||||
|
|
||||||
|
polySub[0]->x0 = poly4->x0;
|
||||||
|
polySub[0]->y0 = poly4->y0;
|
||||||
|
|
||||||
|
polySub[0]->x1 = (poly4->x0 + poly4->x1) >> 1;
|
||||||
|
polySub[0]->y1 = (poly4->y0 + poly4->y1) >> 1;
|
||||||
|
|
||||||
|
polySub[0]->x2 = (poly4->x0 + poly4->x2) >> 1;
|
||||||
|
polySub[0]->y2 = (poly4->y0 + poly4->y2) >> 1;
|
||||||
|
|
||||||
|
polySub[0]->x3 = (poly4->x0 + poly4->x3) >> 1;
|
||||||
|
polySub[0]->y3 = (poly4->y0 + poly4->y3) >> 1;
|
||||||
|
|
||||||
|
|
||||||
|
polySub[1]->x0 = polySub[0]->x1;
|
||||||
|
polySub[1]->y0 = polySub[0]->y1;
|
||||||
|
|
||||||
|
polySub[1]->x1 = poly4->x1;
|
||||||
|
polySub[1]->y1 = poly4->y1;
|
||||||
|
|
||||||
|
polySub[1]->x2 = polySub[0]->x3;
|
||||||
|
polySub[1]->y2 = polySub[0]->y3;
|
||||||
|
|
||||||
|
polySub[1]->x3 = (poly4->x1 + poly4->x3) >> 1;
|
||||||
|
polySub[1]->y3 = (poly4->y1 + poly4->y3) >> 1;
|
||||||
|
|
||||||
|
polySub[2]->x0 = polySub[0]->x2;
|
||||||
|
polySub[2]->y0 = polySub[0]->y2;
|
||||||
|
|
||||||
|
polySub[2]->x1 = polySub[0]->x3;
|
||||||
|
polySub[2]->y1 = polySub[0]->y3;
|
||||||
|
|
||||||
|
polySub[2]->x2 = poly4->x2;
|
||||||
|
polySub[2]->y2 = poly4->y2;
|
||||||
|
|
||||||
|
polySub[2]->x3 = (poly4->x2 + poly4->x3) >> 1;
|
||||||
|
polySub[2]->y3 = (poly4->y2 + poly4->y3) >> 1;
|
||||||
|
|
||||||
|
polySub[3]->x0 = polySub[0]->x3;
|
||||||
|
polySub[3]->y0 = polySub[0]->y3;
|
||||||
|
|
||||||
|
polySub[3]->x1 = polySub[1]->x3;
|
||||||
|
polySub[3]->y1 = polySub[1]->y3;
|
||||||
|
|
||||||
|
polySub[3]->x2 = polySub[2]->x3;
|
||||||
|
polySub[3]->y2 = polySub[2]->y3;
|
||||||
|
|
||||||
|
polySub[3]->x3 = poly4->x3;
|
||||||
|
polySub[3]->y3 = poly4->y3;
|
||||||
|
|
||||||
|
// Draw a Quad
|
||||||
|
|
||||||
|
// Transform 3 first vertices
|
||||||
|
gte_ldv3(&vertPos[0], &vertPos[1], &vertPos[2]);
|
||||||
|
gte_rtpt();
|
||||||
|
gte_stsxy3_f4(poly4);
|
||||||
|
// Transform remaining vertex
|
||||||
|
gte_ldv0(&vertPos[3]);
|
||||||
|
gte_rtps();
|
||||||
|
// SXY3 is set with gte_stsxy() or gte_stsxy2() ¯\_(ツ)_/¯
|
||||||
|
gte_stsxy(&poly4->x3);
|
||||||
|
// Get p, flag and OTz
|
||||||
|
gte_stdp(&p);
|
||||||
|
gte_stflg(&flag);
|
||||||
|
gte_stszotz(&OTz);
|
||||||
|
|
||||||
|
if ( subdiv == 0){
|
||||||
|
setPolyF4(poly4);
|
||||||
|
setRGB0(poly4, 0, 255, 255);
|
||||||
|
addPrim(ot[db], poly4);
|
||||||
|
} else {
|
||||||
|
setPolyF4(polySub[0]);
|
||||||
|
setRGB0(polySub[0], 255, 0, 255);
|
||||||
|
addPrim(ot[db], polySub[0]);
|
||||||
|
|
||||||
|
setPolyF4(polySub[1]);
|
||||||
|
setRGB0(polySub[1], 128, 0, 255);
|
||||||
|
addPrim(ot[db], polySub[1]);
|
||||||
|
|
||||||
|
setPolyF4(polySub[2]);
|
||||||
|
setRGB0(polySub[2], 0, 128, 255);
|
||||||
|
addPrim(ot[db], polySub[2]);
|
||||||
|
|
||||||
|
setPolyF4(polySub[3]);
|
||||||
|
setRGB0(polySub[3], 100, 255, 0);
|
||||||
|
addPrim(ot[db], polySub[3]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Display text
|
||||||
|
FntPrint("Hello poly subdiv !\n");
|
||||||
|
FntFlush(-1);
|
||||||
|
|
||||||
|
display();
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
@ -12,208 +12,110 @@
|
|||||||
//
|
//
|
||||||
// sio echo back
|
// sio echo back
|
||||||
// 1.00 Jan.28.1997 shino
|
// 1.00 Jan.28.1997 shino
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <libgte.h>
|
#include <libgte.h>
|
||||||
#include <libgpu.h>
|
#include <libgpu.h>
|
||||||
#include <libetc.h>
|
#include <libetc.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
// Needed for SIO operations
|
// Needed for SIO operations
|
||||||
|
|
||||||
#include <libsio.h>
|
#include <libsio.h>
|
||||||
|
|
||||||
// Needed for manipulating strings
|
// Needed for manipulating strings
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
// Display stuff (see hello_tile for the basics)
|
// Display stuff (see hello_tile for the basics)
|
||||||
|
|
||||||
#define VMODE 0
|
#define VMODE 0
|
||||||
|
|
||||||
#define SCREENXRES 320
|
#define SCREENXRES 320
|
||||||
|
|
||||||
#define SCREENYRES 240
|
#define SCREENYRES 240
|
||||||
|
|
||||||
#define CENTERX SCREENXRES/2
|
#define CENTERX SCREENXRES/2
|
||||||
|
|
||||||
#define CENTERY SCREENYRES/2
|
#define CENTERY SCREENYRES/2
|
||||||
|
|
||||||
#define OTLEN 2048 // Maximum number of OT entries
|
#define OTLEN 2048 // Maximum number of OT entries
|
||||||
|
|
||||||
#define PRIMBUFFLEN 32768 // Maximum number of POLY_GT3 primitives
|
#define PRIMBUFFLEN 32768 // Maximum number of POLY_GT3 primitives
|
||||||
|
|
||||||
// Display and draw environments, double buffered
|
// Display and draw environments, double buffered
|
||||||
|
|
||||||
DISPENV disp[2];
|
DISPENV disp[2];
|
||||||
|
|
||||||
DRAWENV draw[2];
|
DRAWENV draw[2];
|
||||||
|
|
||||||
u_long ot[2][OTLEN]; // Ordering table (contains addresses to primitives)
|
u_long ot[2][OTLEN]; // Ordering table (contains addresses to primitives)
|
||||||
|
|
||||||
char primbuff[2][PRIMBUFFLEN] = {0}; // Primitive list // That's our prim buffer
|
char primbuff[2][PRIMBUFFLEN] = {0}; // Primitive list // That's our prim buffer
|
||||||
|
|
||||||
char * nextpri = primbuff[0]; // Primitive counter
|
char * nextpri = primbuff[0]; // Primitive counter
|
||||||
|
|
||||||
short db = 0; // Current buffer counter
|
short db = 0; // Current buffer counter
|
||||||
|
|
||||||
// SIO
|
// SIO
|
||||||
|
|
||||||
#define MAX_CHARS 64
|
#define MAX_CHARS 64
|
||||||
|
|
||||||
u_char SIO = 1; // Is SIO enabled ?
|
u_char SIO = 1; // Is SIO enabled ?
|
||||||
|
|
||||||
u_char SIOinit = 0; // Is SIO initialized ?
|
u_char SIOinit = 0; // Is SIO initialized ?
|
||||||
|
|
||||||
// Prototypes
|
// Prototypes
|
||||||
|
|
||||||
void init(void);
|
void init(void);
|
||||||
|
|
||||||
void display(void);
|
void display(void);
|
||||||
|
|
||||||
void init(){
|
void init(){
|
||||||
|
|
||||||
// Reset the GPU before doing anything and the controller
|
// Reset the GPU before doing anything and the controller
|
||||||
|
|
||||||
ResetGraph(0);
|
ResetGraph(0);
|
||||||
|
|
||||||
// Set the display and draw environments
|
// Set the display and draw environments
|
||||||
|
|
||||||
SetDefDispEnv(&disp[0], 0, 0 , SCREENXRES, SCREENYRES);
|
SetDefDispEnv(&disp[0], 0, 0 , SCREENXRES, SCREENYRES);
|
||||||
|
|
||||||
SetDefDispEnv(&disp[1], 0, SCREENYRES, SCREENXRES, SCREENYRES);
|
SetDefDispEnv(&disp[1], 0, SCREENYRES, SCREENXRES, SCREENYRES);
|
||||||
|
|
||||||
SetDefDrawEnv(&draw[0], 0, SCREENYRES, SCREENXRES, SCREENYRES);
|
SetDefDrawEnv(&draw[0], 0, SCREENYRES, SCREENXRES, SCREENYRES);
|
||||||
|
|
||||||
SetDefDrawEnv(&draw[1], 0, 0, SCREENXRES, SCREENYRES);
|
SetDefDrawEnv(&draw[1], 0, 0, SCREENXRES, SCREENYRES);
|
||||||
|
|
||||||
// If in PAL mode, add vertical offset
|
// If in PAL mode, add vertical offset
|
||||||
|
|
||||||
if (VMODE)
|
if (VMODE)
|
||||||
{
|
{
|
||||||
|
|
||||||
SetVideoMode(MODE_PAL);
|
SetVideoMode(MODE_PAL);
|
||||||
|
|
||||||
disp[0].screen.y += 8;
|
disp[0].screen.y += 8;
|
||||||
|
|
||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
setRGB0(&draw[0], 0, 0, 255);
|
|
||||||
|
|
||||||
setRGB0(&draw[1], 0, 0, 255);
|
|
||||||
|
|
||||||
draw[0].isbg = 1;
|
|
||||||
|
|
||||||
draw[1].isbg = 1;
|
|
||||||
|
|
||||||
PutDispEnv(&disp[db]);
|
|
||||||
|
|
||||||
PutDrawEnv(&draw[db]);
|
|
||||||
|
|
||||||
// Init font system
|
|
||||||
|
|
||||||
FntLoad(960, 0);
|
|
||||||
|
|
||||||
FntOpen(16, 16, 196, 64, 0, 256);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void display(void){
|
|
||||||
|
|
||||||
DrawSync(0);
|
|
||||||
|
|
||||||
VSync(0);
|
|
||||||
|
|
||||||
PutDispEnv(&disp[db]);
|
|
||||||
|
|
||||||
PutDrawEnv(&draw[db]);
|
|
||||||
|
|
||||||
SetDispMask(1);
|
SetDispMask(1);
|
||||||
|
setRGB0(&draw[0], 0, 0, 255);
|
||||||
db = !db;
|
setRGB0(&draw[1], 0, 0, 255);
|
||||||
|
draw[0].isbg = 1;
|
||||||
|
draw[1].isbg = 1;
|
||||||
|
PutDispEnv(&disp[db]);
|
||||||
|
PutDrawEnv(&draw[db]);
|
||||||
|
// Init font system
|
||||||
|
FntLoad(960, 0);
|
||||||
|
FntOpen(16, 16, 196, 64, 0, 256);
|
||||||
|
}
|
||||||
|
void display(void){
|
||||||
|
DrawSync(0);
|
||||||
|
VSync(0);
|
||||||
|
PutDispEnv(&disp[db]);
|
||||||
|
PutDrawEnv(&draw[db]);
|
||||||
|
db = !db;
|
||||||
}
|
}
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
|
|
||||||
init();
|
init();
|
||||||
|
|
||||||
// Main loop
|
// Main loop
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
|
|
||||||
// Buffer for the RX data of size MAX_CHARS
|
// Buffer for the RX data of size MAX_CHARS
|
||||||
|
|
||||||
static char buffer[ MAX_CHARS ] = {0};
|
static char buffer[ MAX_CHARS ] = {0};
|
||||||
|
|
||||||
// If SIO flag is set, initialize and get data
|
// If SIO flag is set, initialize and get data
|
||||||
|
|
||||||
if( SIO ){
|
if( SIO ){
|
||||||
|
|
||||||
// Is SIO is not initialized, dot it
|
// Is SIO is not initialized, dot it
|
||||||
|
|
||||||
if( ! SIOinit ){
|
if( ! SIOinit ){
|
||||||
|
|
||||||
ResetCallback();
|
ResetCallback();
|
||||||
|
|
||||||
// Load SIO driver at 115200bps
|
// Load SIO driver at 115200bps
|
||||||
|
|
||||||
AddSIO(115200);
|
AddSIO(115200);
|
||||||
|
|
||||||
ResetGraph(0);
|
ResetGraph(0);
|
||||||
|
|
||||||
// Use _sio_control to clear driver status error-related bits
|
// Use _sio_control to clear driver status error-related bits
|
||||||
// See psyq's libref47.pdf, p.1125 for the commands and status tables
|
// See psyq's libref47.pdf, p.1125 for the commands and status tables
|
||||||
|
|
||||||
_sio_control(2,1,0);
|
_sio_control(2,1,0);
|
||||||
|
|
||||||
SIOinit = 1;
|
SIOinit = 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Limit input buffer to MAX_CHARS chars, making it a rolling buffer
|
// Limit input buffer to MAX_CHARS chars, making it a rolling buffer
|
||||||
|
|
||||||
if( strlen(buffer) > MAX_CHARS ){
|
if( strlen(buffer) > MAX_CHARS ){
|
||||||
|
|
||||||
// If that limit is reached, remove first char in string
|
// If that limit is reached, remove first char in string
|
||||||
|
|
||||||
memmove(buffer, buffer + 1, strlen(buffer));
|
memmove(buffer, buffer + 1, strlen(buffer));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if sio driver is able to write communications data
|
// Check if sio driver is able to write communications data
|
||||||
// If so, this means reading is not occuring
|
// If so, this means reading is not occuring
|
||||||
|
|
||||||
if( _sio_control(0,0,0) & SR_RXRDY ){ // SR_RXRDY == 0x2
|
if( _sio_control(0,0,0) & SR_RXRDY ){ // SR_RXRDY == 0x2
|
||||||
|
|
||||||
// Read byte
|
// Read byte
|
||||||
|
|
||||||
char c = _sio_control(0,4,0);
|
char c = _sio_control(0,4,0);
|
||||||
|
|
||||||
// Add to buffer
|
// Add to buffer
|
||||||
|
|
||||||
strncat(buffer, &c, 1);
|
strncat(buffer, &c, 1);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// END SIO FUN
|
// END SIO FUN
|
||||||
|
|
||||||
FntPrint("Hello Serial!\n\n");
|
FntPrint("Hello Serial!\n\n");
|
||||||
|
|
||||||
if( buffer ){
|
if( buffer ){
|
||||||
|
|
||||||
FntPrint("%s", buffer);
|
FntPrint("%s", buffer);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
FntFlush(-1);
|
FntFlush(-1);
|
||||||
|
|
||||||
display();
|
display();
|
||||||
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -85,6 +85,8 @@ void init(void)
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
|
|
||||||
@ -108,8 +110,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
@ -47,6 +47,8 @@ void init(void)
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
|
|
||||||
@ -68,9 +70,6 @@ void display(void)
|
|||||||
|
|
||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
// We're using a reverse OT, so we want to display the last item first. See PsyQ's LibRef47.pdf, p.277
|
// We're using a reverse OT, so we want to display the last item first. See PsyQ's LibRef47.pdf, p.277
|
||||||
DrawOTag(ot[db] + OTLEN - 1);
|
DrawOTag(ot[db] + OTLEN - 1);
|
||||||
// Uncomment the following line to use a regular oredered OT. Uncomment l.100 accordingly
|
// Uncomment the following line to use a regular oredered OT. Uncomment l.100 accordingly
|
||||||
|
@ -115,6 +115,8 @@ void initGraph(void)
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 50, 50, 50);
|
setRGB0(&draw[0], 50, 50, 50);
|
||||||
setRGB0(&draw[1], 50, 50, 50);
|
setRGB0(&draw[1], 50, 50, 50);
|
||||||
|
|
||||||
@ -137,8 +139,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]);
|
PutDispEnv(&disp[db]);
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1);
|
|
||||||
|
|
||||||
db = !db;
|
db = !db;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -41,6 +41,8 @@ void init(void)
|
|||||||
disp[1].screen.y += 8;
|
disp[1].screen.y += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SetDispMask(1); // Display on screen
|
||||||
|
|
||||||
setRGB0(&draw[0], 50, 50, 50); // set color for first draw area
|
setRGB0(&draw[0], 50, 50, 50); // set color for first draw area
|
||||||
setRGB0(&draw[1], 50, 50, 50); // set color for second draw area
|
setRGB0(&draw[1], 50, 50, 50); // set color for second draw area
|
||||||
|
|
||||||
@ -63,8 +65,6 @@ void display(void)
|
|||||||
PutDispEnv(&disp[db]); // set alternate disp and draw environnments
|
PutDispEnv(&disp[db]); // set alternate disp and draw environnments
|
||||||
PutDrawEnv(&draw[db]);
|
PutDrawEnv(&draw[db]);
|
||||||
|
|
||||||
SetDispMask(1); // Display on screen
|
|
||||||
|
|
||||||
db = !db; // flip db value (0 or 1)
|
db = !db; // flip db value (0 or 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user