X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Fmodex16.c;h=c3a808aa7c7913734e536eba307498ea9195df52;hb=382c52a610e89948ad695a356879daf54653bb4c;hp=83c2278827869163ee9edd97581b7cea999f9650;hpb=cc5df35b6ba3d7871eac6734822464c7e176f4b7;p=16.git diff --git a/src/lib/modex16.c b/src/lib/modex16.c index 83c22788..c3a808aa 100644 --- a/src/lib/modex16.c +++ b/src/lib/modex16.c @@ -591,55 +591,212 @@ modexPalWhite() { /* utility */ void -modexPalUpdate(byte *p, word *i) +modexPalUpdate(bitmap_t *bmp, word *i, word qp) { + byte *p = bmp->palette; word w=0; word q=0; + + if(qp>0) printf("(*i)=%02d\n", (*i)/3); + modexWaitBorder(); if((*i)==0) outp(PAL_WRITE_REG, 0); /* start at the beginning of palette */ - else q=(*i); + else if(qp==0) q=(*i);// else outp(PAL_WRITE_REG, (*i)); if((*i)0)&&((*i)-q)%3==0 && (p[((*i)-q)]==p[((*i)-q)+3] && p[((*i)-q)+1]==p[((*i)-q)+4] && p[((*i)-q)+2]==p[((*i)-q)+5])) outp(PAL_DATA_REG, p[(*i)-q]); else if(((*i)-q)%3==0 && (p[((*i)-q)]==p[((*i)-q)+3] && p[((*i)-q)+1]==p[((*i)-q)+4] && p[((*i)-q)+2]==p[((*i)-q)+5])) { // printf("[%d]", p[((*i)-q)]); printf("[%d]", p[((*i)-q)+1]); printf("[%d]", p[((*i)-q)+2]); printf("[%d]", p[((*i)-q)+3]); printf("[%d]", p[((*i)-q)+4]); printf("[%d]", p[((*i)-q)+5]); printf(" %d [%d]\n", (*i), p[((*i)-q)]); - //printf(" 1st break\n"); w++; - //(*i)=(*i)+3; break; } else { outp(PAL_DATA_REG, p[(*i)-q]); -// if((*i)>(88*3)) printf(" %d %d\n", (*i), p[(*i)]); } } } modexWaitBorder(); /* waits one retrace -- less flicker */ if((*i)>=PAL_SIZE/2 && w==0) { - //printf(" 2nd half\n"); for(; (*i)0)&&((*i)-q)%3==0 && (p[((*i)-q)]==p[((*i)-q)+3] && p[((*i)-q)+1]==p[((*i)-q)+4] && p[((*i)-q)+2]==p[((*i)-q)+5])) outp(PAL_DATA_REG, p[(*i)-q]); else if(((*i)-q)%3==0 && (p[((*i)-q)]==p[((*i)-q)+3] && p[((*i)-q)+1]==p[((*i)-q)+4] && p[((*i)-q)+2]==p[((*i)-q)+5])) { // printf("[%d]", p[((*i)-q)]); printf("[%d]", p[((*i)-q)+1]); printf("[%d]", p[((*i)-q)+2]); printf("[%d]", p[((*i)-q)+3]); printf("[%d]", p[((*i)-q)+4]); printf("[%d]", p[((*i)-q)+5]); printf(" %d [%d]\n", (*i), p[((*i)-q)]); - //printf(" 1st break\n"); w++; - //(*i)=(*i)+3; break; } else { outp(PAL_DATA_REG, p[(*i)-q]); -// if((*i)>(88*3)) printf(" %d %d\n", (*i), p[(*i)]); } } } + + + //palette checker~ + if(q>0 && qp==0) + { + static word a[256] = { 0 }; + long lq; + long bufSize = (bmp->width * bmp->height); + byte *pal; + word z, zz=0,aq=0,aa=0,pp=0,aqpp=0,spee=0,ppp=0; + pal = modexNewPal(); + modexPalSave(pal); + //q-=3; + printf("q: %02d\n", (q/3)); + //check palette for dups + for(z=0; zdata[lq]+bmp->offset==aq) + { + //printf("%02d", bmp->data[lq]); + //printf("\n%02d\n", bmp->offset); + //printf("%02d\n", a[aq]); + bmp->data[lq]=((bmp->data[lq]+bmp->offset)-a[aq]); + } + else if(bmp->data[lq]+bmp->offset < z/3){ bmp->data[lq]+=bmp->offset; } + //printf("%02d ", bmp->data[lq]); + //if(lq > 0 && lq%bmp->width==0) printf("\n"); + } + +// if(spee==0) +// { + while(pp<=aqpp) + { + //if(pp<(z-1)) + /*printf("pp=%02d ", pp/3); + printf("bmp: [%d]", bmp->palette[pp-q]); + printf("[%d]", bmp->palette[(pp-q)+1]); + printf("[%d]\n", bmp->palette[(pp-q)+2]);*/ + if(((pp/3)==aq || spee>0)) + { + printf("spee=%d\n", spee); + printf(" pp=%02d ", pp/3); + printf("old bmp: [%d]", bmp->palette[(pp-ppp)]); + printf("[%d]", bmp->palette[(pp-ppp)+1]); + printf("[%d]\n", bmp->palette[(pp-ppp)+2]); + //if(spee==0) printf("\npp=%02d\n\n", pp/3); + bmp->palette[(pp-ppp)]= bmp->palette[(pp-ppp)+3]; + bmp->palette[(pp-ppp)+1]= bmp->palette[(pp-ppp)+4]; + bmp->palette[(pp-ppp)+2]= bmp->palette[(pp-ppp)+5]; + if(spee==0) spee++; + } +/* bmp->palette[pp]= bmp->palette[pp+3]; + bmp->palette[pp+1]= bmp->palette[pp+4]; + bmp->palette[pp+2]= bmp->palette[pp+5];*/ + printf(" pp=%02d ", pp/3); + printf(" bmp: [%d]", bmp->palette[(pp-ppp)]); + printf("[%d]", bmp->palette[(pp-ppp)+1]); + printf("[%d]\n", bmp->palette[(pp-ppp)+2]); +/* printf("bmp: [%d]", bmp->palette[pp]); + printf("[%d]", bmp->palette[pp+1]); + printf("[%d]\n", bmp->palette[pp+2]);*/ + //aqpp=(pp-q); + //else if(pp==(z-1)) bmp->palette[pp]=0; + pp+=3; + } +// spee++; + printf("aqpp= %02d\n", aqpp/3); + //printf("&aqpp= %02d\n", &aqpp); + //printf("q= %02d\n", q/3); + //printf("z= %02d\n", z/3); + //printf("&q= %02d\n", &q); + //modexPalUpdate(bmp, &q, 1); + //modexPalUpdate(bmp, &, 1); +// if(pp<=aqpp) + //modexPalUpdate(bmp, &ppp, 1); + modexPalUpdate(bmp, 0, 1); +// } + +// modexPalUpdate(bmp, 0, 1); + + if(aq