mirror of
https://github.com/italicsjenga/gba.git
synced 2025-01-13 20:26:10 +11:00
More tiled data types
This commit is contained in:
parent
c440be7467
commit
0f1fa8269f
|
@ -2,40 +2,102 @@
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
/// An 8x8 tile with 4bpp
|
// Note(Lokathor): We've got several newtypes here that don't use the `newtype!`
|
||||||
#[derive(Debug, Clone, Copy, Default)]
|
// macro because it's insufficient at parsing array types being wrapped.
|
||||||
#[repr(transparent)]
|
|
||||||
pub struct Tile4bpp {
|
newtype! {
|
||||||
pub data: [u32; 8],
|
/// An 8x8 tile with 4bpp, packed as `u32` values for proper alignment.
|
||||||
|
#[derive(Debug, Clone, Copy, Default)]
|
||||||
|
Tile4bpp, pub [u32; 8], no frills
|
||||||
}
|
}
|
||||||
|
|
||||||
/// An 8x8 tile with 8bpp
|
newtype! {
|
||||||
#[derive(Debug, Clone, Copy, Default)]
|
/// An 8x8 tile with 8bpp, packed as `u32` values for proper alignment.
|
||||||
#[repr(transparent)]
|
#[derive(Debug, Clone, Copy, Default)]
|
||||||
pub struct Tile8bpp {
|
Tile8bpp, pub [u32; 16], no frills
|
||||||
pub data: [u32; 16],
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A charblock of 4bpp tiles
|
newtype! {
|
||||||
#[derive(Clone, Copy)]
|
/// A 4bpp charblock has 512 tiles in it
|
||||||
#[repr(transparent)]
|
#[derive(Clone, Copy)]
|
||||||
pub struct Charblock4bpp {
|
Charblock4bpp, pub [Tile4bpp; 512], no frills
|
||||||
pub data: [Tile4bpp; 512],
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A charblock of 8bpp tiles
|
newtype! {
|
||||||
#[derive(Clone, Copy)]
|
/// An 8bpp charblock has 256 tiles in it
|
||||||
#[repr(transparent)]
|
#[derive(Clone, Copy)]
|
||||||
pub struct Charblock8bpp {
|
Charblock8bpp, pub [Tile4bpp; 256], no frills
|
||||||
pub data: [Tile8bpp; 256],
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, Default)]
|
newtype! {
|
||||||
#[repr(transparent)]
|
/// A screenblock entry for use in Text mode.
|
||||||
pub struct TextScreenblockEntry(u16);
|
#[derive(Debug, Clone, Copy, Default)]
|
||||||
|
TextScreenblockEntry, u16
|
||||||
#[derive(Clone, Copy)]
|
|
||||||
#[repr(transparent)]
|
|
||||||
pub struct TextScreenblock {
|
|
||||||
pub data: [TextScreenblockEntry; 32 * 32],
|
|
||||||
}
|
}
|
||||||
|
impl TextScreenblockEntry {
|
||||||
|
pub const fn from_tile_index(index: u16) -> Self {
|
||||||
|
TextScreenblockEntry(index & Self::TILE_INDEX_MASK)
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
|
||||||
|
pub const TILE_INDEX_MASK: u16 = 0xA - 1;
|
||||||
|
pub const fn tile_index(self) -> u16 {
|
||||||
|
self.0 & Self::TILE_INDEX_MASK
|
||||||
|
}
|
||||||
|
pub const fn with_tile_index(self, index: u16) -> Self {
|
||||||
|
TextScreenblockEntry((self.0 & !Self::TILE_INDEX_MASK) | (index & Self::TILE_INDEX_MASK))
|
||||||
|
}
|
||||||
|
|
||||||
|
register_bit!(HFLIP_BIT, u16, 1 << 0xA, hflip);
|
||||||
|
register_bit!(VFLIP_BIT, u16, 1 << 0xB, vflip);
|
||||||
|
|
||||||
|
pub const PALBANK_MASK: u16 = 0b1111 << 0xC;
|
||||||
|
pub const fn palbank(self) -> u16 {
|
||||||
|
(self.0 & Self::TILE_INDEX_MASK) >> 0xC
|
||||||
|
}
|
||||||
|
pub const fn with_palbank(self, palbank: u16) -> Self {
|
||||||
|
TextScreenblockEntry((self.0 & !Self::PALBANK_MASK) | (palbank << 0xC))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
newtype! {
|
||||||
|
/// A screenblock for use in Text mode.
|
||||||
|
#[derive(Clone, Copy)]
|
||||||
|
TextScreenblock, [TextScreenblockEntry; 32 * 32], no frills
|
||||||
|
}
|
||||||
|
|
||||||
|
newtype! {
|
||||||
|
/// A screenblock entry for use in Affine mode.
|
||||||
|
#[derive(Debug, Clone, Copy, Default)]
|
||||||
|
AffineScreenblockEntry, u8
|
||||||
|
}
|
||||||
|
|
||||||
|
newtype! {
|
||||||
|
/// A screenblock for use in Affine mode.
|
||||||
|
#[derive(Clone, Copy)]
|
||||||
|
AffineScreenblock_16x16, [AffineScreenblockEntry; 16*16], no frills
|
||||||
|
}
|
||||||
|
|
||||||
|
newtype! {
|
||||||
|
/// A screenblock for use in Affine mode.
|
||||||
|
#[derive(Clone, Copy)]
|
||||||
|
AffineScreenblock_32x32, [AffineScreenblockEntry; 32*32], no frills
|
||||||
|
}
|
||||||
|
|
||||||
|
newtype! {
|
||||||
|
/// A screenblock for use in Affine mode.
|
||||||
|
#[derive(Clone, Copy)]
|
||||||
|
AffineScreenblock_64x64, [AffineScreenblockEntry; 64*64], no frills
|
||||||
|
}
|
||||||
|
|
||||||
|
newtype! {
|
||||||
|
/// A screenblock for use in Affine mode.
|
||||||
|
#[derive(Clone, Copy)]
|
||||||
|
AffineScreenblock_128x128, [AffineScreenblockEntry; 128*128], no frills
|
||||||
|
}
|
||||||
|
|
||||||
|
pub const VRAM_CHARBLOCKS: VolAddressBlock<Charblock4bpp> = unsafe { VolAddressBlock::new_unchecked(VolAddress::new_unchecked(VRAM_BASE_USIZE), 6) };
|
||||||
|
|
||||||
|
pub const VRAM_TEXT_SCREENBLOCKS: VolAddressBlock<TextScreenblock> =
|
||||||
|
unsafe { VolAddressBlock::new_unchecked(VolAddress::new_unchecked(VRAM_BASE_USIZE), 32) };
|
||||||
|
|
Loading…
Reference in a new issue