mirror of
https://github.com/holub/mame
synced 2025-05-10 08:12:13 +03:00
crospang.cpp : Updates
Simplify handlers, Fix namings, Move alternative GFX layout into gfxdecode crospang.h : Move most private things under private:
This commit is contained in:
parent
7e2e58c17f
commit
fcfb4108b9
@ -40,15 +40,15 @@
|
||||
|
||||
/* main cpu */
|
||||
|
||||
void crospang_state::crospang_base_map(address_map &map)
|
||||
void crospang_state::base_map(address_map &map)
|
||||
{
|
||||
map(0x000000, 0x0fffff).rom().nopw(); // writes to rom quite often
|
||||
|
||||
map(0x100000, 0x100001).w(FUNC(crospang_state::bestri_tilebank_select_w));
|
||||
map(0x10000e, 0x10000f).w(FUNC(crospang_state::bestri_tilebank_data_w));
|
||||
map(0x100000, 0x100001).w(FUNC(crospang_state::tilebank_select_w));
|
||||
map(0x10000e, 0x10000f).w(FUNC(crospang_state::tilebank_data_w));
|
||||
|
||||
map(0x120000, 0x1207ff).ram().w(FUNC(crospang_state::crospang_fg_videoram_w)).share("fg_videoram");
|
||||
map(0x122000, 0x1227ff).ram().w(FUNC(crospang_state::crospang_bg_videoram_w)).share("bg_videoram");
|
||||
map(0x120000, 0x1207ff).ram().w(FUNC(crospang_state::fg_videoram_w)).share("fg_videoram");
|
||||
map(0x122000, 0x1227ff).ram().w(FUNC(crospang_state::bg_videoram_w)).share("bg_videoram");
|
||||
map(0x200000, 0x2005ff).ram().w("palette", FUNC(palette_device::write16)).share("palette");
|
||||
map(0x210000, 0x2107ff).ram().share("spriteram");
|
||||
map(0x270001, 0x270001).w(m_soundlatch, FUNC(generic_latch_8_device::write));
|
||||
@ -62,31 +62,31 @@ void crospang_state::crospang_base_map(address_map &map)
|
||||
|
||||
void crospang_state::crospang_map(address_map &map)
|
||||
{
|
||||
crospang_base_map(map);
|
||||
base_map(map);
|
||||
|
||||
map(0x100002, 0x100003).w(FUNC(crospang_state::crospang_fg_scrolly_w));
|
||||
map(0x100004, 0x100005).w(FUNC(crospang_state::crospang_bg_scrollx_w));
|
||||
map(0x100006, 0x100007).w(FUNC(crospang_state::crospang_bg_scrolly_w));
|
||||
map(0x100008, 0x100009).w(FUNC(crospang_state::crospang_fg_scrollx_w));
|
||||
map(0x100002, 0x100003).w(FUNC(crospang_state::fg_scrolly_w));
|
||||
map(0x100004, 0x100005).w(FUNC(crospang_state::bg_scrollx_w));
|
||||
map(0x100006, 0x100007).w(FUNC(crospang_state::bg_scrolly_w));
|
||||
map(0x100008, 0x100009).w(FUNC(crospang_state::fg_scrollx_w));
|
||||
|
||||
map(0x320000, 0x32ffff).ram();
|
||||
}
|
||||
|
||||
void crospang_state::pitapat_map(address_map &map)
|
||||
{
|
||||
crospang_base_map(map);
|
||||
base_map(map);
|
||||
|
||||
map(0x100002, 0x100003).w(FUNC(crospang_state::crospang_fg_scrolly_w));
|
||||
map(0x100004, 0x100005).w(FUNC(crospang_state::crospang_bg_scrollx_w));
|
||||
map(0x100006, 0x100007).w(FUNC(crospang_state::crospang_bg_scrolly_w));
|
||||
map(0x100008, 0x100009).w(FUNC(crospang_state::crospang_fg_scrollx_w));
|
||||
map(0x100002, 0x100003).w(FUNC(crospang_state::fg_scrolly_w));
|
||||
map(0x100004, 0x100005).w(FUNC(crospang_state::bg_scrollx_w));
|
||||
map(0x100006, 0x100007).w(FUNC(crospang_state::bg_scrolly_w));
|
||||
map(0x100008, 0x100009).w(FUNC(crospang_state::fg_scrollx_w));
|
||||
|
||||
map(0x300000, 0x30ffff).ram();
|
||||
}
|
||||
|
||||
void crospang_state::bestri_map(address_map &map)
|
||||
{
|
||||
crospang_base_map(map);
|
||||
base_map(map);
|
||||
|
||||
map(0x100004, 0x100005).w(FUNC(crospang_state::bestri_fg_scrollx_w));
|
||||
map(0x100006, 0x100007).w(FUNC(crospang_state::bestri_fg_scrolly_w));
|
||||
@ -98,7 +98,7 @@ void crospang_state::bestri_map(address_map &map)
|
||||
|
||||
void crospang_state::bestria_map(address_map &map)
|
||||
{
|
||||
crospang_base_map(map);
|
||||
base_map(map);
|
||||
|
||||
map(0x100006, 0x100007).w(FUNC(crospang_state::bestri_fg_scrollx_w));
|
||||
map(0x100008, 0x100009).w(FUNC(crospang_state::bestri_fg_scrolly_w));
|
||||
@ -110,13 +110,13 @@ void crospang_state::bestria_map(address_map &map)
|
||||
|
||||
/* sound cpu */
|
||||
|
||||
void crospang_state::crospang_sound_map(address_map &map)
|
||||
void crospang_state::sound_map(address_map &map)
|
||||
{
|
||||
map(0x0000, 0xbfff).rom();
|
||||
map(0xc000, 0xc7ff).ram();
|
||||
}
|
||||
|
||||
void crospang_state::crospang_sound_io_map(address_map &map)
|
||||
void crospang_state::sound_io_map(address_map &map)
|
||||
{
|
||||
map.global_mask(0xff);
|
||||
map(0x00, 0x01).rw("ymsnd", FUNC(ym3812_device::read), FUNC(ym3812_device::write));
|
||||
@ -393,33 +393,42 @@ static const gfx_layout tlayout =
|
||||
RGN_FRAC(1,2),
|
||||
4,
|
||||
{ RGN_FRAC(1,2)+8, RGN_FRAC(1,2)+0, 8, 0 },
|
||||
{ 32*8+0, 32*8+1, 32*8+2, 32*8+3, 32*8+4, 32*8+5, 32*8+6, 32*8+7,
|
||||
0, 1, 2, 3, 4, 5, 6, 7 },
|
||||
{ 0*16, 1*16, 2*16, 3*16, 4*16, 5*16, 6*16, 7*16,
|
||||
8*16, 9*16, 10*16, 11*16, 12*16, 13*16, 14*16, 15*16 },
|
||||
{ STEP8(8*2*16,1), STEP8(0,1) },
|
||||
{ STEP16(0,8*2) },
|
||||
64*8
|
||||
};
|
||||
|
||||
static const gfx_layout tlayout_alt =
|
||||
{
|
||||
16,16,
|
||||
RGN_FRAC(1,2),
|
||||
4,
|
||||
{ 8, 0, RGN_FRAC(1,2)+8, RGN_FRAC(1,2)+0 },
|
||||
{ STEP8(0,1), STEP8(8*2*16,1) },
|
||||
{ STEP16(0,8*2) },
|
||||
64*8
|
||||
};
|
||||
|
||||
|
||||
static GFXDECODE_START( gfx_crospang )
|
||||
GFXDECODE_ENTRY( "gfx2", 0, tlayout, 0, 64 ) /* Tiles 16x16 */
|
||||
GFXDECODE_ENTRY( "gfx1", 0, tlayout, 0, 64 ) /* Sprites 16x16 */
|
||||
GFXDECODE_ENTRY( "gfx2", 0, tlayout, 0, 64 ) /* Sprites 16x16 */
|
||||
GFXDECODE_ENTRY( "gfx1", 0, tlayout_alt, 0, 64 ) /* Tiles 16x16 */
|
||||
GFXDECODE_END
|
||||
|
||||
void crospang_state::machine_start()
|
||||
{
|
||||
save_item(NAME(m_bestri_tilebank));
|
||||
save_item(NAME(m_bestri_tilebankselect));
|
||||
save_item(NAME(m_tilebank));
|
||||
save_item(NAME(m_tilebankselect));
|
||||
}
|
||||
|
||||
void crospang_state::machine_reset()
|
||||
{
|
||||
m_bestri_tilebank[0] = 0x00;
|
||||
m_bestri_tilebank[1] = 0x01;
|
||||
m_bestri_tilebank[2] = 0x02;
|
||||
m_bestri_tilebank[3] = 0x03;
|
||||
m_tilebank[0] = 0x00;
|
||||
m_tilebank[1] = 0x01;
|
||||
m_tilebank[2] = 0x02;
|
||||
m_tilebank[3] = 0x03;
|
||||
|
||||
m_bestri_tilebankselect = 0;
|
||||
m_tilebankselect = 0;
|
||||
}
|
||||
|
||||
void crospang_state::crospang(machine_config &config)
|
||||
@ -430,8 +439,8 @@ void crospang_state::crospang(machine_config &config)
|
||||
m_maincpu->set_vblank_int("screen", FUNC(crospang_state::irq6_line_hold));
|
||||
|
||||
z80_device &audiocpu(Z80(config, "audiocpu", XTAL(14'318'181)/4)); /* 3.579545MHz */
|
||||
audiocpu.set_addrmap(AS_PROGRAM, &crospang_state::crospang_sound_map);
|
||||
audiocpu.set_addrmap(AS_IO, &crospang_state::crospang_sound_io_map);
|
||||
audiocpu.set_addrmap(AS_PROGRAM, &crospang_state::sound_map);
|
||||
audiocpu.set_addrmap(AS_IO, &crospang_state::sound_io_map);
|
||||
|
||||
/* video hardware */
|
||||
screen_device &screen(SCREEN(config, "screen", SCREEN_TYPE_RASTER));
|
||||
@ -439,7 +448,7 @@ void crospang_state::crospang(machine_config &config)
|
||||
screen.set_vblank_time(ATTOSECONDS_IN_USEC(0));
|
||||
screen.set_size(64*8, 64*8);
|
||||
screen.set_visarea(0, 40*8-1, 0, 30*8-1);
|
||||
screen.set_screen_update(FUNC(crospang_state::screen_update_crospang));
|
||||
screen.set_screen_update(FUNC(crospang_state::screen_update));
|
||||
screen.set_palette("palette");
|
||||
|
||||
PALETTE(config, "palette").set_format(palette_device::xRGB_555, 0x300);
|
||||
@ -743,34 +752,9 @@ ROM_START( pitapat )
|
||||
ROM_LOAD16_BYTE( "ud17", 0x080001, 0x40000, CRC(d4c67e2e) SHA1(e684b58333d64f5961983b42f56c61bb0bea2e5c) )
|
||||
ROM_END
|
||||
|
||||
void crospang_state::tumblepb_gfx1_rearrange()
|
||||
{
|
||||
uint8_t *rom = memregion("gfx1")->base();
|
||||
int len = memregion("gfx1")->bytes();
|
||||
int i;
|
||||
|
||||
/* gfx data is in the wrong order */
|
||||
for (i = 0; i < len; i++)
|
||||
{
|
||||
if ((i & 0x20) == 0)
|
||||
{
|
||||
int t = rom[i]; rom[i] = rom[i + 0x20]; rom[i + 0x20] = t;
|
||||
}
|
||||
}
|
||||
/* low/high half are also swapped */
|
||||
for (i = 0; i < len / 2; i++)
|
||||
{
|
||||
int t = rom[i]; rom[i] = rom[i + len / 2]; rom[i + len / 2] = t;
|
||||
}
|
||||
}
|
||||
|
||||
void crospang_state::init_crospang()
|
||||
{
|
||||
tumblepb_gfx1_rearrange();
|
||||
}
|
||||
|
||||
GAME( 1998, crospang, 0, crospang, crospang, crospang_state, init_crospang, ROT0, "F2 System", "Cross Pang", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1997, heuksun, 0, crospang, heuksun, crospang_state, init_crospang, ROT0, "Oksan / F2 System", "Heuk Sun Baek Sa (Korea)", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1998, bestri, 0, bestri, bestri, crospang_state, init_crospang, ROT0, "F2 System", "Bestri (Korea, set 1)", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1998, bestria, bestri, bestria, bestri, crospang_state, init_crospang, ROT0, "F2 System", "Bestri (Korea, set 2)", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1997, pitapat, 0, pitapat, pitapat, crospang_state, init_crospang, ROT0, "F2 System", "Pitapat Puzzle", MACHINE_SUPPORTS_SAVE ) // Test Mode calls it 'Puzzle Ball'
|
||||
GAME( 1998, crospang, 0, crospang, crospang, crospang_state, empty_init, ROT0, "F2 System", "Cross Pang", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1997, heuksun, 0, crospang, heuksun, crospang_state, empty_init, ROT0, "Oksan / F2 System", "Heuk Sun Baek Sa (Korea)", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1998, bestri, 0, bestri, bestri, crospang_state, empty_init, ROT0, "F2 System", "Bestri (Korea, set 1)", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1998, bestria, bestri, bestria, bestri, crospang_state, empty_init, ROT0, "F2 System", "Bestri (Korea, set 2)", MACHINE_SUPPORTS_SAVE )
|
||||
GAME( 1997, pitapat, 0, pitapat, pitapat, crospang_state, empty_init, ROT0, "F2 System", "Pitapat Puzzle", MACHINE_SUPPORTS_SAVE ) // Test Mode calls it 'Puzzle Ball'
|
||||
|
@ -27,16 +27,27 @@ public:
|
||||
, m_soundlatch(*this, "soundlatch")
|
||||
{ }
|
||||
|
||||
void crospang(machine_config &config);
|
||||
void bestri(machine_config &config);
|
||||
void bestria(machine_config &config);
|
||||
void pitapat(machine_config &config);
|
||||
|
||||
protected:
|
||||
virtual void machine_start() override;
|
||||
virtual void machine_reset() override;
|
||||
virtual void video_start() override;
|
||||
|
||||
private:
|
||||
/* memory pointers */
|
||||
required_shared_ptr<uint16_t> m_fg_videoram;
|
||||
required_shared_ptr<uint16_t> m_bg_videoram;
|
||||
required_shared_ptr<uint16_t> m_spriteram;
|
||||
required_shared_ptr<u16> m_fg_videoram;
|
||||
required_shared_ptr<u16> m_bg_videoram;
|
||||
required_shared_ptr<u16> m_spriteram;
|
||||
|
||||
/* video-related */
|
||||
tilemap_t *m_bg_layer;
|
||||
tilemap_t *m_fg_layer;
|
||||
uint8_t m_bestri_tilebank[4];
|
||||
uint8_t m_bestri_tilebankselect;
|
||||
u8 m_tilebank[4];
|
||||
u8 m_tilebankselect;
|
||||
|
||||
/* devices */
|
||||
required_device<cpu_device> m_maincpu;
|
||||
@ -44,37 +55,28 @@ public:
|
||||
required_device<gfxdecode_device> m_gfxdecode;
|
||||
required_device<generic_latch_8_device> m_soundlatch;
|
||||
|
||||
DECLARE_WRITE16_MEMBER(bestri_tilebank_data_w);
|
||||
DECLARE_WRITE16_MEMBER(bestri_tilebank_select_w);
|
||||
DECLARE_WRITE16_MEMBER(bestri_bg_scrolly_w);
|
||||
DECLARE_WRITE16_MEMBER(bestri_fg_scrolly_w);
|
||||
DECLARE_WRITE16_MEMBER(bestri_fg_scrollx_w);
|
||||
DECLARE_WRITE16_MEMBER(bestri_bg_scrollx_w);
|
||||
DECLARE_WRITE16_MEMBER(crospang_fg_scrolly_w);
|
||||
DECLARE_WRITE16_MEMBER(crospang_bg_scrolly_w);
|
||||
DECLARE_WRITE16_MEMBER(crospang_fg_scrollx_w);
|
||||
DECLARE_WRITE16_MEMBER(crospang_bg_scrollx_w);
|
||||
DECLARE_WRITE16_MEMBER(crospang_fg_videoram_w);
|
||||
DECLARE_WRITE16_MEMBER(crospang_bg_videoram_w);
|
||||
void init_crospang();
|
||||
void tilebank_data_w(u16 data);
|
||||
void tilebank_select_w(u16 data);
|
||||
void bestri_bg_scrolly_w(u16 data);
|
||||
void bestri_fg_scrolly_w(u16 data);
|
||||
void bestri_fg_scrollx_w(u16 data);
|
||||
void bestri_bg_scrollx_w(u16 data);
|
||||
void fg_scrolly_w(u16 data);
|
||||
void bg_scrolly_w(u16 data);
|
||||
void fg_scrollx_w(u16 data);
|
||||
void bg_scrollx_w(u16 data);
|
||||
void fg_videoram_w(offs_t offset, u16 data, u16 mem_mask = ~0);
|
||||
void bg_videoram_w(offs_t offset, u16 data, u16 mem_mask = ~0);
|
||||
TILE_GET_INFO_MEMBER(get_bg_tile_info);
|
||||
TILE_GET_INFO_MEMBER(get_fg_tile_info);
|
||||
virtual void machine_start() override;
|
||||
virtual void machine_reset() override;
|
||||
virtual void video_start() override;
|
||||
uint32_t screen_update_crospang(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
|
||||
void tumblepb_gfx1_rearrange();
|
||||
void crospang(machine_config &config);
|
||||
void bestri(machine_config &config);
|
||||
void bestria(machine_config &config);
|
||||
void pitapat(machine_config &config);
|
||||
u32 screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect);
|
||||
void base_map(address_map &map);
|
||||
void bestri_map(address_map &map);
|
||||
void bestria_map(address_map &map);
|
||||
void pitapat_map(address_map &map);
|
||||
void crospang_base_map(address_map &map);
|
||||
void crospang_map(address_map &map);
|
||||
void crospang_sound_io_map(address_map &map);
|
||||
void crospang_sound_map(address_map &map);
|
||||
void pitapat_map(address_map &map);
|
||||
void sound_io_map(address_map &map);
|
||||
void sound_map(address_map &map);
|
||||
};
|
||||
|
||||
#endif // MAME_INCLUDES_CROSPANG_H
|
||||
|
@ -15,19 +15,19 @@
|
||||
#include "includes/crospang.h"
|
||||
|
||||
|
||||
WRITE16_MEMBER(crospang_state::bestri_tilebank_select_w)
|
||||
void crospang_state::tilebank_select_w(u16 data)
|
||||
{
|
||||
logerror("bestri_tilebank_select_w %04x\n", data & mem_mask);
|
||||
logerror("tilebank_select_w %04x\n", data);
|
||||
|
||||
m_bestri_tilebankselect = (data >> 8) & 3;
|
||||
m_tilebankselect = (data >> 8) & 3;
|
||||
}
|
||||
|
||||
|
||||
WRITE16_MEMBER(crospang_state::bestri_tilebank_data_w)
|
||||
void crospang_state::tilebank_data_w(u16 data)
|
||||
{
|
||||
logerror("bestri_tilebank_data_w %04x\n", data & mem_mask);
|
||||
logerror("tilebank_data_w %04x\n", data);
|
||||
|
||||
m_bestri_tilebank[m_bestri_tilebankselect] = data >> 8;
|
||||
m_tilebank[m_tilebankselect] = data >> 8;
|
||||
|
||||
m_fg_layer->mark_all_dirty();
|
||||
m_bg_layer->mark_all_dirty();
|
||||
@ -35,7 +35,7 @@ WRITE16_MEMBER(crospang_state::bestri_tilebank_data_w)
|
||||
|
||||
|
||||
// Bestri performs some unusual operations on the scroll values before writing them
|
||||
WRITE16_MEMBER(crospang_state::bestri_bg_scrolly_w)
|
||||
void crospang_state::bestri_bg_scrolly_w(u16 data)
|
||||
{
|
||||
// addi.w #$1f8, D0
|
||||
// eori.w #$154, D0
|
||||
@ -43,7 +43,7 @@ WRITE16_MEMBER(crospang_state::bestri_bg_scrolly_w)
|
||||
m_bg_layer->set_scrolly(0, -scroll + 7);
|
||||
}
|
||||
|
||||
WRITE16_MEMBER(crospang_state::bestri_fg_scrolly_w)
|
||||
void crospang_state::bestri_fg_scrolly_w(u16 data)
|
||||
{
|
||||
// addi.w #$1f8, D0
|
||||
// eori.w #$aa, D0
|
||||
@ -51,7 +51,7 @@ WRITE16_MEMBER(crospang_state::bestri_fg_scrolly_w)
|
||||
m_fg_layer->set_scrolly(0, -scroll + 7);
|
||||
}
|
||||
|
||||
WRITE16_MEMBER(crospang_state::bestri_fg_scrollx_w)
|
||||
void crospang_state::bestri_fg_scrollx_w(u16 data)
|
||||
{
|
||||
// addi.w #$400, D1
|
||||
// eori.w #$1e0, D1
|
||||
@ -59,7 +59,7 @@ WRITE16_MEMBER(crospang_state::bestri_fg_scrollx_w)
|
||||
m_fg_layer->set_scrollx(0, scroll - 1);
|
||||
}
|
||||
|
||||
WRITE16_MEMBER(crospang_state::bestri_bg_scrollx_w)
|
||||
void crospang_state::bestri_bg_scrollx_w(u16 data)
|
||||
{
|
||||
// addi.w #$3fc, D1
|
||||
// eori.w #$3c0, D1
|
||||
@ -68,34 +68,34 @@ WRITE16_MEMBER(crospang_state::bestri_bg_scrollx_w)
|
||||
}
|
||||
|
||||
|
||||
WRITE16_MEMBER(crospang_state::crospang_fg_scrolly_w)
|
||||
void crospang_state::fg_scrolly_w(u16 data)
|
||||
{
|
||||
m_fg_layer->set_scrolly(0, data + 8);
|
||||
}
|
||||
|
||||
WRITE16_MEMBER(crospang_state::crospang_bg_scrolly_w)
|
||||
void crospang_state::bg_scrolly_w(u16 data)
|
||||
{
|
||||
m_bg_layer->set_scrolly(0, data + 8);
|
||||
}
|
||||
|
||||
WRITE16_MEMBER(crospang_state::crospang_fg_scrollx_w)
|
||||
void crospang_state::fg_scrollx_w(u16 data)
|
||||
{
|
||||
m_fg_layer->set_scrollx(0, data);
|
||||
}
|
||||
|
||||
WRITE16_MEMBER(crospang_state::crospang_bg_scrollx_w)
|
||||
void crospang_state::bg_scrollx_w(u16 data)
|
||||
{
|
||||
m_bg_layer->set_scrollx(0, data + 4);
|
||||
}
|
||||
|
||||
|
||||
WRITE16_MEMBER(crospang_state::crospang_fg_videoram_w)
|
||||
void crospang_state::fg_videoram_w(offs_t offset, u16 data, u16 mem_mask)
|
||||
{
|
||||
COMBINE_DATA(&m_fg_videoram[offset]);
|
||||
m_fg_layer->mark_tile_dirty(offset);
|
||||
}
|
||||
|
||||
WRITE16_MEMBER(crospang_state::crospang_bg_videoram_w)
|
||||
void crospang_state::bg_videoram_w(offs_t offset, u16 data, u16 mem_mask)
|
||||
{
|
||||
COMBINE_DATA(&m_bg_videoram[offset]);
|
||||
m_bg_layer->mark_tile_dirty(offset);
|
||||
@ -106,7 +106,7 @@ TILE_GET_INFO_MEMBER(crospang_state::get_bg_tile_info)
|
||||
int data = m_bg_videoram[tile_index];
|
||||
int tile = data & 0x03ff;
|
||||
int tilebank = (data & 0x0c00) >> 10;
|
||||
tile = tile + (m_bestri_tilebank[tilebank] << 10);
|
||||
tile = tile + (m_tilebank[tilebank] << 10);
|
||||
int color = (data >> 12) & 0x0f;
|
||||
|
||||
SET_TILE_INFO_MEMBER(1, tile, color + 0x20, 0);
|
||||
@ -117,7 +117,7 @@ TILE_GET_INFO_MEMBER(crospang_state::get_fg_tile_info)
|
||||
int data = m_fg_videoram[tile_index];
|
||||
int tile = data & 0x03ff;
|
||||
int tilebank = (data & 0x0c00) >> 10;
|
||||
tile = tile + (m_bestri_tilebank[tilebank] << 10);
|
||||
tile = tile + (m_tilebank[tilebank] << 10);
|
||||
int color = (data >> 12) & 0x0f;
|
||||
|
||||
SET_TILE_INFO_MEMBER(1, tile, color + 0x10, 0);
|
||||
@ -132,7 +132,7 @@ void crospang_state::video_start()
|
||||
m_fg_layer->set_transparent_pen(0);
|
||||
}
|
||||
|
||||
uint32_t crospang_state::screen_update_crospang(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
|
||||
u32 crospang_state::screen_update(screen_device &screen, bitmap_ind16 &bitmap, const rectangle &cliprect)
|
||||
{
|
||||
m_bg_layer->draw(screen, bitmap, cliprect, 0, 0);
|
||||
m_fg_layer->draw(screen, bitmap, cliprect, 0, 0);
|
||||
|
Loading…
Reference in New Issue
Block a user