X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fmodex16%2F16render.c;h=fdc2215e82ff0dcf7527afb4a0cd663b85106387;hb=1a01aa526f8f38ec5f3aad51e8e7526b8a7cac45;hp=b70c7f19cdae73dbb29ccb53d7c0b9d6faf0c984;hpb=84aee10629e5f04d34de5e4997e305cd2fd746cf;p=16.git diff --git a/src/lib/modex16/16render.c b/src/lib/modex16/16render.c index b70c7f19..fdc2215e 100755 --- a/src/lib/modex16/16render.c +++ b/src/lib/modex16/16render.c @@ -31,36 +31,33 @@ //modexDrawBmpRegion (page_t *page, int x, int y, int rx, int ry, int rw, int rh, bitmap_t *bmp) void modexDrawPBufRegion (page_t *page, int x, int y, int rx, int ry, int rw, int rh, planar_buf_t *p, boolean sprite) { - sword plane; + word plane; int i; - const int px=x;//-page->dx; - const int py=y;//-page->dy; - #define PEEE ((rw)/4)-rx - //-(rx/4) - #define PEEEE ((p->pwidth)*(ry)) - //y=py; - //x=px; + const int px=x+page->dx; + const int py=y+page->dy; + const int prw = rw/4; + + //fine tuning + rx+=1; + ry+=1; + + //^^; + #define PEEE rx-prw + #define PE (p->pwidth) + #define PEEEE (PE*(ry)) + y=py; + x=px; //printf("%d,%d p(%d,%d) r(%d,%d) rwh(%d,%d)\n", x, y, px, py, rx, ry, rw, rh); for(plane=0; plane < 4; plane++) { i=PEEE+PEEEE; - //printf("PEEE=%d ", PEEE); - //printf("PEEEE=%d ", PEEEE); - //printf("i=%d\n", i); - modexSelectPlane(PLANE(plane+x)); + modexSelectPlane(PLANE(plane-1)); for(; y < py+rh; y++) { - //for(px=0; px < p->width; px++) { - //printf("%02X ", (int) p->plane[plane][i++]); -// _fmemcpy(buff, &(p->plane[plane][i+=p->pwidth]), p->pwidth); -// printf("buff %u==%s\n", y, *buff); - _fmemcpy(page->data + (((page->width/4) * y) + (x / 4)), &(p->plane[plane][i+=p->pwidth]), (rw/4)); - //} - //if(plane==3) IN_Ack(); + _fmemcpy(page->data + (((page->width/4) * (y)) + ((x) / 4)), &(p->plane[plane][i]), prw); + i+=PE; } - /*printf("y%d=%d ", plane, y); - if(plane==3) printf("y%d=%d\n", plane, y);*/ x=px; y=py; - } + } } @@ -68,7 +65,9 @@ void modexDrawPBufRegion (page_t *page, int x, int y, int rx, int ry, int rw, in void modexDrawPBuf(page_t *page, int x, int y, planar_buf_t *p, boolean sprite) { - int plane; + modexDrawPBufRegion (page, x, x, 0, 0, p->width, p->height, p, sprite); + /* + sword plane; int i; // byte near *buff; const int px=x+page->dx; @@ -93,7 +92,7 @@ modexDrawPBuf(page_t *page, int x, int y, planar_buf_t *p, boolean sprite) // } for(plane=0; plane < 4; plane++) { i=0; - modexSelectPlane(PLANE(plane+x)); + modexSelectPlane(PLANE(plane-1)); for(; y < py+p->height; y++) { //for(px=0; px < p->width; px++) { //printf("%02X ", (int) p->plane[plane][i++]); @@ -107,7 +106,7 @@ modexDrawPBuf(page_t *page, int x, int y, planar_buf_t *p, boolean sprite) x=px; y=py; } -// _nfree(buff); +// _nfree(buff);*/ } void