X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmain.rs;h=0cb2ecfadb754f30b6dff5007a20643f596246c1;hb=c315bb317cbd779063cb0135abe731886de30838;hp=7182836a5925442e970bbfe8c7deb9e4d68e39bc;hpb=296187ca027364405cf2fd95e727d5d1eaaec4fc;p=kaka%2Frust-sdl-test.git diff --git a/src/main.rs b/src/main.rs index 7182836..0cb2ecf 100644 --- a/src/main.rs +++ b/src/main.rs @@ -22,7 +22,7 @@ use sdl2::video::Window; use sdl2::video::WindowContext; use time::PreciseTime; -use boll::Boll; +use boll::{Boll, SquareBoll}; use common::Point2D; #[macro_use] mod common; @@ -33,6 +33,8 @@ const SCREEN_HEIGHT: u32 = (SCREEN_WIDTH as f64 * (1440.0 / 2560.0)) as u32; const FPS: u32 = 60; const NS_PER_FRAME: u32 = 1_000_000_000 / FPS; +type Bollar = Vec>; + fn init() -> (Canvas, EventPump) { let context = sdl2::init().unwrap(); let video = context.video().unwrap(); @@ -66,7 +68,7 @@ fn main() { let mut frame_count: u64 = 0; let mut fps_time = PreciseTime::now(); - let mut bolls: Vec = Vec::new(); + let mut bolls: Bollar = Bollar::new(); let mut boll_size = 1; let texture_creator = canvas.texture_creator(); @@ -123,10 +125,10 @@ fn main() { } Event::KeyDown { keycode: Some(Keycode::KpPlus), .. } => { boll_size = std::cmp::min(boll_size + 1, 32) } Event::KeyDown { keycode: Some(Keycode::KpMinus), .. } => { boll_size = std::cmp::max(boll_size - 1, 1) } - Event::MouseMotion { x, y, .. } => { bolls.push(Boll { + Event::MouseMotion { x, y, .. } => { bolls.push(Box::new(SquareBoll { pos: point!(x as f64, y as f64), vel: point!(0.0, 0.0), - }) } + })) } _ => {} } } @@ -150,7 +152,7 @@ fn main() { println!("number of bolls: {}", bolls.len()); } -fn change_boll_count(mut bolls: &mut Vec, delta: i32) { +fn change_boll_count(mut bolls: &mut Bollar, delta: i32) { if delta > 0 { for _i in 0..delta { add_boll(&mut bolls); @@ -162,10 +164,10 @@ fn change_boll_count(mut bolls: &mut Vec, delta: i32) { } } -fn add_boll(bolls: &mut Vec) { +fn add_boll(bolls: &mut Bollar) { let mut rng = rand::thread_rng(); - bolls.push(Boll { + bolls.push(Box::new(SquareBoll { pos: point!(rng.gen_range(0, SCREEN_WIDTH) as f64, rng.gen_range(0, SCREEN_HEIGHT) as f64), vel: point!(rng.gen_range(-2.0, 2.0), rng.gen_range(-2.0, 2.0)), - }); + })); }