From f3178df0a92fb3b87087e78cad7b9313f947be6a Mon Sep 17 00:00:00 2001 From: Arne Dußin Date: Wed, 5 May 2021 23:40:17 +0200 Subject: Initial commit --- src/systems/draw.rs | 58 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 src/systems/draw.rs (limited to 'src/systems/draw.rs') diff --git a/src/systems/draw.rs b/src/systems/draw.rs new file mode 100644 index 0000000..1d5ee6b --- /dev/null +++ b/src/systems/draw.rs @@ -0,0 +1,58 @@ +use sdl2::pixels::Color; +use sdl2::render::WindowCanvas; +use sdl2::video::{Window, WindowContext}; +use specs::prelude::*; + +use crate::components::{Pos, StaticDrawable}; +use crate::texture_manager::TextureManager; + +pub struct SysDraw +{ + canvas: WindowCanvas, + texture_manager: TextureManager, +} + +impl SysDraw +{ + pub fn new(window: Window) -> Self + { + let mut canvas = window + .into_canvas() + .build() + .expect("Unable to create canvas"); + canvas.set_draw_color(Color::RGB(255, 255, 0)); + + let texture_manager = TextureManager::new(canvas.texture_creator()); + + Self { + canvas, + texture_manager, + } + } +} + +impl<'a> System<'a> for SysDraw +{ + type SystemData = (ReadStorage<'a, Pos>, ReadStorage<'a, StaticDrawable>); + + fn run(&mut self, (pos, drawable): Self::SystemData) + { + self.canvas.clear(); + + // XXX: This is so slow.. yaaaawn. Replace with ids and texture manager + // lifetime? + for (_pos, drawable) in (&pos, &drawable).join() { + let texture = self + .texture_manager + .get(&drawable.texture_name) + .expect("Unable to load texture"); + + // let texture_info = texture.query(); + self.canvas + .copy(&texture, None, None) + .expect("Unable to draw texture"); + } + + self.canvas.present(); + } +} -- cgit v1.2.3-70-g09d2