mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-11 17:41:33 +11:00
add rotation to sprite example
This commit is contained in:
parent
7265576e2a
commit
875d53c040
|
@ -3,7 +3,12 @@
|
||||||
|
|
||||||
extern crate alloc;
|
extern crate alloc;
|
||||||
|
|
||||||
use agb::display::object::{Graphics, OAMManager, Sprite, TagMap};
|
use agb::display::{
|
||||||
|
affine::AffineMatrix,
|
||||||
|
object::{self, Graphics, OAMManager, Sprite, TagMap},
|
||||||
|
};
|
||||||
|
use agb::fixnum::num;
|
||||||
|
use agb_fixnum::Num;
|
||||||
use alloc::vec::Vec;
|
use alloc::vec::Vec;
|
||||||
|
|
||||||
const GRAPHICS: &Graphics = agb::include_aseprite!(
|
const GRAPHICS: &Graphics = agb::include_aseprite!(
|
||||||
|
@ -15,14 +20,20 @@ const GRAPHICS: &Graphics = agb::include_aseprite!(
|
||||||
const SPRITES: &[Sprite] = GRAPHICS.sprites();
|
const SPRITES: &[Sprite] = GRAPHICS.sprites();
|
||||||
const TAG_MAP: &TagMap = GRAPHICS.tags();
|
const TAG_MAP: &TagMap = GRAPHICS.tags();
|
||||||
|
|
||||||
fn all_sprites(gfx: &OAMManager) {
|
fn all_sprites(gfx: &OAMManager, rotation_speed: Num<i32, 16>) {
|
||||||
let mut input = agb::input::ButtonController::new();
|
let mut input = agb::input::ButtonController::new();
|
||||||
let mut objs = Vec::new();
|
let mut objs = Vec::new();
|
||||||
|
|
||||||
|
let mut rotation: Num<i32, 16> = num!(0.);
|
||||||
|
|
||||||
|
let rotation_matrix = AffineMatrix::from_rotation(rotation);
|
||||||
|
let matrix = object::AffineMatrix::new(rotation_matrix.to_object_wrapping());
|
||||||
|
|
||||||
for y in 0..9 {
|
for y in 0..9 {
|
||||||
for x in 0..14 {
|
for x in 0..14 {
|
||||||
let mut obj = gfx.add_object_static_sprite(&SPRITES[0]);
|
let mut obj = gfx.add_object_static_sprite(&SPRITES[0]);
|
||||||
obj.show();
|
obj.set_affine_matrix(matrix.clone());
|
||||||
|
obj.show_affine(object::AffineMode::Affine);
|
||||||
obj.set_position((x * 16 + 8, y * 16 + 8).into());
|
obj.set_position((x * 16 + 8, y * 16 + 8).into());
|
||||||
objs.push(obj);
|
objs.push(obj);
|
||||||
}
|
}
|
||||||
|
@ -41,6 +52,15 @@ fn all_sprites(gfx: &OAMManager) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rotation += rotation_speed;
|
||||||
|
let rotation_matrix = AffineMatrix::from_rotation(rotation);
|
||||||
|
|
||||||
|
let matrix = object::AffineMatrix::new(rotation_matrix.to_object_wrapping());
|
||||||
|
|
||||||
|
for obj in objs.iter_mut() {
|
||||||
|
obj.set_affine_matrix(matrix.clone());
|
||||||
|
}
|
||||||
|
|
||||||
count += 1;
|
count += 1;
|
||||||
|
|
||||||
if count % 5 == 0 {
|
if count % 5 == 0 {
|
||||||
|
@ -50,8 +70,8 @@ fn all_sprites(gfx: &OAMManager) {
|
||||||
let this_image = (image + i) % SPRITES.len();
|
let this_image = (image + i) % SPRITES.len();
|
||||||
obj.set_sprite(gfx.get_vram_sprite(&SPRITES[this_image]));
|
obj.set_sprite(gfx.get_vram_sprite(&SPRITES[this_image]));
|
||||||
}
|
}
|
||||||
gfx.commit();
|
|
||||||
}
|
}
|
||||||
|
gfx.commit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,8 +123,7 @@ fn main(mut gba: agb::Gba) -> ! {
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
all_tags(&gfx);
|
all_tags(&gfx);
|
||||||
gfx.commit();
|
all_sprites(&gfx, num!(0.));
|
||||||
all_sprites(&gfx);
|
all_sprites(&gfx, num!(0.01));
|
||||||
gfx.commit();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue