X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fmodex16.c;h=e2c95ac95a018d654725758021d594f872f29228;hb=02dd99850b12a31480e011885a8299a0e24f7dd8;hp=c3a808aa7c7913734e536eba307498ea9195df52;hpb=382c52a610e89948ad695a356879daf54653bb4c;p=16.git diff --git a/src/lib/modex16.c b/src/lib/modex16.c index c3a808aa..e2c95ac9 100644 --- a/src/lib/modex16.c +++ b/src/lib/modex16.c @@ -591,34 +591,74 @@ modexPalWhite() { /* utility */ void -modexPalUpdate(bitmap_t *bmp, word *i, word qp) +modexPalUpdate(bitmap_t *bmp, word *i, word qp, word aqoffset) { +//---- static word count=0; byte *p = bmp->palette; word w=0; word q=0; + word qq=0; + //word ii; + static word a[PAL_SIZE/3]; + word z=0, aq=0, aa=0, pp=0; + //sword aqpw; - if(qp>0) printf("(*i)=%02d\n", (*i)/3); - + //printf("1 (*i)=%02d\n", (*i)/3); modexWaitBorder(); - if((*i)==0) outp(PAL_WRITE_REG, 0); /* start at the beginning of palette */ - else if(qp==0) q=(*i);// else outp(PAL_WRITE_REG, (*i)); + if((*i)==0) + { + memset(a, -1, sizeof(a)); + outp(PAL_WRITE_REG, 0); /* start at the beginning of palette */ + } + else if(qp==0) + { + q=(*i); + } + else + { + q=(*i); + qq=(*i)/3; +// 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)-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])) + 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)]); w++; break; } + else if(qp>0 && (*i)>=(qp*3) && (*i)<((qp*3)+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]); + printf(" %d's color=%d\n", (*i), (a[qp]*3)+(aqoffset*3));//+(aqoffset*3) + outp(PAL_DATA_REG, p[(a[qp]*3)+(aqoffset*3)]); + if((*i)+1==(qp*3)+3){ /*(*i)++;*/ break; } + } else { - outp(PAL_DATA_REG, p[(*i)-q]); + 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)*/)]); } } + //if(qp>0) printf("qp=%d\n", qp); + if(qp>0) printf(" (*i)=%d\n", (*i)/3); } modexWaitBorder(); /* waits one retrace -- less flicker */ if((*i)>=PAL_SIZE/2 && w==0) @@ -626,73 +666,198 @@ modexPalUpdate(bitmap_t *bmp, word *i, word qp) 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])) + 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)]); w++; break; } + else if(qp>0 && (*i)>=(qp*3) && (*i)<((qp*3)+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); + 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; + } else { - outp(PAL_DATA_REG, p[(*i)-q]); + if(qp==0) outp(PAL_DATA_REG, p[(*i)-q]); + else outp(PAL_DATA_REG, p[((*i)-(bmp->offset*3))+(qp*3)]); } } + //printf(" (*i)=%d\n", (*i)/3); } +// if(q>0) +// printf("2 (*i)=%02d\n", (*i)/3); //palette checker~ if(q>0 && qp==0) { - static word a[256] = { 0 }; long lq; long bufSize = (bmp->width * bmp->height); + pp = q; + //printf("1(*i)=%02d\n", (*i)/3); + //printf("1z=%02d\n", z/3); + 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) + { +// printf("a[%02d]=(%d)\n", aq, a[aq]); + if(a[aq]==-1) aq++; + else { aqoffset++; break; } + } + + for(lq=0; lqdata[lq]+bmp->offset); + /*if(bmp->data[lq]+bmp->offset==aq) + { + //printf("%02d", bmp->data[lq]); + //printf("\n%02d\n", bmp->offset); + printf("aq=%02d ", aq); + printf("a[aq]=%02d ", a[aq]); + printf("a[aq]+aqpp=%02d ", a[aq]+aqpp); + printf("a[aq]-aqpp=%02d\n", a[aq]-aqpp); + //bmp->data[lq]=((bmp->data[lq]+bmp->offset)-a[aq]); +//++++ bmp->data[lq]=a[aq]-aqpp; +// printf("_%d ", bmp->data[lq]); + //if(lq > 0 && lq%bmp->width==0) printf("\n"); + } + else if(bmp->data[lq]+bmp->offset < ((*i)/3)-aqpp) + { + if(bmp->data[lq]+bmp->offset >= aq) + { + bmp->data[lq]=(bmp->data[lq]+bmp->offset)-aqpp;//-((z-(*i))/3); + //printf("_%d ", bmp->data[lq]+bmp->offset)-aqpp-((z-(*i))/3); + } + else bmp->data[lq]+=(bmp->offset-aqpp); + }*/ + + //printf("%02d`", bmp->data[lq]); + //if(lq > 0 && lq%bmp->width==0) printf("\n"); + } + +//printf(" aq=%02d\n", aq); +//printf(" aa=%02d\n", aa); + + //update the palette~ + modexPalUpdate(bmp, &pp, aq, aqoffset); + (*i)=pp; + + if(aqdata[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