mirror of
https://github.com/italicsjenga/agb.git
synced 2025-01-11 01:21:34 +11:00
Merge pull request #1 from gwilymk/textrender-rework-gwilym
Textrender rework gwilym
This commit is contained in:
commit
3b19088b5b
|
@ -40,7 +40,8 @@ fn main(mut gba: agb::Gba) -> ! {
|
||||||
|
|
||||||
vram.remove_dynamic_tile(background_tile);
|
vram.remove_dynamic_tile(background_tile);
|
||||||
|
|
||||||
let mut writer = FONT.render_text((0u16, 3u16).into(), 1, 2, &mut bg, &mut vram);
|
let mut renderer = FONT.render_text((0u16, 3u16).into());
|
||||||
|
let mut writer = renderer.writer(1, 2, &mut bg, &mut vram);
|
||||||
|
|
||||||
writeln!(&mut writer, "Hello, World!").unwrap();
|
writeln!(&mut writer, "Hello, World!").unwrap();
|
||||||
writeln!(&mut writer, "This is a font rendering example").unwrap();
|
writeln!(&mut writer, "This is a font rendering example").unwrap();
|
||||||
|
@ -53,7 +54,8 @@ fn main(mut gba: agb::Gba) -> ! {
|
||||||
let mut frame = 0;
|
let mut frame = 0;
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
let mut writer = FONT.render_text((4u16, 0u16).into(), 1, 2, &mut bg, &mut vram);
|
let mut renderer = FONT.render_text((4u16, 0u16).into());
|
||||||
|
let mut writer = renderer.writer(1, 2, &mut bg, &mut vram);
|
||||||
|
|
||||||
writeln!(&mut writer, "Frame {}", frame).unwrap();
|
writeln!(&mut writer, "Frame {}", frame).unwrap();
|
||||||
writer.commit();
|
writer.commit();
|
||||||
|
@ -62,5 +64,7 @@ fn main(mut gba: agb::Gba) -> ! {
|
||||||
|
|
||||||
vblank.wait_for_vblank();
|
vblank.wait_for_vblank();
|
||||||
bg.commit(&mut vram);
|
bg.commit(&mut vram);
|
||||||
|
|
||||||
|
renderer.clear(&mut vram);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,8 +8,7 @@ use super::tiled::{DynamicTile, RegularMap, TileSetting, VRamManager};
|
||||||
/// The text renderer renders a variable width fixed size
|
/// The text renderer renders a variable width fixed size
|
||||||
/// bitmap font using dynamic tiles as a rendering surface.
|
/// bitmap font using dynamic tiles as a rendering surface.
|
||||||
/// Does not support any unicode features.
|
/// Does not support any unicode features.
|
||||||
/// For usage see the `text_render.rs` example
|
/// For usage see the `text_render.rs` example
|
||||||
|
|
||||||
pub struct FontLetter {
|
pub struct FontLetter {
|
||||||
width: u8,
|
width: u8,
|
||||||
height: u8,
|
height: u8,
|
||||||
|
@ -75,8 +74,8 @@ impl Font {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Keeps track of the cursor and manages rendered tiles.
|
||||||
pub struct TextRenderer<'a> {
|
pub struct TextRenderer<'a> {
|
||||||
/// Keeps track of the cursor and manages rendered tiles.
|
|
||||||
current_x_pos: i32,
|
current_x_pos: i32,
|
||||||
current_y_pos: i32,
|
current_y_pos: i32,
|
||||||
font: &'a Font,
|
font: &'a Font,
|
||||||
|
@ -84,17 +83,17 @@ pub struct TextRenderer<'a> {
|
||||||
tiles: HashMap<(i32, i32), DynamicTile<'a>>,
|
tiles: HashMap<(i32, i32), DynamicTile<'a>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct TextWriter<'a, 'b: 'a, 'c> {
|
/// Generated from the renderer for use
|
||||||
/// Generated from the renderer for use
|
/// with `Write` trait methods.
|
||||||
/// with `Write` trait methods.
|
pub struct TextWriter<'a, 'b> {
|
||||||
foreground_colour: u8,
|
foreground_colour: u8,
|
||||||
background_colour: u8,
|
background_colour: u8,
|
||||||
text_renderer: &'a mut TextRenderer<'c>,
|
text_renderer: &'a mut TextRenderer<'b>,
|
||||||
vram_manager: &'b mut VRamManager,
|
vram_manager: &'a mut VRamManager,
|
||||||
bg: &'b mut RegularMap,
|
bg: &'a mut RegularMap,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'b, 'c> Write for TextWriter<'a, 'b, 'c> {
|
impl<'a, 'b> Write for TextWriter<'a, 'b> {
|
||||||
fn write_str(&mut self, text: &str) -> Result<(), Error> {
|
fn write_str(&mut self, text: &str) -> Result<(), Error> {
|
||||||
for c in text.chars() {
|
for c in text.chars() {
|
||||||
self.text_renderer.write_char(
|
self.text_renderer.write_char(
|
||||||
|
@ -108,8 +107,8 @@ impl<'a, 'b, 'c> Write for TextWriter<'a, 'b, 'c> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
impl<'a, 'b, 'c> TextWriter<'a, 'b, 'c> {
|
|
||||||
/// Calls commit on the parent renderer, consuming the writer.
|
impl<'a, 'b> TextWriter<'a, 'b> {
|
||||||
pub fn commit(self) {
|
pub fn commit(self) {
|
||||||
self.text_renderer.commit(self.bg, self.vram_manager);
|
self.text_renderer.commit(self.bg, self.vram_manager);
|
||||||
}
|
}
|
||||||
|
@ -119,14 +118,14 @@ fn div_ceil(quotient: i32, divisor: i32) -> i32 {
|
||||||
(quotient + divisor - 1) / divisor
|
(quotient + divisor - 1) / divisor
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'b, 'c> TextRenderer<'c> {
|
impl<'a, 'b> TextRenderer<'b> {
|
||||||
pub fn writer(
|
pub fn writer(
|
||||||
&'a mut self,
|
&'a mut self,
|
||||||
foreground_colour: u8,
|
foreground_colour: u8,
|
||||||
background_colour: u8,
|
background_colour: u8,
|
||||||
bg: &'b mut RegularMap,
|
bg: &'a mut RegularMap,
|
||||||
vram_manager: &'b mut VRamManager,
|
vram_manager: &'a mut VRamManager,
|
||||||
) -> TextWriter<'a, 'b, 'c> {
|
) -> TextWriter<'a, 'b> {
|
||||||
TextWriter {
|
TextWriter {
|
||||||
text_renderer: self,
|
text_renderer: self,
|
||||||
foreground_colour,
|
foreground_colour,
|
||||||
|
@ -205,8 +204,9 @@ impl<'a, 'b, 'c> TextRenderer<'c> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Commit the dynamic tiles that contain the text to the background.
|
/// Commit the dynamic tiles that contain the text to the background.
|
||||||
pub fn commit(&self, bg: &'b mut RegularMap, vram_manager: &'b mut VRamManager) {
|
pub fn commit(&self, bg: &'a mut RegularMap, vram_manager: &'a mut VRamManager) {
|
||||||
for ((x, y), tile) in self.tiles.iter() {
|
for ((x, y), tile) in self.tiles.iter() {
|
||||||
bg.set_tile(
|
bg.set_tile(
|
||||||
vram_manager,
|
vram_manager,
|
||||||
|
@ -216,6 +216,7 @@ impl<'a, 'b, 'c> TextRenderer<'c> {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Write another char into the text, moving the cursor as appropriate.
|
/// Write another char into the text, moving the cursor as appropriate.
|
||||||
pub fn write_char(
|
pub fn write_char(
|
||||||
&mut self,
|
&mut self,
|
||||||
|
|
Loading…
Reference in a new issue