X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fmodex16.c;h=08ab753dbb075cf82d5186614a2bcb7c3659bc60;hb=c49e0bb8159b3a5bf318ef305f302f1f1df9524c;hp=fa13d3658ccc16987c8127c7e0a90d17c0d2ec40;hpb=60bed23e449fb5296f73e5cd6bddb0d8d7f0eb4c;p=16.git diff --git a/src/lib/modex16.c b/src/lib/modex16.c index fa13d365..08ab753d 100644 --- a/src/lib/modex16.c +++ b/src/lib/modex16.c @@ -4,7 +4,7 @@ #include #include #include -#include "src\lib\modex16.h" +#include "src/lib/modex16.h" byte far* VGA=(byte far*) 0xA0000000; /* this points to video memory. */ @@ -481,7 +481,7 @@ fadePalette(sbyte fade, sbyte start, word iter, byte *palette) { /* handle the case where we just update */ if(iter == 0) { - modexPalUpdate2(palette); + modexPalUpdate1(palette); return; } @@ -494,7 +494,7 @@ fadePalette(sbyte fade, sbyte start, word iter, byte *palette) { tmppal[i] = 63; } } - modexPalUpdate2(tmppal); + modexPalUpdate1(tmppal); iter--; dim += fade; } @@ -597,12 +597,9 @@ modexPalUpdate(bitmap_t *bmp, word *i, word qp, word aqoffset) word w=0; word q=0; word qq=0; - //word ii; - static word a[PAL_SIZE/3]; //palette array of change values! + static word a[PAL_SIZE]; //palette array of change values! word z=0, aq=0, aa=0, pp=0; - //sword aqpw; - //printf("1 (*i)=%02d\n", (*i)/3); modexWaitBorder(); if((*i)==0) { @@ -620,7 +617,6 @@ modexPalUpdate(bitmap_t *bmp, word *i, word qp, word aqoffset) // printf("q: %02d\n", (q)); // printf("qq: %02d\n", (qq)); //printf(" (*i)-q=%02d\n", (*i)-q); -// printf("================\n"); outp(PAL_WRITE_REG, qq); /* start at the beginning of palette */ } if((*i)0 && (*i)>=(qp*3) && (*i)<((qp*3)+3)) + else if(qp>0 && (*i)>=(qp) && (*i)<((qp)+3)) { - /* - note to self - use a[qp] instead of bmp->offset for this spot! - */ //printf("qp=%d\n", qp); - //printf(" (*i)=%d\n", (*i)/3); - //for(w=(*i); w<()){ - printf(" (*i)=%d a[%d]=%d\n", (*i), qp, a[qp]); -//0000 printf(" %d's color=%d\n", (*i), (a[qp])*3);//+(aqoffset*3) -//0000 outp(PAL_DATA_REG, p[((a[qp])*3)]);// fix this shit! - if((*i)+1==(qp*3)+3){ w++; /*(*i)++;*/ break; } + //printf(" (*i)=%d a[%d]=%d\n", (*i), qp, a[qp]); + printf(" %d's color=%d\n", (*i), (a[qp])-(bmp->offset*3)+qp); + //outp(PAL_DATA_REG, p[((a[qp])-(bmp->offset*3)+qp)]);// fix this shit! + if((*i)+1==(qp)+3){ w++; /*(*i)++;*/ break; } } else { if(bmp->offset==0 && (*i)<3 && q==0) outp(PAL_DATA_REG, 0); else if(qp==0) outp(PAL_DATA_REG, p[(*i)-q]); - else outp(PAL_DATA_REG, p[((*i)-(bmp->offset*3)/*+(aqoffset*3)*/)]); + else{ //outp(PAL_DATA_REG, p[((*i)-(bmp->offset*3)+qp)]); + printf("p[]=%d qp=%d p[]-qp=%d\n", ((*i)-(bmp->offset*3)), qp, ((*i)-(bmp->offset*3))+qp); } } } //if(qp>0) printf("qp=%d\n", qp); - if(qp>0) printf(" (*i)=%d\n", (*i)/3); + //if(qp>0) printf(" (*i)=%d\n", (*i)/3); } modexWaitBorder(); /* waits one retrace -- less flicker */ if((*i)>=PAL_SIZE/2 && w==0) @@ -670,28 +661,25 @@ modexPalUpdate(bitmap_t *bmp, word *i, word qp, word aqoffset) w++; break; } - else if(qp>0 && (*i)>=(qp*3) && (*i)<((qp*3)+3)) + else if(qp>0 && (*i)>=(qp) && (*i)<((qp)+3)) { //printf("qp=%d\n", qp); - //printf(" (*i)=%d\n", (*i)/3); - printf(" (*i)=%d bmp->offset*3=%d (qp*3)=%d\n", (*i), (bmp->offset), (qp)); - printf(" %d's color=%d\n", (*i)/3, ((*i)-(bmp->offset)+(qp*3))); - //printf(" %d's color2=%d\n", (*i)/3, ((*i)-(bmp->offset*3))-(qp*3)); - //outp(PAL_DATA_REG, p[((*i)-(bmp->offset*3))+()]); - (*i)++; - break; + //printf(" (*i)=%d a[%d]=%d\n", (*i), qp, a[qp]); + printf(" %d's color=%d\n", (*i), (a[qp]-(bmp->offset*3)+qp)); + //outp(PAL_DATA_REG, p[((a[qp])-(bmp->offset*3)+qp)]);// fix this shit! + if((*i)+1==(qp)+3){ w++; /*(*i)++;*/ break; } } else { if(qp==0) outp(PAL_DATA_REG, p[(*i)-q]); - else outp(PAL_DATA_REG, p[((*i)-(bmp->offset*3))+(qp*3)]); + else{ //outp(PAL_DATA_REG, p[((*i)-(bmp->offset*3)+qp)]); + printf("p[]=%d qp=%d p[]-qp=%d\n", ((*i)-(bmp->offset*3)), qp, ((*i)-(bmp->offset*3))+qp); } } } //printf(" (*i)=%d\n", (*i)/3); } -// if(q>0) -// printf("2 (*i)=%02d\n", (*i)/3); +printf("\nqqqqqqqq\n\n"); //palette checker~ if(q>0 && qp==0) @@ -704,7 +692,6 @@ modexPalUpdate(bitmap_t *bmp, word *i, word qp, word aqoffset) chkcolor(bmp, &q, &a, &aa, &z, i); //printf("2(*i)=%02d\n", (*i)/3); //printf("2z=%02d\n", z/3); - aq=0; aqpee: while(aq<=aa) @@ -713,7 +700,7 @@ aqpee: if(a[aq]==-1) aq++; else { aqoffset++; break; } } - +//update the image data here! for(lq=0; lqoffset)*bmp->offset - printf("%02d ",bmp->data[lq]+bmp->offset); - if(lq > 0 && lq%bmp->width==0) printf("\n"); + //printf("%02d ",bmp->data[lq]+bmp->offset); + //if(lq > 0 && lq%bmp->width==0) printf("\n"); //printf("%02d_", bmp->data[lq]+bmp->offset); /*if(bmp->data[lq]+bmp->offset==aq) { @@ -778,7 +758,7 @@ aqpee: } void -modexPalUpdate2(byte *p) +modexPalUpdate1(byte *p) { int i; modexWaitBorder(); @@ -795,7 +775,7 @@ modexPalUpdate2(byte *p) } void -modexPalUpdate3(byte *p) +modexPalUpdate0(byte *p) { int i; modexWaitBorder();