mirror of
https://github.com/Xevion/Pac-Man.git
synced 2025-12-10 22:07:55 -06:00
feat: window events & canvas rendering
This commit is contained in:
73
src/main.rs
73
src/main.rs
@@ -1,55 +1,96 @@
|
|||||||
use sdl2::pixels::Color;
|
use crate::constants::{WINDOW_HEIGHT, WINDOW_WIDTH};
|
||||||
use sdl2::event::Event;
|
use sdl2::event::{Event, WindowEvent};
|
||||||
use sdl2::image::LoadTexture;
|
use sdl2::image::LoadTexture;
|
||||||
use sdl2::keyboard::{Keycode, Mod};
|
use sdl2::keyboard::Keycode;
|
||||||
|
use sdl2::pixels::Color;
|
||||||
|
use sdl2::render::{Texture, Canvas};
|
||||||
use std::time::Duration;
|
use std::time::Duration;
|
||||||
use crate::constants::{WINDOW_WIDTH, WINDOW_HEIGHT};
|
|
||||||
|
|
||||||
#[cfg(target_os = "emscripten")]
|
#[cfg(target_os = "emscripten")]
|
||||||
pub mod emscripten;
|
pub mod emscripten;
|
||||||
|
|
||||||
mod constants;
|
|
||||||
mod board;
|
mod board;
|
||||||
|
mod constants;
|
||||||
mod game;
|
mod game;
|
||||||
|
|
||||||
|
fn redraw(canvas: &mut Canvas<sdl2::video::Window>, tex: &Texture, i: u8) {
|
||||||
|
canvas.set_draw_color(Color::RGB(i, i, i));
|
||||||
|
canvas.clear();
|
||||||
|
canvas
|
||||||
|
.copy(tex, None, None)
|
||||||
|
.expect("Could not render texture on canvas");
|
||||||
|
}
|
||||||
|
|
||||||
pub fn main() {
|
pub fn main() {
|
||||||
let sdl_context = sdl2::init().unwrap();
|
let sdl_context = sdl2::init().unwrap();
|
||||||
let video_subsystem = sdl_context.video().unwrap();
|
let video_subsystem = sdl_context.video().unwrap();
|
||||||
|
|
||||||
let window = video_subsystem.window("Pac-Man", WINDOW_WIDTH, WINDOW_HEIGHT)
|
let window = video_subsystem
|
||||||
|
.window("Pac-Man", WINDOW_WIDTH, WINDOW_HEIGHT)
|
||||||
.position_centered()
|
.position_centered()
|
||||||
|
.resizable()
|
||||||
.build()
|
.build()
|
||||||
.expect("Could not initialize window");
|
.expect("Could not initialize window");
|
||||||
|
|
||||||
let mut canvas = window.into_canvas().build().expect("Could not build canvas");
|
let mut canvas = window
|
||||||
|
.into_canvas()
|
||||||
|
.build()
|
||||||
|
.expect("Could not build canvas");
|
||||||
let texture_creator = canvas.texture_creator();
|
let texture_creator = canvas.texture_creator();
|
||||||
|
|
||||||
let map_texture = texture_creator.load_texture("assets/map.png").expect("Could not load pacman texture");
|
let map_texture = texture_creator
|
||||||
canvas.copy(&map_texture, None, None).expect("Could not render texture on canvas");
|
.load_texture("assets/map.png")
|
||||||
|
.expect("Could not load pacman texture");
|
||||||
|
|
||||||
|
canvas
|
||||||
|
.copy(&map_texture, None, None)
|
||||||
|
.expect("Could not render texture on canvas");
|
||||||
|
|
||||||
|
let mut i = 0u8;
|
||||||
|
|
||||||
|
let mut event_pump = sdl_context
|
||||||
|
.event_pump()
|
||||||
|
.expect("Could not get SDL EventPump");
|
||||||
|
|
||||||
let mut event_pump = sdl_context.event_pump().expect("Could not get SDL EventPump");
|
|
||||||
let mut main_loop = || {
|
let mut main_loop = || {
|
||||||
for event in event_pump.poll_iter() {
|
for event in event_pump.poll_iter() {
|
||||||
match event {
|
match event {
|
||||||
Event::Quit { .. } |
|
// Handle quitting keys or window close
|
||||||
Event::KeyDown { keycode: Some(Keycode::Q), .. } => break,
|
Event::Quit { .. }
|
||||||
|
| Event::KeyDown {
|
||||||
|
keycode: Some(Keycode::Escape) | Some(Keycode::Q),
|
||||||
|
..
|
||||||
|
} => return false,
|
||||||
event @ Event::KeyDown { .. } => {
|
event @ Event::KeyDown { .. } => {
|
||||||
println!("{:?}", event);
|
println!("{:?}", event);
|
||||||
}
|
},
|
||||||
|
Event::Window { win_event, .. } => {
|
||||||
|
if let WindowEvent::Resized(width, height) = win_event {
|
||||||
|
i = i.wrapping_add(1);
|
||||||
|
|
||||||
|
canvas.set_logical_size(width as u32, height as u32).unwrap();
|
||||||
|
redraw(&mut canvas, &map_texture, i);
|
||||||
|
}
|
||||||
|
},
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
canvas.present();
|
canvas.present();
|
||||||
::std::thread::sleep(Duration::from_millis(10));
|
::std::thread::sleep(Duration::from_millis(10));
|
||||||
|
true
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(target_os = "emscripten")]
|
#[cfg(target_os = "emscripten")]
|
||||||
use emscripten::{emscripten};
|
use emscripten::emscripten;
|
||||||
|
|
||||||
#[cfg(target_os = "emscripten")]
|
#[cfg(target_os = "emscripten")]
|
||||||
emscripten::set_main_loop_callback(main_loop);
|
emscripten::set_main_loop_callback(main_loop);
|
||||||
|
|
||||||
#[cfg(not(target_os = "emscripten"))]
|
#[cfg(not(target_os = "emscripten"))]
|
||||||
loop { main_loop(); }
|
loop {
|
||||||
}
|
if !main_loop() {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user