mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-11 09:31:34 +11:00
Update to be closer to the API I actually want but currently only works in release mode
This commit is contained in:
parent
59673206b3
commit
83c28254a1
|
@ -570,7 +570,7 @@ impl<I: FixedWidthUnsignedInteger, const N: usize> Debug for Num<I, N> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A vector of two points: (x, y) represened by integers or fixed point numbers
|
/// A vector of two points: (x, y) represened by integers or fixed point numbers
|
||||||
#[derive(Clone, Copy, PartialEq, Eq, Debug)]
|
#[derive(Clone, Copy, PartialEq, Eq, Debug, Default)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Vector2D<T: Number> {
|
pub struct Vector2D<T: Number> {
|
||||||
/// The x coordinate
|
/// The x coordinate
|
||||||
|
@ -1016,7 +1016,7 @@ impl<T: Number> Vector2D<T> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl <T: Number + Neg<Output = T>> Neg for Vector2D<T> {
|
impl<T: Number + Neg<Output = T>> Neg for Vector2D<T> {
|
||||||
type Output = Self;
|
type Output = Self;
|
||||||
|
|
||||||
fn neg(self) -> Self::Output {
|
fn neg(self) -> Self::Output {
|
||||||
|
|
|
@ -56,13 +56,9 @@ fn main(mut gba: agb::Gba) -> ! {
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
|
|
||||||
bg.set_scroll_pos((16 * 4, 16 * 4).into());
|
|
||||||
let scroll_pos = (scroll_x as i16, scroll_y as i16);
|
let scroll_pos = (scroll_x as i16, scroll_y as i16);
|
||||||
bg.set_transform(
|
bg.set_scroll_pos(scroll_pos.into());
|
||||||
scroll_pos,
|
bg.set_transform((0, 0), (1, 1), 0);
|
||||||
(1, 1),
|
|
||||||
rotation,
|
|
||||||
);
|
|
||||||
|
|
||||||
rotation += rotation_increase;
|
rotation += rotation_increase;
|
||||||
if rotation >= num!(255.) {
|
if rotation >= num!(255.) {
|
||||||
|
|
|
@ -1197,7 +1197,7 @@ enum ColourMode {
|
||||||
/// that can apply to objects and background layers in modes 1 and 2.
|
/// that can apply to objects and background layers in modes 1 and 2.
|
||||||
/// This can be obtained from X/Y scale and rotation angle with
|
/// This can be obtained from X/Y scale and rotation angle with
|
||||||
/// [`agb::syscall::affine_matrix`].
|
/// [`agb::syscall::affine_matrix`].
|
||||||
#[derive(Copy, Clone, Default, Debug, PartialEq, Eq)]
|
#[derive(Copy, Clone, Debug, PartialEq, Eq)]
|
||||||
#[repr(C, packed)]
|
#[repr(C, packed)]
|
||||||
pub struct AffineMatrixAttributes {
|
pub struct AffineMatrixAttributes {
|
||||||
/// Adjustment made to *X* coordinate when drawing *horizontal* lines.
|
/// Adjustment made to *X* coordinate when drawing *horizontal* lines.
|
||||||
|
@ -1218,6 +1218,17 @@ pub struct AffineMatrixAttributes {
|
||||||
pub p_d: Num<i16, 8>,
|
pub p_d: Num<i16, 8>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Default for AffineMatrixAttributes {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self {
|
||||||
|
p_a: 1.into(),
|
||||||
|
p_b: Default::default(),
|
||||||
|
p_c: Default::default(),
|
||||||
|
p_d: 1.into(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// this mod is not public, so the internal parts don't need documenting.
|
// this mod is not public, so the internal parts don't need documenting.
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
mod attributes {
|
mod attributes {
|
||||||
|
|
|
@ -257,13 +257,9 @@ impl<'a> InfiniteScrolledMap<'a> {
|
||||||
let y_end = div_ceil(self.current_pos.y + display::HEIGHT, 8) + 1;
|
let y_end = div_ceil(self.current_pos.y + display::HEIGHT, 8) + 1;
|
||||||
|
|
||||||
let offset = self.current_pos - (x_start * 8, y_start * 8).into();
|
let offset = self.current_pos - (x_start * 8, y_start * 8).into();
|
||||||
let offset_scroll = (
|
|
||||||
self.map.size().tile_pos_x(offset.x),
|
|
||||||
self.map.size().tile_pos_y(offset.y),
|
|
||||||
)
|
|
||||||
.into();
|
|
||||||
|
|
||||||
self.map.set_scroll_pos(offset_scroll);
|
self.map
|
||||||
|
.set_scroll_pos((offset.x as i16, offset.y as i16).into());
|
||||||
self.offset = (x_start, y_start).into();
|
self.offset = (x_start, y_start).into();
|
||||||
|
|
||||||
let copy_from = self.copied_up_to;
|
let copy_from = self.copied_up_to;
|
||||||
|
@ -386,11 +382,7 @@ impl<'a> InfiniteScrolledMap<'a> {
|
||||||
}
|
}
|
||||||
|
|
||||||
let current_scroll = self.map.scroll_pos();
|
let current_scroll = self.map.scroll_pos();
|
||||||
let new_scroll = (
|
let new_scroll = current_scroll + (difference.x as i16, difference.y as i16).into();
|
||||||
size.px_offset_x(i32::from(current_scroll.x) + difference.x),
|
|
||||||
size.px_offset_y(i32::from(current_scroll.y) + difference.y),
|
|
||||||
)
|
|
||||||
.into();
|
|
||||||
|
|
||||||
self.map.set_scroll_pos(new_scroll);
|
self.map.set_scroll_pos(new_scroll);
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@ use core::ops::{Deref, DerefMut};
|
||||||
use crate::bitarray::Bitarray;
|
use crate::bitarray::Bitarray;
|
||||||
use crate::display::{object::AffineMatrixAttributes, Priority, DISPLAY_CONTROL};
|
use crate::display::{object::AffineMatrixAttributes, Priority, DISPLAY_CONTROL};
|
||||||
use crate::dma::dma_copy16;
|
use crate::dma::dma_copy16;
|
||||||
use crate::fixnum::{Num, Number, Vector2D};
|
use crate::fixnum::{Num, Vector2D};
|
||||||
use crate::memory_mapped::MemoryMapped;
|
use crate::memory_mapped::MemoryMapped;
|
||||||
|
|
||||||
use super::{
|
use super::{
|
||||||
|
@ -16,7 +16,6 @@ use crate::syscall::BgAffineSetData;
|
||||||
use alloc::{vec, vec::Vec};
|
use alloc::{vec, vec::Vec};
|
||||||
|
|
||||||
pub trait TiledMapTypes {
|
pub trait TiledMapTypes {
|
||||||
type Position: Number;
|
|
||||||
type Size: BackgroundSize + Copy;
|
type Size: BackgroundSize + Copy;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,19 +25,17 @@ trait TiledMapPrivate: TiledMapTypes {
|
||||||
|
|
||||||
fn tiles_mut(&mut self) -> &mut [Self::TileType];
|
fn tiles_mut(&mut self) -> &mut [Self::TileType];
|
||||||
fn tiles_dirty(&mut self) -> &mut bool;
|
fn tiles_dirty(&mut self) -> &mut bool;
|
||||||
fn x_scroll_mut(&mut self) -> &mut Self::Position;
|
|
||||||
fn y_scroll_mut(&mut self) -> &mut Self::Position;
|
|
||||||
|
|
||||||
fn x_scroll(&self) -> Self::Position;
|
|
||||||
fn y_scroll(&self) -> Self::Position;
|
|
||||||
fn affine_matrix(&self) -> Self::AffineMatrix;
|
|
||||||
fn background_id(&self) -> usize;
|
fn background_id(&self) -> usize;
|
||||||
fn screenblock(&self) -> usize;
|
fn screenblock(&self) -> usize;
|
||||||
fn priority(&self) -> Priority;
|
fn priority(&self) -> Priority;
|
||||||
fn map_size(&self) -> Self::Size;
|
fn map_size(&self) -> Self::Size;
|
||||||
fn bg_x(&self) -> MemoryMapped<Self::Position>;
|
|
||||||
fn bg_y(&self) -> MemoryMapped<Self::Position>;
|
fn update_bg_registers(&self);
|
||||||
fn bg_affine_matrix(&self) -> MemoryMapped<Self::AffineMatrix>;
|
|
||||||
|
fn scroll_pos(&self) -> Vector2D<i16>;
|
||||||
|
fn set_scroll_pos(&mut self, new_pos: Vector2D<i16>);
|
||||||
|
|
||||||
fn bg_control_register(&self) -> MemoryMapped<u16> {
|
fn bg_control_register(&self) -> MemoryMapped<u16> {
|
||||||
unsafe { MemoryMapped::new(0x0400_0008 + 2 * self.background_id()) }
|
unsafe { MemoryMapped::new(0x0400_0008 + 2 * self.background_id()) }
|
||||||
}
|
}
|
||||||
|
@ -55,8 +52,8 @@ pub trait TiledMap: TiledMapTypes {
|
||||||
fn size(&self) -> Self::Size;
|
fn size(&self) -> Self::Size;
|
||||||
|
|
||||||
#[must_use]
|
#[must_use]
|
||||||
fn scroll_pos(&self) -> Vector2D<Self::Position>;
|
fn scroll_pos(&self) -> Vector2D<i16>;
|
||||||
fn set_scroll_pos(&mut self, pos: Vector2D<Self::Position>);
|
fn set_scroll_pos(&mut self, pos: Vector2D<i16>);
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T> TiledMap for T
|
impl<T> TiledMap for T
|
||||||
|
@ -92,9 +89,7 @@ where
|
||||||
| (self.map_size().size_flag() << 14);
|
| (self.map_size().size_flag() << 14);
|
||||||
|
|
||||||
self.bg_control_register().set(new_bg_control_value);
|
self.bg_control_register().set(new_bg_control_value);
|
||||||
self.bg_x().set(self.x_scroll());
|
self.update_bg_registers();
|
||||||
self.bg_y().set(self.y_scroll());
|
|
||||||
self.bg_affine_matrix().set(self.affine_matrix());
|
|
||||||
|
|
||||||
let screenblock_memory = self.screenblock_memory();
|
let screenblock_memory = self.screenblock_memory();
|
||||||
let x: TileIndex = unsafe { *self.tiles_mut().get_unchecked(0) }.into();
|
let x: TileIndex = unsafe { *self.tiles_mut().get_unchecked(0) }.into();
|
||||||
|
@ -119,13 +114,12 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
#[must_use]
|
#[must_use]
|
||||||
fn scroll_pos(&self) -> Vector2D<T::Position> {
|
fn scroll_pos(&self) -> Vector2D<i16> {
|
||||||
(self.x_scroll(), self.y_scroll()).into()
|
TiledMapPrivate::scroll_pos(self)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn set_scroll_pos(&mut self, pos: Vector2D<T::Position>) {
|
fn set_scroll_pos(&mut self, pos: Vector2D<i16>) {
|
||||||
*self.x_scroll_mut() = pos.x;
|
TiledMapPrivate::set_scroll_pos(self, pos);
|
||||||
*self.y_scroll_mut() = pos.y;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -135,8 +129,7 @@ pub struct RegularMap {
|
||||||
priority: Priority,
|
priority: Priority,
|
||||||
size: RegularBackgroundSize,
|
size: RegularBackgroundSize,
|
||||||
|
|
||||||
x_scroll: u16,
|
scroll: Vector2D<i16>,
|
||||||
y_scroll: u16,
|
|
||||||
|
|
||||||
tiles: Vec<Tile>,
|
tiles: Vec<Tile>,
|
||||||
tiles_dirty: bool,
|
tiles_dirty: bool,
|
||||||
|
@ -145,7 +138,6 @@ pub struct RegularMap {
|
||||||
pub const TRANSPARENT_TILE_INDEX: u16 = (1 << 10) - 1;
|
pub const TRANSPARENT_TILE_INDEX: u16 = (1 << 10) - 1;
|
||||||
|
|
||||||
impl TiledMapTypes for RegularMap {
|
impl TiledMapTypes for RegularMap {
|
||||||
type Position = u16;
|
|
||||||
type Size = RegularBackgroundSize;
|
type Size = RegularBackgroundSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -159,19 +151,7 @@ impl TiledMapPrivate for RegularMap {
|
||||||
fn tiles_dirty(&mut self) -> &mut bool {
|
fn tiles_dirty(&mut self) -> &mut bool {
|
||||||
&mut self.tiles_dirty
|
&mut self.tiles_dirty
|
||||||
}
|
}
|
||||||
fn x_scroll_mut(&mut self) -> &mut Self::Position {
|
|
||||||
&mut self.x_scroll
|
|
||||||
}
|
|
||||||
fn y_scroll_mut(&mut self) -> &mut Self::Position {
|
|
||||||
&mut self.y_scroll
|
|
||||||
}
|
|
||||||
fn x_scroll(&self) -> Self::Position {
|
|
||||||
self.x_scroll
|
|
||||||
}
|
|
||||||
fn y_scroll(&self) -> Self::Position {
|
|
||||||
self.y_scroll
|
|
||||||
}
|
|
||||||
fn affine_matrix(&self) -> Self::AffineMatrix {}
|
|
||||||
fn background_id(&self) -> usize {
|
fn background_id(&self) -> usize {
|
||||||
self.background_id as usize
|
self.background_id as usize
|
||||||
}
|
}
|
||||||
|
@ -184,14 +164,15 @@ impl TiledMapPrivate for RegularMap {
|
||||||
fn map_size(&self) -> Self::Size {
|
fn map_size(&self) -> Self::Size {
|
||||||
self.size
|
self.size
|
||||||
}
|
}
|
||||||
fn bg_x(&self) -> MemoryMapped<Self::Position> {
|
fn update_bg_registers(&self) {
|
||||||
unsafe { MemoryMapped::new(0x0400_0010 + 4 * self.background_id as usize) }
|
self.x_register().set(self.scroll.x);
|
||||||
|
self.y_register().set(self.scroll.y);
|
||||||
}
|
}
|
||||||
fn bg_y(&self) -> MemoryMapped<Self::Position> {
|
fn scroll_pos(&self) -> Vector2D<i16> {
|
||||||
unsafe { MemoryMapped::new(0x0400_0012 + 4 * self.background_id as usize) }
|
self.scroll
|
||||||
}
|
}
|
||||||
fn bg_affine_matrix(&self) -> MemoryMapped<Self::AffineMatrix> {
|
fn set_scroll_pos(&mut self, new_pos: Vector2D<i16>) {
|
||||||
unsafe { MemoryMapped::new(0) }
|
self.scroll = new_pos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -208,8 +189,7 @@ impl RegularMap {
|
||||||
priority,
|
priority,
|
||||||
size,
|
size,
|
||||||
|
|
||||||
x_scroll: 0,
|
scroll: Default::default(),
|
||||||
y_scroll: 0,
|
|
||||||
|
|
||||||
tiles: vec![Default::default(); size.num_tiles()],
|
tiles: vec![Default::default(); size.num_tiles()],
|
||||||
tiles_dirty: true,
|
tiles_dirty: true,
|
||||||
|
@ -247,6 +227,14 @@ impl RegularMap {
|
||||||
self.tiles_mut()[pos] = new_tile;
|
self.tiles_mut()[pos] = new_tile;
|
||||||
*self.tiles_dirty() = true;
|
*self.tiles_dirty() = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn x_register(&self) -> MemoryMapped<i16> {
|
||||||
|
unsafe { MemoryMapped::new(0x0400_0010 + 4 * self.background_id as usize) }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn y_register(&self) -> MemoryMapped<i16> {
|
||||||
|
unsafe { MemoryMapped::new(0x0400_0012 + 4 * self.background_id as usize) }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct AffineMap {
|
pub struct AffineMap {
|
||||||
|
@ -255,7 +243,9 @@ pub struct AffineMap {
|
||||||
priority: Priority,
|
priority: Priority,
|
||||||
size: AffineBackgroundSize,
|
size: AffineBackgroundSize,
|
||||||
|
|
||||||
bg_center: Vector2D<Num<i32, 8>>,
|
scroll: Vector2D<i16>,
|
||||||
|
|
||||||
|
transform_origin: Vector2D<Num<i32, 8>>,
|
||||||
transform: BgAffineSetData,
|
transform: BgAffineSetData,
|
||||||
|
|
||||||
tiles: Vec<u8>,
|
tiles: Vec<u8>,
|
||||||
|
@ -263,7 +253,6 @@ pub struct AffineMap {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl TiledMapTypes for AffineMap {
|
impl TiledMapTypes for AffineMap {
|
||||||
type Position = Num<i32, 8>;
|
|
||||||
type Size = AffineBackgroundSize;
|
type Size = AffineBackgroundSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -277,21 +266,6 @@ impl TiledMapPrivate for AffineMap {
|
||||||
fn tiles_dirty(&mut self) -> &mut bool {
|
fn tiles_dirty(&mut self) -> &mut bool {
|
||||||
&mut self.tiles_dirty
|
&mut self.tiles_dirty
|
||||||
}
|
}
|
||||||
fn x_scroll_mut(&mut self) -> &mut Self::Position {
|
|
||||||
&mut self.bg_center.x
|
|
||||||
}
|
|
||||||
fn y_scroll_mut(&mut self) -> &mut Self::Position {
|
|
||||||
&mut self.bg_center.y
|
|
||||||
}
|
|
||||||
fn x_scroll(&self) -> Self::Position {
|
|
||||||
self.bg_center.x + self.transform.position.x
|
|
||||||
}
|
|
||||||
fn y_scroll(&self) -> Self::Position {
|
|
||||||
self.bg_center.y + self.transform.position.y
|
|
||||||
}
|
|
||||||
fn affine_matrix(&self) -> Self::AffineMatrix {
|
|
||||||
self.transform.matrix
|
|
||||||
}
|
|
||||||
fn background_id(&self) -> usize {
|
fn background_id(&self) -> usize {
|
||||||
self.background_id as usize
|
self.background_id as usize
|
||||||
}
|
}
|
||||||
|
@ -304,14 +278,23 @@ impl TiledMapPrivate for AffineMap {
|
||||||
fn map_size(&self) -> Self::Size {
|
fn map_size(&self) -> Self::Size {
|
||||||
self.size
|
self.size
|
||||||
}
|
}
|
||||||
fn bg_x(&self) -> MemoryMapped<Self::Position> {
|
fn update_bg_registers(&self) {
|
||||||
unsafe { MemoryMapped::new(0x0400_0008 + 0x10 * self.background_id()) }
|
let register_pos = self.transform.position + self.transform_origin;
|
||||||
|
self.bg_x().set(register_pos.x);
|
||||||
|
self.bg_y().set(register_pos.y);
|
||||||
|
self.bg_affine_matrix().set(self.transform.matrix);
|
||||||
|
|
||||||
|
crate::println!(
|
||||||
|
"update: {:?} {:?}",
|
||||||
|
self.transform.matrix,
|
||||||
|
self.bg_affine_matrix().get()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
fn bg_y(&self) -> MemoryMapped<Self::Position> {
|
fn scroll_pos(&self) -> Vector2D<i16> {
|
||||||
unsafe { MemoryMapped::new(0x0400_000c + 0x10 * self.background_id()) }
|
self.scroll
|
||||||
}
|
}
|
||||||
fn bg_affine_matrix(&self) -> MemoryMapped<Self::AffineMatrix> {
|
fn set_scroll_pos(&mut self, new_pos: Vector2D<i16>) {
|
||||||
unsafe { MemoryMapped::new(0x0400_0000 + 0x10 * self.background_id()) }
|
self.scroll = new_pos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -321,7 +304,6 @@ impl AffineMap {
|
||||||
screenblock: u8,
|
screenblock: u8,
|
||||||
priority: Priority,
|
priority: Priority,
|
||||||
size: AffineBackgroundSize,
|
size: AffineBackgroundSize,
|
||||||
bg_center: Vector2D<Num<i32, 8>>,
|
|
||||||
) -> Self {
|
) -> Self {
|
||||||
Self {
|
Self {
|
||||||
background_id,
|
background_id,
|
||||||
|
@ -329,7 +311,9 @@ impl AffineMap {
|
||||||
priority,
|
priority,
|
||||||
size,
|
size,
|
||||||
|
|
||||||
bg_center,
|
scroll: Default::default(),
|
||||||
|
|
||||||
|
transform_origin: Default::default(),
|
||||||
transform: Default::default(),
|
transform: Default::default(),
|
||||||
|
|
||||||
tiles: vec![Default::default(); size.num_tiles()],
|
tiles: vec![Default::default(); size.num_tiles()],
|
||||||
|
@ -369,22 +353,36 @@ impl AffineMap {
|
||||||
*self.tiles_dirty() = true;
|
*self.tiles_dirty() = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set_transform_raw(&mut self, transform: BgAffineSetData) {
|
|
||||||
self.transform = transform;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn set_transform(
|
pub fn set_transform(
|
||||||
&mut self,
|
&mut self,
|
||||||
display_center: impl Into<Vector2D<i16>>,
|
transform_origin: impl Into<Vector2D<Num<i32, 8>>>,
|
||||||
scale: impl Into<Vector2D<Num<i16, 8>>>,
|
scale: impl Into<Vector2D<Num<i16, 8>>>,
|
||||||
rotation: impl Into<Num<u16, 8>>,
|
rotation: impl Into<Num<u16, 8>>,
|
||||||
) {
|
) {
|
||||||
self.set_transform_raw(crate::syscall::bg_affine_matrix(
|
self.transform_origin = transform_origin.into();
|
||||||
self.bg_center,
|
let scale = scale.into();
|
||||||
display_center.into(),
|
let rotation = rotation.into();
|
||||||
scale.into(),
|
self.transform =
|
||||||
rotation.into(),
|
crate::syscall::bg_affine_matrix(self.transform_origin, self.scroll, scale, rotation);
|
||||||
));
|
|
||||||
|
crate::println!(
|
||||||
|
"{:?}, {:?}, {:?}, {:?}",
|
||||||
|
self.transform_origin,
|
||||||
|
self.scroll,
|
||||||
|
scale,
|
||||||
|
rotation
|
||||||
|
);
|
||||||
|
crate::println!("{:?}", self.transform.matrix);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn bg_x(&self) -> MemoryMapped<Num<i32, 8>> {
|
||||||
|
unsafe { MemoryMapped::new(0x0400_0008 + 0x10 * self.background_id()) }
|
||||||
|
}
|
||||||
|
fn bg_y(&self) -> MemoryMapped<Num<i32, 8>> {
|
||||||
|
unsafe { MemoryMapped::new(0x0400_000c + 0x10 * self.background_id()) }
|
||||||
|
}
|
||||||
|
fn bg_affine_matrix(&self) -> MemoryMapped<AffineMatrixAttributes> {
|
||||||
|
unsafe { MemoryMapped::new(0x0400_0000 + 0x10 * self.background_id()) }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ mod vram_manager;
|
||||||
|
|
||||||
use crate::bitarray::Bitarray;
|
use crate::bitarray::Bitarray;
|
||||||
use crate::display::Priority;
|
use crate::display::Priority;
|
||||||
use agb_fixnum::{Num, Vector2D};
|
use agb_fixnum::Vector2D;
|
||||||
use core::cell::RefCell;
|
use core::cell::RefCell;
|
||||||
pub use infinite_scrolled_map::{InfiniteScrolledMap, PartialUpdateStatus};
|
pub use infinite_scrolled_map::{InfiniteScrolledMap, PartialUpdateStatus};
|
||||||
pub use map::{AffineMap, MapLoan, RegularMap, TiledMap};
|
pub use map::{AffineMap, MapLoan, RegularMap, TiledMap};
|
||||||
|
@ -307,16 +307,7 @@ where
|
||||||
screenblocks.set(id, true);
|
screenblocks.set(id, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
let center_dim = Num::new(size.width() as i32 * 8 / 2);
|
let bg = AffineMap::new(new_background as u8, screenblock as u8 + 16, priority, size);
|
||||||
let default_bg_center = (center_dim, center_dim).into();
|
|
||||||
|
|
||||||
let bg = AffineMap::new(
|
|
||||||
new_background as u8,
|
|
||||||
screenblock as u8 + 16,
|
|
||||||
priority,
|
|
||||||
size,
|
|
||||||
default_bg_center,
|
|
||||||
);
|
|
||||||
|
|
||||||
affine.set(new_background, true);
|
affine.set(new_background, true);
|
||||||
|
|
||||||
|
|
|
@ -185,7 +185,8 @@ pub fn bg_affine_matrix(
|
||||||
in("r0") &input as *const Input,
|
in("r0") &input as *const Input,
|
||||||
in("r1") output.as_mut_ptr(),
|
in("r1") output.as_mut_ptr(),
|
||||||
in("r2") 1,
|
in("r2") 1,
|
||||||
lateout("r3") _,
|
|
||||||
|
clobber_abi("C")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -231,7 +232,7 @@ mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
#[test_case]
|
#[test_case]
|
||||||
fn affine(_gba: &mut crate::Gba) {
|
fn affine_obj(_gba: &mut crate::Gba) {
|
||||||
// expect identity matrix
|
// expect identity matrix
|
||||||
let one: Num<i16, 8> = 1.into();
|
let one: Num<i16, 8> = 1.into();
|
||||||
|
|
||||||
|
@ -241,4 +242,22 @@ mod tests {
|
||||||
assert_eq!(p_a, one);
|
assert_eq!(p_a, one);
|
||||||
assert_eq!(p_d, one);
|
assert_eq!(p_d, one);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test_case]
|
||||||
|
fn affine_bg(_gba: &mut crate::Gba) {
|
||||||
|
// expect the identity matrix
|
||||||
|
let aff = bg_affine_matrix(
|
||||||
|
(0, 0).into(),
|
||||||
|
(0i16, 0i16).into(),
|
||||||
|
(1i16, 1i16).into(),
|
||||||
|
0.into(),
|
||||||
|
);
|
||||||
|
|
||||||
|
let matrix = aff.matrix;
|
||||||
|
let (p_a, p_b, p_c, p_d) = (matrix.p_a, matrix.p_b, matrix.p_c, matrix.p_d);
|
||||||
|
assert_eq!(p_a, 1.into());
|
||||||
|
assert_eq!(p_b, 0.into());
|
||||||
|
assert_eq!(p_c, 0.into());
|
||||||
|
assert_eq!(p_d, 1.into());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,27 +1,21 @@
|
||||||
use agb::{
|
use agb::{
|
||||||
display::tiled::{RegularMap, TileFormat, TileSet, TileSetting, TiledMap, VRamManager},
|
display::tiled::{RegularMap, TileFormat, TileSet, TileSetting, VRamManager},
|
||||||
include_gfx, rng,
|
include_gfx, rng,
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::sfx::Sfx;
|
use crate::sfx::Sfx;
|
||||||
|
|
||||||
include_gfx!("gfx/backgrounds.toml");
|
include_gfx!("gfx/stars.toml");
|
||||||
|
|
||||||
|
include_gfx!("gfx/help.toml");
|
||||||
|
|
||||||
pub fn load_palettes(vram: &mut VRamManager) {
|
pub fn load_palettes(vram: &mut VRamManager) {
|
||||||
vram.set_background_palettes(backgrounds::stars.palettes);
|
vram.set_background_palettes(&[
|
||||||
}
|
stars::stars.palettes[0].clone(),
|
||||||
|
crate::customise::DESCRIPTIONS_1_PALETTE.clone(),
|
||||||
fn description_tileset() -> (TileSet<'static>, TileSet<'static>) {
|
crate::customise::DESCRIPTIONS_2_PALETTE.clone(),
|
||||||
let descriptions_1_tileset = TileSet::new(
|
help::help.palettes[0].clone(),
|
||||||
backgrounds::descriptions1.tiles,
|
]);
|
||||||
agb::display::tiled::TileFormat::FourBpp,
|
|
||||||
);
|
|
||||||
let descriptions_2_tileset = TileSet::new(
|
|
||||||
backgrounds::descriptions2.tiles,
|
|
||||||
agb::display::tiled::TileFormat::FourBpp,
|
|
||||||
);
|
|
||||||
|
|
||||||
(descriptions_1_tileset, descriptions_2_tileset)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn load_help_text(
|
pub(crate) fn load_help_text(
|
||||||
|
@ -30,69 +24,18 @@ pub(crate) fn load_help_text(
|
||||||
help_text_line: u16,
|
help_text_line: u16,
|
||||||
at_tile: (u16, u16),
|
at_tile: (u16, u16),
|
||||||
) {
|
) {
|
||||||
let help_tileset = TileSet::new(
|
let help_tileset = TileSet::new(help::help.tiles, agb::display::tiled::TileFormat::FourBpp);
|
||||||
backgrounds::help.tiles,
|
|
||||||
agb::display::tiled::TileFormat::FourBpp,
|
|
||||||
);
|
|
||||||
|
|
||||||
for x in 0..16 {
|
for x in 0..16 {
|
||||||
let tile_id = help_text_line * 16 + x;
|
|
||||||
background.set_tile(
|
background.set_tile(
|
||||||
vram,
|
vram,
|
||||||
(x + at_tile.0, at_tile.1).into(),
|
(x + at_tile.0, at_tile.1).into(),
|
||||||
&help_tileset,
|
&help_tileset,
|
||||||
TileSetting::new(
|
TileSetting::new(help_text_line * 16 + x, false, false, 3),
|
||||||
tile_id,
|
|
||||||
false,
|
|
||||||
false,
|
|
||||||
backgrounds::help.palette_assignments[tile_id as usize],
|
|
||||||
),
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn load_description(
|
|
||||||
upgrade: usize,
|
|
||||||
descriptions_map: &mut RegularMap,
|
|
||||||
vram: &mut VRamManager,
|
|
||||||
) {
|
|
||||||
let (descriptions_1_tileset, descriptions_2_tileset) = description_tileset();
|
|
||||||
|
|
||||||
for y in 0..11 {
|
|
||||||
for x in 0..8 {
|
|
||||||
if upgrade < 10 {
|
|
||||||
let tile_id = y * 8 + x + 8 * 11 * upgrade as u16;
|
|
||||||
|
|
||||||
descriptions_map.set_tile(
|
|
||||||
vram,
|
|
||||||
(x, y).into(),
|
|
||||||
&descriptions_1_tileset,
|
|
||||||
TileSetting::new(
|
|
||||||
tile_id,
|
|
||||||
false,
|
|
||||||
false,
|
|
||||||
backgrounds::descriptions1.palette_assignments[tile_id as usize],
|
|
||||||
),
|
|
||||||
)
|
|
||||||
} else {
|
|
||||||
let tile_id = y * 8 + x + 8 * 11 * (upgrade as u16 - 10);
|
|
||||||
|
|
||||||
descriptions_map.set_tile(
|
|
||||||
vram,
|
|
||||||
(x, y).into(),
|
|
||||||
&descriptions_2_tileset,
|
|
||||||
TileSetting::new(
|
|
||||||
tile_id,
|
|
||||||
false,
|
|
||||||
false,
|
|
||||||
backgrounds::descriptions2.palette_assignments[tile_id as usize],
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Expects a 64x32 map
|
// Expects a 64x32 map
|
||||||
fn create_background_map(map: &mut RegularMap, vram: &mut VRamManager, stars_tileset: &TileSet) {
|
fn create_background_map(map: &mut RegularMap, vram: &mut VRamManager, stars_tileset: &TileSet) {
|
||||||
for x in 0..64u16 {
|
for x in 0..64u16 {
|
||||||
|
@ -104,16 +47,7 @@ fn create_background_map(map: &mut RegularMap, vram: &mut VRamManager, stars_til
|
||||||
} else {
|
} else {
|
||||||
rng::gen().rem_euclid(64) as u16
|
rng::gen().rem_euclid(64) as u16
|
||||||
};
|
};
|
||||||
let tile_setting = TileSetting::new(
|
let tile_setting = TileSetting::new(tile_id, false, false, 0);
|
||||||
tile_id,
|
|
||||||
false,
|
|
||||||
false,
|
|
||||||
if blank {
|
|
||||||
0
|
|
||||||
} else {
|
|
||||||
backgrounds::stars.palette_assignments[tile_id as usize]
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
map.set_tile(vram, (x, y).into(), stars_tileset, tile_setting);
|
map.set_tile(vram, (x, y).into(), stars_tileset, tile_setting);
|
||||||
}
|
}
|
||||||
|
@ -124,11 +58,8 @@ fn create_background_map(map: &mut RegularMap, vram: &mut VRamManager, stars_til
|
||||||
|
|
||||||
pub fn show_title_screen(background: &mut RegularMap, vram: &mut VRamManager, sfx: &mut Sfx) {
|
pub fn show_title_screen(background: &mut RegularMap, vram: &mut VRamManager, sfx: &mut Sfx) {
|
||||||
background.set_scroll_pos((0_u16, 0_u16).into());
|
background.set_scroll_pos((0_u16, 0_u16).into());
|
||||||
vram.set_background_palettes(backgrounds::title.palettes);
|
vram.set_background_palettes(stars::title.palettes);
|
||||||
let tile_set = TileSet::new(
|
let tile_set = TileSet::new(stars::title.tiles, agb::display::tiled::TileFormat::FourBpp);
|
||||||
backgrounds::title.tiles,
|
|
||||||
agb::display::tiled::TileFormat::FourBpp,
|
|
||||||
);
|
|
||||||
background.hide();
|
background.hide();
|
||||||
|
|
||||||
for x in 0..30u16 {
|
for x in 0..30u16 {
|
||||||
|
@ -142,7 +73,7 @@ pub fn show_title_screen(background: &mut RegularMap, vram: &mut VRamManager, sf
|
||||||
tile_id,
|
tile_id,
|
||||||
false,
|
false,
|
||||||
false,
|
false,
|
||||||
backgrounds::title.palette_assignments[tile_id as usize],
|
stars::title.palette_assignments[tile_id as usize],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -169,7 +100,7 @@ impl<'a> StarBackground<'a> {
|
||||||
background2: &'a mut RegularMap,
|
background2: &'a mut RegularMap,
|
||||||
vram: &'_ mut VRamManager,
|
vram: &'_ mut VRamManager,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
let stars_tileset = TileSet::new(backgrounds::stars.tiles, TileFormat::FourBpp);
|
let stars_tileset = TileSet::new(stars::stars.tiles, TileFormat::FourBpp);
|
||||||
create_background_map(background1, vram, &stars_tileset);
|
create_background_map(background1, vram, &stars_tileset);
|
||||||
create_background_map(background2, vram, &stars_tileset);
|
create_background_map(background2, vram, &stars_tileset);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue