mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-26 00:56:38 +11:00
At least it compiles...
This commit is contained in:
parent
5197f5b37d
commit
f655e08665
3 changed files with 175 additions and 105 deletions
|
@ -1,26 +1,45 @@
|
||||||
use agb::display::{background::BackgroundRegister, HEIGHT, WIDTH};
|
use agb::display::{
|
||||||
|
background::{RegularMap, TileSetReference, TileSetting, VRamManager},
|
||||||
|
HEIGHT, WIDTH,
|
||||||
|
};
|
||||||
|
|
||||||
const LEVEL_START: u16 = 12 * 28;
|
const LEVEL_START: u16 = 12 * 28;
|
||||||
const NUMBERS_START: u16 = 12 * 28 + 3;
|
const NUMBERS_START: u16 = 12 * 28 + 3;
|
||||||
const HYPHEN: u16 = 12 * 28 + 11;
|
const HYPHEN: u16 = 12 * 28 + 11;
|
||||||
pub const BLANK: u16 = 11 * 28;
|
pub const BLANK: u16 = 11 * 28;
|
||||||
|
|
||||||
pub fn write_level(background: &mut BackgroundRegister, world: u32, level: u32) {
|
pub fn write_level(
|
||||||
let map = background.get_block();
|
map: &mut RegularMap,
|
||||||
let mut counter = 0;
|
world: u32,
|
||||||
|
level: u32,
|
||||||
|
tile_set_ref: TileSetReference,
|
||||||
|
vram: &mut VRamManager,
|
||||||
|
) {
|
||||||
|
for (i, &tile) in [
|
||||||
|
LEVEL_START,
|
||||||
|
LEVEL_START + 1,
|
||||||
|
LEVEL_START + 2,
|
||||||
|
BLANK,
|
||||||
|
world as u16 + NUMBERS_START - 1,
|
||||||
|
HYPHEN,
|
||||||
|
level as u16 + NUMBERS_START - 1,
|
||||||
|
]
|
||||||
|
.iter()
|
||||||
|
.enumerate()
|
||||||
|
{
|
||||||
|
map.set_tile(
|
||||||
|
vram,
|
||||||
|
(i as u16, 0).into(),
|
||||||
|
tile_set_ref,
|
||||||
|
TileSetting::from_raw(tile),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
map[0][0] = LEVEL_START;
|
map.set_scroll_pos(
|
||||||
map[0][1] = LEVEL_START + 1;
|
(
|
||||||
map[0][2] = LEVEL_START + 2;
|
-(WIDTH / 2 - 7 as i32 * 8 / 2) as u16,
|
||||||
|
-(HEIGHT / 2 - 4) as u16,
|
||||||
counter += 4;
|
)
|
||||||
|
.into(),
|
||||||
map[0][counter] = world as u16 + NUMBERS_START - 1;
|
);
|
||||||
counter += 1;
|
|
||||||
map[0][counter] = HYPHEN;
|
|
||||||
counter += 1;
|
|
||||||
map[0][counter] = level as u16 + NUMBERS_START - 1;
|
|
||||||
counter += 1;
|
|
||||||
|
|
||||||
background.set_position((-(WIDTH / 2 - counter as i32 * 8 / 2), -(HEIGHT / 2 - 4)).into());
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,18 @@
|
||||||
#![no_std]
|
#![no_std]
|
||||||
#![no_main]
|
#![no_main]
|
||||||
|
|
||||||
|
extern crate alloc;
|
||||||
|
|
||||||
use agb::{
|
use agb::{
|
||||||
display::{
|
display::{
|
||||||
background::BackgroundRegular,
|
background::{InfiniteScrolledMap, TileFormat, TileSet, TileSetting, VRamManager},
|
||||||
object::{ObjectControl, ObjectStandard, Size},
|
object::{ObjectControl, ObjectStandard, Size},
|
||||||
Priority, HEIGHT, WIDTH,
|
Priority, HEIGHT, WIDTH,
|
||||||
},
|
},
|
||||||
fixnum::{FixedNum, Vector2D},
|
fixnum::{FixedNum, Vector2D},
|
||||||
input::{self, Button, ButtonController},
|
input::{self, Button, ButtonController},
|
||||||
};
|
};
|
||||||
|
use alloc::boxed::Box;
|
||||||
|
|
||||||
mod enemies;
|
mod enemies;
|
||||||
mod level_display;
|
mod level_display;
|
||||||
|
@ -267,40 +270,24 @@ impl<'a> Entity<'a> {
|
||||||
}
|
}
|
||||||
|
|
||||||
struct Map<'a, 'b> {
|
struct Map<'a, 'b> {
|
||||||
background: &'a mut BackgroundRegular<'b>,
|
background: &'a mut InfiniteScrolledMap<'b>,
|
||||||
foreground: &'a mut BackgroundRegular<'b>,
|
foreground: &'a mut InfiniteScrolledMap<'b>,
|
||||||
position: Vector2D<FixedNumberType>,
|
position: Vector2D<FixedNumberType>,
|
||||||
level: &'a Level,
|
level: &'a Level,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'b, 'c> Map<'a, 'b> {
|
impl<'a, 'b> Map<'a, 'b> {
|
||||||
pub fn commit_position(&mut self) {
|
pub fn commit_position(&mut self, vram: &mut VRamManager) {
|
||||||
self.background.set_position(self.position.floor());
|
self.background.set_pos(vram, self.position.floor());
|
||||||
self.foreground.set_position(self.position.floor());
|
self.foreground.set_pos(vram, self.position.floor());
|
||||||
|
|
||||||
self.background.commit();
|
self.background.commit();
|
||||||
self.foreground.commit();
|
self.foreground.commit();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn load_foreground(&'c mut self) -> impl Iterator<Item = ()> + 'c {
|
pub fn init(&mut self, vram: &mut VRamManager) {
|
||||||
self.background.set_position(self.position.floor());
|
self.background.init(vram, self.position.floor());
|
||||||
self.background.set_map(agb::display::background::Map::new(
|
self.foreground.init(vram, self.position.floor());
|
||||||
self.level.foreground,
|
|
||||||
self.level.dimensions,
|
|
||||||
0,
|
|
||||||
));
|
|
||||||
self.background.commit_partial()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn load_background(&'c mut self) -> impl Iterator<Item = ()> + 'c {
|
|
||||||
self.foreground.set_position(self.position.floor());
|
|
||||||
self.foreground.set_map(agb::display::background::Map::new(
|
|
||||||
self.level.background,
|
|
||||||
self.level.dimensions,
|
|
||||||
0,
|
|
||||||
));
|
|
||||||
self.foreground.set_priority(Priority::P2);
|
|
||||||
self.foreground.commit_partial()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -618,8 +605,8 @@ impl<'a, 'b, 'c> PlayingLevel<'a, 'b> {
|
||||||
fn open_level(
|
fn open_level(
|
||||||
level: &'a Level,
|
level: &'a Level,
|
||||||
object_control: &'a ObjectControl,
|
object_control: &'a ObjectControl,
|
||||||
background: &'a mut BackgroundRegular<'b>,
|
background: &'a mut InfiniteScrolledMap<'b>,
|
||||||
foreground: &'a mut BackgroundRegular<'b>,
|
foreground: &'a mut InfiniteScrolledMap<'b>,
|
||||||
input: ButtonController,
|
input: ButtonController,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
let mut e: [enemies::Enemy<'a>; 16] = Default::default();
|
let mut e: [enemies::Enemy<'a>; 16] = Default::default();
|
||||||
|
@ -658,14 +645,6 @@ impl<'a, 'b, 'c> PlayingLevel<'a, 'b> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn load_1(&'c mut self) -> impl Iterator<Item = ()> + 'c {
|
|
||||||
self.background.load_background()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn load_2(&'c mut self) -> impl Iterator<Item = ()> + 'c {
|
|
||||||
self.background.load_foreground()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn show_backgrounds(&mut self) {
|
fn show_backgrounds(&mut self) {
|
||||||
self.background.background.show();
|
self.background.background.show();
|
||||||
self.background.foreground.show();
|
self.background.foreground.show();
|
||||||
|
@ -691,7 +670,11 @@ impl<'a, 'b, 'c> PlayingLevel<'a, 'b> {
|
||||||
self.player.wizard.position.y - self.background.position.y < (HEIGHT + 8).into()
|
self.player.wizard.position.y - self.background.position.y < (HEIGHT + 8).into()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn update_frame(&mut self, sfx_player: &mut sfx::SfxPlayer) -> UpdateState {
|
fn update_frame(
|
||||||
|
&mut self,
|
||||||
|
sfx_player: &mut sfx::SfxPlayer,
|
||||||
|
vram: &mut VRamManager,
|
||||||
|
) -> UpdateState {
|
||||||
self.timer += 1;
|
self.timer += 1;
|
||||||
self.input.update();
|
self.input.update();
|
||||||
|
|
||||||
|
@ -719,7 +702,7 @@ impl<'a, 'b, 'c> PlayingLevel<'a, 'b> {
|
||||||
}
|
}
|
||||||
|
|
||||||
self.background.position = self.get_next_map_position();
|
self.background.position = self.get_next_map_position();
|
||||||
self.background.commit_position();
|
self.background.commit_position(vram);
|
||||||
|
|
||||||
self.player.wizard.commit_position(self.background.position);
|
self.player.wizard.commit_position(self.background.position);
|
||||||
self.player.hat.commit_position(self.background.position);
|
self.player.hat.commit_position(self.background.position);
|
||||||
|
@ -774,25 +757,44 @@ impl<'a, 'b, 'c> PlayingLevel<'a, 'b> {
|
||||||
|
|
||||||
#[agb::entry]
|
#[agb::entry]
|
||||||
fn main(mut agb: agb::Gba) -> ! {
|
fn main(mut agb: agb::Gba) -> ! {
|
||||||
splash_screen::show_splash_screen(&mut agb, splash_screen::SplashScreen::Start, None, None);
|
let (tiled, mut vram) = agb.display.video.tiled0();
|
||||||
|
vram.set_background_palettes(tile_sheet::background.palettes);
|
||||||
|
let mut world_display = tiled.background(Priority::P0);
|
||||||
|
|
||||||
|
let tile_set_ref = vram.add_tileset(TileSet::new(
|
||||||
|
tile_sheet::background.tiles,
|
||||||
|
TileFormat::FourBpp,
|
||||||
|
));
|
||||||
|
|
||||||
|
splash_screen::show_splash_screen(
|
||||||
|
splash_screen::SplashScreen::Start,
|
||||||
|
None,
|
||||||
|
None,
|
||||||
|
&mut world_display,
|
||||||
|
&mut vram,
|
||||||
|
);
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
let mut tiled = agb.display.video.tiled0();
|
|
||||||
let mut object = agb.display.object.get();
|
let mut object = agb.display.object.get();
|
||||||
let mut timer_controller = agb.timers.timers();
|
let mut timer_controller = agb.timers.timers();
|
||||||
let mut mixer = agb.mixer.mixer(&mut timer_controller.timer0);
|
let mut mixer = agb.mixer.mixer(&mut timer_controller.timer0);
|
||||||
|
|
||||||
tiled.set_background_palettes(tile_sheet::background.palettes);
|
|
||||||
tiled.set_background_tilemap(0, tile_sheet::background.tiles);
|
|
||||||
object.set_sprite_palettes(object_sheet::object_sheet.palettes);
|
object.set_sprite_palettes(object_sheet::object_sheet.palettes);
|
||||||
object.set_sprite_tilemap(object_sheet::object_sheet.tiles);
|
object.set_sprite_tilemap(object_sheet::object_sheet.tiles);
|
||||||
|
|
||||||
let mut world_display = tiled.get_raw_regular().unwrap();
|
for y in 0..20u16 {
|
||||||
world_display.clear(level_display::BLANK);
|
for x in 0..30u16 {
|
||||||
|
world_display.set_tile(
|
||||||
|
&mut vram,
|
||||||
|
(x, y).into(),
|
||||||
|
tile_set_ref,
|
||||||
|
TileSetting::from_raw(level_display::BLANK),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
world_display.show();
|
world_display.show();
|
||||||
|
|
||||||
let mut background = tiled.get_regular().unwrap();
|
|
||||||
let mut foreground = tiled.get_regular().unwrap();
|
|
||||||
object.enable();
|
object.enable();
|
||||||
|
|
||||||
mixer.enable();
|
mixer.enable();
|
||||||
|
@ -815,6 +817,8 @@ fn main(mut agb: agb::Gba) -> ! {
|
||||||
&mut world_display,
|
&mut world_display,
|
||||||
current_level / 8 + 1,
|
current_level / 8 + 1,
|
||||||
current_level % 8 + 1,
|
current_level % 8 + 1,
|
||||||
|
tile_set_ref,
|
||||||
|
&mut vram,
|
||||||
);
|
);
|
||||||
|
|
||||||
world_display.show();
|
world_display.show();
|
||||||
|
@ -824,6 +828,39 @@ fn main(mut agb: agb::Gba) -> ! {
|
||||||
vblank.wait_for_vblank();
|
vblank.wait_for_vblank();
|
||||||
mixer.after_vblank();
|
mixer.after_vblank();
|
||||||
|
|
||||||
|
vram.set_background_palettes(tile_sheet::background.palettes);
|
||||||
|
|
||||||
|
let mut background = InfiniteScrolledMap::new(
|
||||||
|
tiled.background(Priority::P1),
|
||||||
|
Box::new(move |pos: Vector2D<i32>| {
|
||||||
|
let level = &map_tiles::LEVELS[current_level as usize];
|
||||||
|
(
|
||||||
|
tile_set_ref,
|
||||||
|
TileSetting::from_raw(
|
||||||
|
*level
|
||||||
|
.background
|
||||||
|
.get((pos.y * level.dimensions.x as i32 + pos.x) as usize)
|
||||||
|
.unwrap_or(&0),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
let mut foreground = InfiniteScrolledMap::new(
|
||||||
|
tiled.background(Priority::P2),
|
||||||
|
Box::new(move |pos: Vector2D<i32>| {
|
||||||
|
let level = &map_tiles::LEVELS[current_level as usize];
|
||||||
|
(
|
||||||
|
tile_set_ref,
|
||||||
|
TileSetting::from_raw(
|
||||||
|
*level
|
||||||
|
.foreground
|
||||||
|
.get((pos.y * level.dimensions.x as i32 + pos.x) as usize)
|
||||||
|
.unwrap_or(&0),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
let mut level = PlayingLevel::open_level(
|
let mut level = PlayingLevel::open_level(
|
||||||
&map_tiles::LEVELS[current_level as usize],
|
&map_tiles::LEVELS[current_level as usize],
|
||||||
&object,
|
&object,
|
||||||
|
@ -831,32 +868,24 @@ fn main(mut agb: agb::Gba) -> ! {
|
||||||
&mut foreground,
|
&mut foreground,
|
||||||
agb::input::ButtonController::new(),
|
agb::input::ButtonController::new(),
|
||||||
);
|
);
|
||||||
let mut level_load = level.load_1().step_by(24);
|
|
||||||
for _ in 0..30 {
|
level.background.init(&mut vram);
|
||||||
|
|
||||||
|
for _ in 0..60 {
|
||||||
music_box.before_frame(&mut mixer);
|
music_box.before_frame(&mut mixer);
|
||||||
mixer.frame();
|
mixer.frame();
|
||||||
vblank.wait_for_vblank();
|
vblank.wait_for_vblank();
|
||||||
mixer.after_vblank();
|
mixer.after_vblank();
|
||||||
|
|
||||||
level_load.next();
|
|
||||||
}
|
}
|
||||||
level_load.count();
|
|
||||||
let mut level_load = level.load_2().step_by(24);
|
|
||||||
for _ in 0..30 {
|
|
||||||
music_box.before_frame(&mut mixer);
|
|
||||||
mixer.frame();
|
|
||||||
vblank.wait_for_vblank();
|
|
||||||
mixer.after_vblank();
|
|
||||||
|
|
||||||
level_load.next();
|
|
||||||
}
|
|
||||||
level_load.count();
|
|
||||||
level.show_backgrounds();
|
level.show_backgrounds();
|
||||||
|
|
||||||
world_display.hide();
|
world_display.hide();
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
match level.update_frame(&mut sfx::SfxPlayer::new(&mut mixer, &music_box)) {
|
match level
|
||||||
|
.update_frame(&mut sfx::SfxPlayer::new(&mut mixer, &music_box), &mut vram)
|
||||||
|
{
|
||||||
UpdateState::Normal => {}
|
UpdateState::Normal => {}
|
||||||
UpdateState::Dead => {
|
UpdateState::Dead => {
|
||||||
level.dead_start();
|
level.dead_start();
|
||||||
|
@ -882,10 +911,11 @@ fn main(mut agb: agb::Gba) -> ! {
|
||||||
}
|
}
|
||||||
|
|
||||||
splash_screen::show_splash_screen(
|
splash_screen::show_splash_screen(
|
||||||
&mut agb,
|
|
||||||
splash_screen::SplashScreen::End,
|
splash_screen::SplashScreen::End,
|
||||||
Some(&mut mixer),
|
Some(&mut mixer),
|
||||||
Some(&mut music_box),
|
Some(&mut music_box),
|
||||||
|
&mut world_display,
|
||||||
|
&mut vram,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
use super::sfx::MusicBox;
|
use super::sfx::MusicBox;
|
||||||
use agb::sound::mixer::Mixer;
|
use agb::{
|
||||||
|
display::background::{RegularMap, TileFormat, TileSet, TileSetting, VRamManager},
|
||||||
|
sound::mixer::Mixer,
|
||||||
|
};
|
||||||
|
|
||||||
agb::include_gfx!("gfx/splash_screens.toml");
|
agb::include_gfx!("gfx/splash_screens.toml");
|
||||||
|
|
||||||
|
@ -9,39 +12,54 @@ pub enum SplashScreen {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn show_splash_screen(
|
pub fn show_splash_screen(
|
||||||
agb: &mut agb::Gba,
|
|
||||||
which: SplashScreen,
|
which: SplashScreen,
|
||||||
mut mixer: Option<&mut Mixer>,
|
mut mixer: Option<&mut Mixer>,
|
||||||
mut music_box: Option<&mut MusicBox>,
|
mut music_box: Option<&mut MusicBox>,
|
||||||
|
map: &mut RegularMap,
|
||||||
|
vram: &mut VRamManager,
|
||||||
) {
|
) {
|
||||||
let mut tiled = agb.display.video.tiled0();
|
map.set_scroll_pos((0u16, 0u16).into());
|
||||||
|
let tile_set_ref = match which {
|
||||||
match which {
|
|
||||||
SplashScreen::Start => {
|
SplashScreen::Start => {
|
||||||
tiled.set_background_tilemap(0, splash_screens::splash.tiles);
|
let tile_set_ref = vram.add_tileset(TileSet::new(
|
||||||
tiled.set_background_palettes(splash_screens::splash.palettes);
|
splash_screens::splash.tiles,
|
||||||
|
TileFormat::FourBpp,
|
||||||
|
));
|
||||||
|
|
||||||
|
vram.set_background_palettes(splash_screens::splash.palettes);
|
||||||
|
|
||||||
|
tile_set_ref
|
||||||
}
|
}
|
||||||
SplashScreen::End => {
|
SplashScreen::End => {
|
||||||
tiled.set_background_tilemap(0, splash_screens::thanks_for_playing.tiles);
|
let tile_set_ref = vram.add_tileset(TileSet::new(
|
||||||
tiled.set_background_palettes(splash_screens::thanks_for_playing.palettes);
|
splash_screens::thanks_for_playing.tiles,
|
||||||
}
|
TileFormat::FourBpp,
|
||||||
}
|
|
||||||
let vblank = agb::interrupt::VBlank::get();
|
|
||||||
let mut splash_screen_display = tiled.get_regular().unwrap();
|
|
||||||
|
|
||||||
let mut entries: [u16; 30 * 20] = [0; 30 * 20];
|
|
||||||
for tile_id in 0..(30 * 20) {
|
|
||||||
entries[tile_id as usize] = tile_id;
|
|
||||||
}
|
|
||||||
let mut input = agb::input::ButtonController::new();
|
|
||||||
splash_screen_display.set_map(agb::display::background::Map::new(
|
|
||||||
&entries,
|
|
||||||
(30_u32, 20_u32).into(),
|
|
||||||
0,
|
|
||||||
));
|
));
|
||||||
splash_screen_display.set_position((0, 0).into());
|
|
||||||
splash_screen_display.commit();
|
vram.set_background_palettes(splash_screens::thanks_for_playing.palettes);
|
||||||
splash_screen_display.show();
|
|
||||||
|
tile_set_ref
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let vblank = agb::interrupt::VBlank::get();
|
||||||
|
|
||||||
|
let mut input = agb::input::ButtonController::new();
|
||||||
|
|
||||||
|
for y in 0..20u16 {
|
||||||
|
for x in 0..30u16 {
|
||||||
|
map.set_tile(
|
||||||
|
vram,
|
||||||
|
(x, y).into(),
|
||||||
|
tile_set_ref,
|
||||||
|
TileSetting::from_raw(y * 30 + x),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
map.commit();
|
||||||
|
map.show();
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
input.update();
|
input.update();
|
||||||
if input.is_just_pressed(
|
if input.is_just_pressed(
|
||||||
|
@ -64,5 +82,8 @@ pub fn show_splash_screen(
|
||||||
mixer.after_vblank();
|
mixer.after_vblank();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
splash_screen_display.hide();
|
|
||||||
|
map.hide();
|
||||||
|
|
||||||
|
vram.remove_tileset(tile_set_ref);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue