initial commit
This commit is contained in:
21
Cargo.lock
generated
Normal file
21
Cargo.lock
generated
Normal file
@@ -0,0 +1,21 @@
|
||||
[root]
|
||||
name = "smb"
|
||||
version = "0.0.1"
|
||||
dependencies = [
|
||||
"sdl2 0.0.7 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||
"sdl2_ttf 0.0.3 (git+https://github.com/andelf/rust-sdl2_ttf)",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
name = "sdl2"
|
||||
version = "0.0.7"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
|
||||
[[package]]
|
||||
name = "sdl2_ttf"
|
||||
version = "0.0.3"
|
||||
source = "git+https://github.com/andelf/rust-sdl2_ttf#614fdbed9f07208d280a41abf02cc91a401d6cb5"
|
||||
dependencies = [
|
||||
"sdl2 0.0.7 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||
]
|
||||
|
||||
12
Cargo.toml
Normal file
12
Cargo.toml
Normal file
@@ -0,0 +1,12 @@
|
||||
[package]
|
||||
name = "smb"
|
||||
version = "0.0.1"
|
||||
authors = ["logaritmisk <anders.e.olsson@gmail.com>"]
|
||||
|
||||
|
||||
[dependencies]
|
||||
sdl2 = "0.0.7"
|
||||
|
||||
|
||||
[dependencies.sdl2_ttf]
|
||||
git = "https://github.com/andelf/rust-sdl2_ttf"
|
||||
81
src/main.rs
Normal file
81
src/main.rs
Normal file
@@ -0,0 +1,81 @@
|
||||
extern crate sdl2;
|
||||
|
||||
|
||||
use sdl2::video::{Window, WindowPos, OPENGL};
|
||||
use sdl2::event::{poll_event, Event};
|
||||
use sdl2::timer::{get_ticks, delay};
|
||||
use sdl2::rect::{Rect};
|
||||
|
||||
|
||||
const SCREEN_WIDTH : int = 800;
|
||||
const SCREEN_HEIGHT : int = 600;
|
||||
|
||||
const MS_PER_UPDATE : uint = 10;
|
||||
|
||||
|
||||
fn main() {
|
||||
sdl2::init(sdl2::INIT_EVERYTHING);
|
||||
|
||||
let window = match Window::new("SMB", WindowPos::PosCentered, WindowPos::PosCentered, SCREEN_WIDTH, SCREEN_HEIGHT, OPENGL) {
|
||||
Ok(window) => window,
|
||||
Err(err) => panic!("failed to create window: {}", err)
|
||||
};
|
||||
|
||||
let renderer = match sdl2::render::Renderer::from_window(window, sdl2::render::RenderDriverIndex::Auto, sdl2::render::ACCELERATED) {
|
||||
Ok(renderer) => renderer,
|
||||
Err(err) => panic!("failed to create renderer: {}", err)
|
||||
};
|
||||
|
||||
let mut player = Rect::new(0, 290, 10, 10);
|
||||
|
||||
let mut x : f32 = 390.0;
|
||||
let mut v_x : f32 = 0.0;
|
||||
|
||||
let mut current : uint = 0;
|
||||
let mut elapsed : uint = 0;
|
||||
let mut lag : uint = 0;
|
||||
|
||||
let mut previous : uint = get_ticks();
|
||||
|
||||
'event : loop {
|
||||
current = get_ticks();
|
||||
elapsed = current - previous;
|
||||
previous = current;
|
||||
lag += elapsed;
|
||||
|
||||
v_x = 0.0;
|
||||
match poll_event() {
|
||||
Event::Quit(_) => break 'event,
|
||||
Event::KeyDown(_, _, key, _, _, _) => {
|
||||
if key == sdl2::keycode::KeyCode::Escape {
|
||||
break 'event;
|
||||
} else if key == sdl2::keycode::KeyCode::Right {
|
||||
v_x = 1.0;
|
||||
} else if key == sdl2::keycode::KeyCode::Left {
|
||||
v_x = -1.0;
|
||||
}
|
||||
},
|
||||
_ => (),
|
||||
}
|
||||
|
||||
while lag >= MS_PER_UPDATE {
|
||||
x += v_x;
|
||||
|
||||
lag -= MS_PER_UPDATE;
|
||||
|
||||
println!("lag: {}", lag);
|
||||
}
|
||||
|
||||
let _ = renderer.set_draw_color(sdl2::pixels::Color::RGB(0, 0, 0));
|
||||
let _ = renderer.clear();
|
||||
|
||||
player.x = x as i32;
|
||||
|
||||
let _ = renderer.set_draw_color(sdl2::pixels::Color::RGB(0, 255, 0));
|
||||
let _ = renderer.fill_rect(&player);
|
||||
|
||||
renderer.present();
|
||||
}
|
||||
|
||||
sdl2::quit();
|
||||
}
|
||||
Reference in New Issue
Block a user