- Redistribució de gràfics en diferents GIFs
This commit is contained in:
103
source/room.cpp
103
source/room.cpp
@@ -14,6 +14,23 @@ namespace room
|
||||
static uint8_t door_height[4];
|
||||
static uint8_t color = 5;
|
||||
|
||||
static uint8_t floor_type = 0;
|
||||
static uint8_t walls_type = 0;
|
||||
static uint8_t doors_type = 0;
|
||||
|
||||
static draw::surface *floor_surf = nullptr;
|
||||
static draw::surface *walls_surf = nullptr;
|
||||
static draw::surface *doors_surf = nullptr;
|
||||
static draw::surface *aux_surf = nullptr;
|
||||
|
||||
void init()
|
||||
{
|
||||
floor_surf = draw::loadSurface("floor.gif");
|
||||
walls_surf = draw::loadSurface("walls.gif");
|
||||
doors_surf = draw::loadSurface("doors.gif");
|
||||
aux_surf = draw::loadSurface("roomaux.gif");
|
||||
}
|
||||
|
||||
void load(int x, int y, int8_t xp, int8_t xn, int8_t yp, int8_t yn, uint8_t col)
|
||||
{
|
||||
color = col;
|
||||
@@ -51,6 +68,7 @@ namespace room
|
||||
|
||||
void draw()
|
||||
{
|
||||
draw::pushSource();
|
||||
draw::swapcol(1, color);
|
||||
|
||||
// RUTINES DE PINTAT DE LA PORTA DE DALT A LA DRETA
|
||||
@@ -58,17 +76,21 @@ namespace room
|
||||
{
|
||||
// Si la porta està elevada, pintar la part frontal de baix de la porta
|
||||
if (door_height[3] > 0) {
|
||||
draw::draw( 164+3*16-tmin.y*16, (36+3*8+tmin.y*8) + (5-door_height[3])*8, 16, 48-(5-door_height[3])*8, 128, 16+(5-door_height[3])*8);
|
||||
draw::draw( 164+4*16-tmin.y*16, (36+4*8+tmin.y*8) + (5-door_height[3])*8, 16, 48-(5-door_height[3])*8, 128, 16+(5-door_height[3])*8);
|
||||
draw::setSource(walls_surf);
|
||||
draw::draw( 164+3*16-tmin.y*16, (36+3*8+tmin.y*8) + (5-door_height[3])*8, 16, 48-(5-door_height[3])*8, walls_type*32, (5-door_height[3])*8);
|
||||
draw::draw( 164+4*16-tmin.y*16, (36+4*8+tmin.y*8) + (5-door_height[3])*8, 16, 48-(5-door_height[3])*8, walls_type*32, (5-door_height[3])*8);
|
||||
}
|
||||
|
||||
// Pintem els dos tiles baix de la porta
|
||||
draw::draw(164+4*16-(tmin.y-1)*16, -door_height[3]*8+84+4*8+(tmin.y-1)*8, 16, 15, 144, 49); // Vora
|
||||
draw::draw(148+3*16-(tmin.y-1)*16, -door_height[3]*8+76+3*8+(tmin.y-1)*8, 32, 15, 0, 1); // Tile de Piso
|
||||
draw::draw(148+4*16-(tmin.y-1)*16, -door_height[3]*8+76+4*8+(tmin.y-1)*8, 32, 15, 0, 1); // Tile de Piso
|
||||
draw::setSource(walls_surf);
|
||||
draw::draw(164+4*16-(tmin.y-1)*16, -door_height[3]*8+84+4*8+(tmin.y-1)*8, 16, 15, 16+walls_type*32, 33); // Vora
|
||||
draw::setSource(floor_surf);
|
||||
draw::draw(148+3*16-(tmin.y-1)*16, -door_height[3]*8+76+3*8+(tmin.y-1)*8, 32, 15, floor_type*32, 1); // Tile de Piso
|
||||
draw::draw(148+4*16-(tmin.y-1)*16, -door_height[3]*8+76+4*8+(tmin.y-1)*8, 32, 15, floor_type*32, 1); // Tile de Piso
|
||||
|
||||
// Pintem la porta
|
||||
draw::draw(164+3*16-tmin.y*16, -door_height[3]*8+32+3*8+tmin.y*8,40,59,18,133);
|
||||
draw::setSource(doors_surf);
|
||||
draw::draw(164+3*16-tmin.y*16, -door_height[3]*8+32+3*8+tmin.y*8,40,59,doors_type*80,0);
|
||||
}
|
||||
|
||||
// RUTINES DE PINTAT DE LA PORTA DE DALT A LA ESQUERRA
|
||||
@@ -76,77 +98,92 @@ namespace room
|
||||
{
|
||||
// Si la porta està elevada, pintar la part frontal de baix de la porta
|
||||
if (door_height[1] > 0) {
|
||||
draw::draw(148+tmin.x*16-3*16, (36+tmin.x*8+3*8)+(5-door_height[1])*8, 16, 48-(5-door_height[1])*8, 144, 16+(5-door_height[1])*8);
|
||||
draw::draw(148+tmin.x*16-4*16, (36+tmin.x*8+4*8)+(5-door_height[1])*8, 16, 48-(5-door_height[1])*8, 144, 16+(5-door_height[1])*8);
|
||||
draw::setSource(walls_surf);
|
||||
draw::draw(148+tmin.x*16-3*16, (36+tmin.x*8+3*8)+(5-door_height[1])*8, 16, 48-(5-door_height[1])*8, 16+walls_type*32, (5-door_height[1])*8);
|
||||
draw::draw(148+tmin.x*16-4*16, (36+tmin.x*8+4*8)+(5-door_height[1])*8, 16, 48-(5-door_height[1])*8, 16+walls_type*32, (5-door_height[1])*8);
|
||||
}
|
||||
|
||||
// Pintem els dos tiles baix de la porta
|
||||
draw::draw(164+(tmin.x-1)*16-5*16, -door_height[1]*8+84+(tmin.x-1)*8+4*8, 16, 15, 128, 49); // Vora
|
||||
draw::draw(148+(tmin.x-1)*16-3*16, -door_height[1]*8+76+(tmin.x-1)*8+3*8,32,15,0,1);
|
||||
draw::draw(148+(tmin.x-1)*16-4*16, -door_height[1]*8+76+(tmin.x-1)*8+4*8,32,15,0,1);
|
||||
draw::setSource(walls_surf);
|
||||
draw::draw(164+(tmin.x-1)*16-5*16, -door_height[1]*8+84+(tmin.x-1)*8+4*8, 16, 15, walls_type*32, 33); // Vora
|
||||
draw::setSource(floor_surf);
|
||||
draw::draw(148+(tmin.x-1)*16-3*16, -door_height[1]*8+76+(tmin.x-1)*8+3*8,32,15,floor_type*32,1);
|
||||
draw::draw(148+(tmin.x-1)*16-4*16, -door_height[1]*8+76+(tmin.x-1)*8+4*8,32,15,floor_type*32,1);
|
||||
|
||||
// Pintem la porta
|
||||
draw::draw(164+(tmin.x-1)*16-4*16-8, -door_height[1]*8+32+3*8+9+(tmin.x-1)*8, 40,59, 64,133);
|
||||
draw::setSource(doors_surf);
|
||||
draw::draw(164+(tmin.x-1)*16-4*16-8, -door_height[1]*8+32+3*8+9+(tmin.x-1)*8, 40,59, 40+doors_type*80,0);
|
||||
}
|
||||
|
||||
draw::setSource(walls_surf);
|
||||
for (int x=tmin.x;x<=tmax.x;++x)
|
||||
{
|
||||
// Si hi ha porta en YP i està a altura 0, no pintem la vorera en eixos dos tiles
|
||||
if ( !(doors & DOOR_YP) || (door_height[2] != 0) || (x!=3 && x!=4) ) draw::draw(148+x*16-tmax.y*16,84+x*8+tmax.y*8,16,15,128,49);
|
||||
if ( !(doors & DOOR_YP) || (door_height[2] != 0) || (x!=3 && x!=4) ) draw::draw(148+x*16-tmax.y*16,84+x*8+tmax.y*8,16,15,walls_type*32, 33);
|
||||
|
||||
// Si hi ha porta en YN, no pintem la pared en eixos dos tiles
|
||||
if ( !(doors & DOOR_YN) || (x!=3 && x!=4) ) draw::draw(164+x*16-tmin.y*16,36+x*8+tmin.y*8,16,48,128,16);
|
||||
if ( !(doors & DOOR_YN) || (x!=3 && x!=4) ) draw::draw(164+x*16-tmin.y*16,36+x*8+tmin.y*8,16,48,walls_type*32, 0);
|
||||
}
|
||||
|
||||
for (int y=tmin.y;y<=tmax.y;++y)
|
||||
{
|
||||
draw::setSource(walls_surf);
|
||||
// Si hi ha porta en XP i està a altura 0, no pintem la vorera en eixos dos tiles
|
||||
if ( !(doors & DOOR_XP) || (door_height[0] != 0) || (y!=3 && y!=4) ) draw::draw(164+tmax.x*16-y*16,84+tmax.x*8+y*8,16,15,144,49);
|
||||
if ( !(doors & DOOR_XP) || (door_height[0] != 0) || (y!=3 && y!=4) ) draw::draw(164+tmax.x*16-y*16,84+tmax.x*8+y*8,16,15,16+walls_type*32, 33);
|
||||
|
||||
// Si hi ha porta en XN, no pintem la pared en eixos dos tiles
|
||||
if ( !(doors & DOOR_XN) || (y!=3 && y!=4) ) draw::draw(148+tmin.x*16-y*16,36+tmin.x*8+y*8,16,48,144,16);
|
||||
if ( !(doors & DOOR_XN) || (y!=3 && y!=4) ) draw::draw(148+tmin.x*16-y*16,36+tmin.x*8+y*8,16,48,16+walls_type*32,0);
|
||||
|
||||
// Pintem tots els tiles del piso
|
||||
draw::setSource(floor_surf);
|
||||
for (int x=tmin.x;x<=tmax.x;++x)
|
||||
{
|
||||
draw::draw(148+x*16-y*16,76+x*8+y*8,32,15,0,1);
|
||||
draw::draw(148+x*16-y*16,76+x*8+y*8,32,15,floor_type*32,1);
|
||||
}
|
||||
}
|
||||
}
|
||||
draw::popSource();
|
||||
}
|
||||
|
||||
void draw2()
|
||||
{
|
||||
draw::pushSource();
|
||||
draw::swapcol(1, color);
|
||||
|
||||
if (doors & DOOR_YP)
|
||||
{
|
||||
// Pintem les voreres dels dos tiles extra per a la porta YP
|
||||
draw::draw(164+4*16-(tmax.y+1)*16, -door_height[2]*8+84+4*8+(tmax.y+1)*8, 16, 15+door_height[2]*8, 144, 17);
|
||||
draw::draw(148+3*16-(tmax.y+1)*16, -door_height[2]*8+84+3*8+(tmax.y+1)*8, 16, 15+door_height[2]*8, 128, 17);
|
||||
draw::draw(148+4*16-(tmax.y+1)*16, -door_height[2]*8+84+4*8+(tmax.y+1)*8, 16, 15+door_height[2]*8, 128, 17);
|
||||
draw::setSource(walls_surf);
|
||||
draw::draw(164+4*16-(tmax.y+1)*16, -door_height[2]*8+84+4*8+(tmax.y+1)*8, 16, 15+door_height[2]*8, 16+walls_type*32, 1);
|
||||
draw::draw(148+3*16-(tmax.y+1)*16, -door_height[2]*8+84+3*8+(tmax.y+1)*8, 16, 15+door_height[2]*8, walls_type*32, 1);
|
||||
draw::draw(148+4*16-(tmax.y+1)*16, -door_height[2]*8+84+4*8+(tmax.y+1)*8, 16, 15+door_height[2]*8, walls_type*32, 1);
|
||||
|
||||
draw::draw(164+4*16-(tmax.y+1)*16, 91+4*8+(tmax.y+1)*8, 16, 8, 16, 24);
|
||||
draw::draw(148+3*16-(tmax.y+1)*16, 91+3*8+(tmax.y+1)*8, 16, 8, 0, 24);
|
||||
draw::draw(148+4*16-(tmax.y+1)*16, 91+4*8+(tmax.y+1)*8, 16, 8, 0, 24);
|
||||
draw::setSource(aux_surf);
|
||||
draw::draw(164+4*16-(tmax.y+1)*16, 91+4*8+(tmax.y+1)*8, 16, 8, 16, 0);
|
||||
draw::draw(148+3*16-(tmax.y+1)*16, 91+3*8+(tmax.y+1)*8, 16, 8, 0, 0);
|
||||
draw::draw(148+4*16-(tmax.y+1)*16, 91+4*8+(tmax.y+1)*8, 16, 8, 0, 0);
|
||||
|
||||
// Pintem la porta YP
|
||||
draw::draw(164+3*16-8-(tmax.y+1)*16, -door_height[2]*8+32+3*8+4+(tmax.y+1)*8,40,59,18,133);
|
||||
draw::setSource(doors_surf);
|
||||
draw::draw(164+3*16-8-(tmax.y+1)*16, -door_height[2]*8+32+3*8+4+(tmax.y+1)*8,40,59,doors_type*80,0);
|
||||
}
|
||||
if (doors & DOOR_XP)
|
||||
{
|
||||
// Pintem les voreres dels dos tiles extra per a la porta XP
|
||||
draw::draw(148+(tmax.x+1)*16-4*16, -door_height[0]*8+84+(tmax.x+1)*8+4*8,16,15+door_height[0]*8,128,17);
|
||||
draw::draw(164+(tmax.x+1)*16-3*16, -door_height[0]*8+84+(tmax.x+1)*8+3*8,16,15+door_height[0]*8,144,17);
|
||||
draw::draw(164+(tmax.x+1)*16-4*16, -door_height[0]*8+84+(tmax.x+1)*8+4*8,16,15+door_height[0]*8,144,17);
|
||||
draw::setSource(walls_surf);
|
||||
draw::draw(148+(tmax.x+1)*16-4*16, -door_height[0]*8+84+(tmax.x+1)*8+4*8,16,15+door_height[0]*8,walls_type*32, 1);
|
||||
draw::draw(164+(tmax.x+1)*16-3*16, -door_height[0]*8+84+(tmax.x+1)*8+3*8,16,15+door_height[0]*8,16+walls_type*32, 1);
|
||||
draw::draw(164+(tmax.x+1)*16-4*16, -door_height[0]*8+84+(tmax.x+1)*8+4*8,16,15+door_height[0]*8,16+walls_type*32, 1);
|
||||
|
||||
draw::draw(148+(tmax.x+1)*16-4*16, 91+(tmax.x+1)*8+4*8,16,8,0,24);
|
||||
draw::draw(164+(tmax.x+1)*16-3*16, 91+(tmax.x+1)*8+3*8,16,8,16,24);
|
||||
draw::draw(164+(tmax.x+1)*16-4*16, 91+(tmax.x+1)*8+4*8,16,8,16,24);
|
||||
draw::setSource(aux_surf);
|
||||
draw::draw(148+(tmax.x+1)*16-4*16, 91+(tmax.x+1)*8+4*8,16,8,0,0);
|
||||
draw::draw(164+(tmax.x+1)*16-3*16, 91+(tmax.x+1)*8+3*8,16,8,16,0);
|
||||
draw::draw(164+(tmax.x+1)*16-4*16, 91+(tmax.x+1)*8+4*8,16,8,16,0);
|
||||
|
||||
// Pintem la porta XP
|
||||
draw::draw( 164+(tmax.x+1)*16-4*16-16, -door_height[0]*8+32+3*8+4+(tmax.x+1)*8, 40,59, 64,133);
|
||||
draw::setSource(doors_surf);
|
||||
draw::draw( 164+(tmax.x+1)*16-4*16-16, -door_height[0]*8+32+3*8+4+(tmax.x+1)*8, 40,59, 40+doors_type*80,0);
|
||||
}
|
||||
|
||||
draw::popSource();
|
||||
}
|
||||
|
||||
vec3_t getSize()
|
||||
|
||||
Reference in New Issue
Block a user