Improved bg gfxs in Super Crowns Golf, needs to move the bg drawing function from VIDEO_UPDATE to handler +

This commit is contained in:
Angelo Salese 2009-05-30 19:23:48 +00:00
parent 818b17bc13
commit 5cc50b43a9

View File

@ -69,7 +69,7 @@ static WRITE8_HANDLER( rom2_bank_select_w )
static MACHINE_RESET( suprgolf ) static MACHINE_RESET( suprgolf )
{ {
msm_nmi_mask = 0;
} }
static VIDEO_START( suprgolf ) static VIDEO_START( suprgolf )
@ -87,6 +87,7 @@ static void bg_draw(running_machine *machine, bitmap_t *bitmap, const rectangle
{ {
int x,y,trans; int x,y,trans;
UINT32 count; UINT32 count;
UINT16 alpha_val;
count = starting_offs<<16; count = starting_offs<<16;
trans = starting_offs; trans = starting_offs;
@ -97,33 +98,52 @@ static void bg_draw(running_machine *machine, bitmap_t *bitmap, const rectangle
{ {
UINT16 color; UINT16 color;
color = ((suprgolf_bg_pen[count] & 0xff)<<4) | ((suprgolf_bg_vram[count] & 0xf0)>>4); color = ((suprgolf_bg_vram[count] & 0xf0)>>4);
//color+= ((suprgolf_bg_pen[count+0x10000])<<4);
//if((x)<video_screen_get_visible_area(machine)->max_x && ((y)+0)<video_screen_get_visible_area(machine)->max_y) if(suprgolf_bg_pen[count] & 0x80)
if(x+1 < 256) color |= ((suprgolf_bg_pen[count] & 0x7f)<<4);
else
{
/* TODO */
color |= ((suprgolf_bg_pen[count] & 0x7f)<<4);
//color |= 0x73<<4;//((suprgolf_bg_vram[count+0x10000] & 0x0f)<<4);
}
alpha_val = 0;//(paletteram[color*2]+256*paletteram[color*2+1]) & 0x8000;
if((x+1) >= 0 && (x+1) < 256 && (!(alpha_val)))
{ {
if(trans) if(trans)
{ {
if((suprgolf_bg_vram[count] & 0xf0) != 0xf0) if((suprgolf_bg_vram[count] & 0xf0) != 0xf0)
*BITMAP_ADDR32(bitmap, y, x+1) = machine->pens[(color & 0x7ff)]; *BITMAP_ADDR16(bitmap, y, (x+1)) = machine->pens[(color & 0x7ff)];
} }
else else
*BITMAP_ADDR32(bitmap, y, x+1) = machine->pens[(color & 0x7ff)]; *BITMAP_ADDR16(bitmap, y, (x+1)) = machine->pens[(color & 0x7ff)];
} }
color = ((suprgolf_bg_pen[count] & 0xff)<<4) | (suprgolf_bg_vram[count] & 0x0f); color = (suprgolf_bg_vram[count] & 0x0f);
//color+= ((suprgolf_bg_pen[count+0x10000])<<4);
//if((x+1)<video_screen_get_visible_area(screen)->max_x && ((y)+0)<video_screen_get_visible_area(screen)->max_y) if(suprgolf_bg_pen[count] & 0x80)
if(x < 256) color |= ((suprgolf_bg_pen[count] & 0x7f)<<4);
else
{
/* TODO */
color |= ((suprgolf_bg_pen[count] & 0x7f)<<4);
//color |= 0x73<<4;//((suprgolf_bg_vram[count+0x10000] & 0x0f)<<4);
}
alpha_val = 0;//(paletteram[color*2]+256*paletteram[color*2+1]) & 0x8000;
if(x >= 0 && x < 256 && (!(alpha_val)))
{ {
if(trans) if(trans)
{ {
if((suprgolf_bg_vram[count] & 0x0f) != 0x0f) if((suprgolf_bg_vram[count] & 0x0f) != 0x0f)
*BITMAP_ADDR32(bitmap, y, x) = machine->pens[(color & 0x7ff)]; *BITMAP_ADDR16(bitmap, y, x) = machine->pens[(color & 0x7ff)];
} }
else else
*BITMAP_ADDR32(bitmap, y, x) = machine->pens[(color & 0x7ff)]; *BITMAP_ADDR16(bitmap, y, x) = machine->pens[(color & 0x7ff)];
} }
count++; count++;
@ -133,11 +153,11 @@ static void bg_draw(running_machine *machine, bitmap_t *bitmap, const rectangle
static VIDEO_UPDATE( suprgolf ) static VIDEO_UPDATE( suprgolf )
{ {
bitmap_fill(bitmap, cliprect, get_black_pen(screen->machine));
bg_draw(screen->machine,bitmap,cliprect,0); bg_draw(screen->machine,bitmap,cliprect,0);
//bg_draw(screen->machine,bitmap,cliprect,1);
bg_draw(screen->machine,bitmap,cliprect,2); //this probably should be putted over the fg tilemap too.
tilemap_draw(bitmap,cliprect,suprgolf_tilemap,0,0); tilemap_draw(bitmap,cliprect,suprgolf_tilemap,0,0);
bg_draw(screen->machine,bitmap,cliprect,2);
return 0; return 0;
} }
@ -160,9 +180,9 @@ static WRITE8_HANDLER( suprgolf_videoram_w )
offset>>=1; offset>>=1;
datax=paletteram[offset*2]+256*paletteram[offset*2+1]; datax=paletteram[offset*2]+256*paletteram[offset*2+1];
b=(datax & 0x8000) ? 0 : ((datax)&0x001f)>>0; b = (datax & 0x8000) ? 0 : ((datax)&0x001f)>>0;
g=(datax & 0x8000) ? 0 : ((datax)&0x03e0)>>5; g = (datax & 0x8000) ? 0 : ((datax)&0x03e0)>>5;
r=(datax & 0x8000) ? 0 : ((datax)&0x7c00)>>10; r = (datax & 0x8000) ? 0 : ((datax)&0x7c00)>>10;
palette_set_color_rgb(space->machine, offset, pal5bit(r), pal5bit(g), pal5bit(b)); palette_set_color_rgb(space->machine, offset, pal5bit(r), pal5bit(g), pal5bit(b));
} }
@ -199,7 +219,7 @@ static READ8_HANDLER( suprgolf_bg_vram_r )
static WRITE8_HANDLER( suprgolf_bg_vram_w ) static WRITE8_HANDLER( suprgolf_bg_vram_w )
{ {
suprgolf_bg_vram[offset+suprgolf_bg_bank*0x2000] = data; suprgolf_bg_vram[offset+suprgolf_bg_bank*0x2000] = data;
suprgolf_bg_pen[offset+suprgolf_bg_bank*0x2000] = data ? pen : 0; suprgolf_bg_pen[offset+suprgolf_bg_bank*0x2000] = pen;
} }
/* maybe bit 7 isn't actually for the pen? */ /* maybe bit 7 isn't actually for the pen? */
@ -466,7 +486,7 @@ static MACHINE_DRIVER_START( suprgolf )
MDRV_SCREEN_ADD("screen", RASTER) MDRV_SCREEN_ADD("screen", RASTER)
MDRV_SCREEN_REFRESH_RATE(60) MDRV_SCREEN_REFRESH_RATE(60)
MDRV_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500) /* not accurate */) MDRV_SCREEN_VBLANK_TIME(ATTOSECONDS_IN_USEC(2500) /* not accurate */)
MDRV_SCREEN_FORMAT(BITMAP_FORMAT_RGB32) MDRV_SCREEN_FORMAT(BITMAP_FORMAT_INDEXED16)
MDRV_SCREEN_SIZE(256, 256) MDRV_SCREEN_SIZE(256, 256)
MDRV_SCREEN_VISIBLE_AREA(0, 255, 0, 191) MDRV_SCREEN_VISIBLE_AREA(0, 255, 0, 191)