Fixed a bug with scrolling on 16-color text backgrounds.

Fixed a possible bug with 3D layer scrolling.
This commit is contained in:
luigi__ 2009-01-16 20:35:40 +00:00
parent 519711e6f8
commit 171b4aeeba
1 changed files with 25 additions and 18 deletions

View File

@ -1084,7 +1084,9 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u8 * dst, u32 Y, u16 XBG, u16 Y
struct _DISPCNT *dispCnt = &(gpu->dispx_st)->dispx_DISPCNT.bits; struct _DISPCNT *dispCnt = &(gpu->dispx_st)->dispx_DISPCNT.bits;
u16 lg = gpu->BGSize[num][0]; u16 lg = gpu->BGSize[num][0];
u16 ht = gpu->BGSize[num][1]; u16 ht = gpu->BGSize[num][1];
u16 tmp = ((YBG&(ht-1))>>3); u16 wmask = (lg-1);
u16 hmask = (ht-1);
u16 tmp = ((YBG & hmask) >> 3);
u8 *map = NULL; u8 *map = NULL;
u8 *tile, *pal, *line; u8 *tile, *pal, *line;
u16 color; u16 color;
@ -1110,14 +1112,14 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u8 * dst, u32 Y, u16 XBG, u16 Y
if(tmp>31) if(tmp>31)
tmp_map+= ADDRESS_STEP_512B << bgCnt->ScreenSize ; tmp_map+= ADDRESS_STEP_512B << bgCnt->ScreenSize ;
map = (u8 *)MMU_RenderMapToLCD(tmp_map); map = (u8*)MMU_RenderMapToLCD(tmp_map);
if(!map) return; // no map if(!map) return; // no map
tile = (u8*) MMU_RenderMapToLCD(gpu->BG_tile_ram[num]); tile = (u8*) MMU_RenderMapToLCD(gpu->BG_tile_ram[num]);
if(!tile) return; // no tiles if(!tile) return; // no tiles
xoff = XBG; xoff = XBG;
pal = ARM9Mem.ARM9_VMEM + gpu->core * ADDRESS_STEP_1KB ; pal = ARM9Mem.ARM9_VMEM + gpu->core * ADDRESS_STEP_1KB;
if(!bgCnt->Palette_256) // color: 16 palette entries if(!bgCnt->Palette_256) // color: 16 palette entries
{ {
@ -1192,7 +1194,7 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u8 * dst, u32 Y, u16 XBG, u16 Y
for(x = 0; x < LG; xfin = std::min<u16>(x+8, LG)) for(x = 0; x < LG; xfin = std::min<u16>(x+8, LG))
{ {
u16 tilePalette = 0; u16 tilePalette = 0;
tmp = ((xoff&(lg-1))>>3); tmp = ((xoff&wmask)>>3);
mapinfo = map + (tmp&0x1F) * 2; mapinfo = map + (tmp&0x1F) * 2;
if(tmp>31) mapinfo += 32*32*2; if(tmp>31) mapinfo += 32*32*2;
tileentry.val = T1ReadWord(mapinfo, 0); tileentry.val = T1ReadWord(mapinfo, 0);
@ -1208,12 +1210,15 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u8 * dst, u32 Y, u16 XBG, u16 Y
{ {
u8 currLine = *line; u8 currLine = *line;
if (currLine>>4) if(!(xoff&1))
{ {
color = T1ReadWord(pal, ((currLine>>4) + tilePalette) << 1); if (currLine>>4)
gpu->setFinalColorBck(gpu,0,num,dst,color,x); {
color = T1ReadWord(pal, ((currLine>>4) + tilePalette) << 1);
gpu->setFinalColorBck(gpu,0,num,dst,color,x);
}
dst += 2; x++; xoff++;
} }
dst += 2; x++; xoff++;
if (currLine&0xF) if (currLine&0xF)
{ {
@ -1228,13 +1233,16 @@ INLINE void renderline_textBG(GPU * gpu, u8 num, u8 * dst, u32 Y, u16 XBG, u16 Y
{ {
u8 currLine = *line; u8 currLine = *line;
if (currLine&0xF) if(!(xoff&1))
{ {
color = T1ReadWord(pal, ((currLine&0xF) + tilePalette) << 1); if (currLine&0xF)
gpu->setFinalColorBck(gpu,0,num,dst,color,x); {
} color = T1ReadWord(pal, ((currLine&0xF) + tilePalette) << 1);
gpu->setFinalColorBck(gpu,0,num,dst,color,x);
}
dst += 2; x++; xoff++; dst += 2; x++; xoff++;
}
if (currLine>>4) if (currLine>>4)
{ {
@ -2513,13 +2521,12 @@ static void GPU_ligne_layer(NDS_Screen * screen, u16 l)
gpu3D->NDS_3D_GetLine(l, 0, 255, line3Dcolor, line3Dalpha); gpu3D->NDS_3D_GetLine(l, 0, 255, line3Dcolor, line3Dalpha);
for(int k = 0, q = hofs; k < 256; k++) for(int k = 0, q = 0; k < 256; k++)
{ {
q = ((k + hofs) & 0x1FF);
if(line3Dcolor[q] & 0x8000) if(line3Dcolor[q] & 0x8000)
gpu->setFinalColor3D(gpu, (k << 1), dst, line3Dcolor[q], line3Dalpha[q], k); gpu->setFinalColor3D(gpu, (k << 1), dst, line3Dcolor[q], line3Dalpha[q], k);
q++;
q &= 0x1FF;
} }
continue; continue;