diff options
Diffstat (limited to 'src/main.rs')
| -rw-r--r-- | src/main.rs | 147 |
1 files changed, 119 insertions, 28 deletions
diff --git a/src/main.rs b/src/main.rs index e106cb2..eab790e 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,12 +1,24 @@ +/* ************************************************************************** */ +/* */ +/* . */ +/* main.rs / \ */ +/* / \ */ +/* By: charles <charles.cabergs@gmail.com> /o o \ */ +/* / v \ */ +/* Created: 2020/06/25 11:42:17 by charles / _ \ */ +/* Updated: 2020/06/25 13:24:00 by charles '-----------' */ +/* */ +/* ************************************************************************** */ + use sdl2::ttf; -use sdl2::event::{Event}; +use sdl2::event::{Event, WindowEvent}; use sdl2::keyboard::Keycode; use sdl2::pixels::Color; use sdl2::rect::Rect; +use sdl2::render::{Texture, TextureCreator}; pub mod time; pub mod scramble; -pub mod text; pub mod history; use scramble::Scramble; @@ -15,33 +27,43 @@ use history::History; const WIDTH: u32 = 640; const HEIGHT: u32 = 480; const TITLE: &str = "rutikmer"; -const FONT_SIZE: u32 = 40; +const FONT_SIZE: u32 = 20; + +const CENTER_Y: u32 = HEIGHT / 2; +const CENTER_X: u32 = WIDTH / 2; +const WHITE: Color = Color::RGB(0xff, 0xff, 0xff); const GREEN: Color = Color::RGB(0x1B, 0x5E, 0x20); const ORANGE: Color = Color::RGB(0xEF, 0x6C, 0x00); const BLACK: Color = Color::RGB(0x00, 0x00, 0x00); +fn str_to_tex<'a, T>(s: &str, font: &ttf::Font, creator: &'a TextureCreator<T>, bg: Color) -> Texture<'a> { + let surface = font.render(s).shaded(WHITE, bg).unwrap(); + creator.create_texture_from_surface(&surface).unwrap() +} + +fn pad_rect(rect: &mut Rect, pad: u32) { + rect.resize(rect.width() - pad, rect.height() - pad); + rect.offset(pad as i32 / 2, pad as i32 / 2); +} + fn main() { let sdl = sdl2::init().unwrap(); let ttf = ttf::init().unwrap(); let video_subsys = sdl.video().unwrap(); let window = video_subsys .window(TITLE, WIDTH, HEIGHT) - .resizable() .build() .unwrap(); let font = ttf.load_font("font/FiraMono-Regular.ttf", FONT_SIZE as u16).unwrap(); - let hist = History::from_csv("history.csv"); - let mut canvas = window.into_canvas().build().unwrap(); let mut event_pump = sdl.event_pump().unwrap(); let tex_creator = canvas.texture_creator(); + let hist = History::from_csv("history.csv"); let mut timer = time::Timer::new(); - let timer_rect = Rect::new(10, 10, 100, 40); - let mut text_factory = text::Factory::new(&font, &tex_creator, BLACK, FONT_SIZE); - - let mut scramble_str = Scramble::new_rand(10).to_string(); + let mut scramble_tex = str_to_tex(&Scramble::new_rand(10).to_string(), &font, &tex_creator, BLACK); + let mut timer_tex = str_to_tex(&timer.to_string(), &font, &tex_creator, BLACK); 'running: loop { for e in event_pump.poll_iter() { @@ -49,12 +71,14 @@ fn main() { Event::Quit {..} => break 'running, Event::KeyDown { keycode: Some(Keycode::Space), repeat: false, .. } => { match timer.state { - time::State::Idle => {}, - time::State::Active => timer.stop(), time::State::Inactive => { timer.idle(); - scramble_str = Scramble::new_rand(10).to_string(); + scramble_tex = str_to_tex(&Scramble::new_rand(10).to_string(), + &font, &tex_creator, BLACK); + timer_tex = str_to_tex(&timer.to_string(), &font, &tex_creator, BLACK); }, + time::State::Idle => {}, + time::State::Active => timer.stop(), } } Event::KeyUp { keycode: Some(Keycode::Space), repeat: false, .. } => { @@ -62,34 +86,101 @@ fn main() { timer.start(); } }, - - // Event::Window { win_event: WindowEvent::Resized(w, h), .. } => - // ui.set_layout(w as u32, h as u32), _ => {} } } let bg_color = match timer.state { + time::State::Inactive => BLACK, time::State::Idle => ORANGE, time::State::Active => GREEN, - time::State::Inactive => BLACK, }; canvas.set_draw_color(bg_color); - text_factory.set_bg(bg_color); canvas.clear(); - if timer.state != time::State::Idle { - canvas.copy(&text_factory.from_string(&timer.to_string()), None, timer_rect).unwrap(); - } + match timer.state { + time::State::Inactive => { - if timer.state == time::State::Inactive { - canvas.copy(&text_factory.from_string(&scramble_str), None, Rect::new(10, 100, 500, 40)).unwrap(); - let sum = hist.summary(3); - for (i, s) in sum.iter().enumerate() { - canvas.copy(&text_factory.from_string(&s), None, Rect::new(10, 200 + 40 * (i as i32), 200, 30)).unwrap(); - } + let mut history_rect = Rect::new(0, 0, WIDTH/ 3, HEIGHT); + let mut scramble_rect = Rect::new(WIDTH as i32 / 3, 0, 2 * WIDTH / 3, HEIGHT / 3); + let mut timer_rect = Rect::new(WIDTH as i32 / 3, HEIGHT as i32 / 3, + 2 * WIDTH / 3, 2 * HEIGHT / 3); + canvas.set_draw_color(WHITE); + canvas.draw_rect(history_rect).unwrap(); + canvas.draw_rect(scramble_rect).unwrap(); + canvas.draw_rect(timer_rect).unwrap(); + + pad_rect(&mut history_rect, 10); + pad_rect(&mut scramble_rect, 20); + pad_rect(&mut timer_rect, 40); + scramble_rect.set_height(FONT_SIZE * 2); + timer_rect.set_height(FONT_SIZE * 2); + timer_rect.set_width(timer.to_string().len() as u32 * FONT_SIZE); + + canvas.copy(&scramble_tex, None, scramble_rect).unwrap(); + canvas.copy(&timer_tex, None, timer_rect).unwrap(); + + let mut entry_rect = history_rect; + entry_rect.set_height(entry_rect.height() / 5); + for entry in hist.summarize(5) { + let entry_tex = str_to_tex(&entry.to_string(), &font, &tex_creator, BLACK); + canvas.copy(&entry_tex, None, entry_rect).unwrap(); + entry_rect.set_y(entry_rect.y() + history_rect.height() as i32 / 5); + } + }, + time::State::Idle => {}, + time::State::Active => { + let s = timer.to_string(); + timer_tex = str_to_tex(&s, &font, &tex_creator, GREEN); + let h: u32 = FONT_SIZE * 2; + let w: u32 = s.len() as u32 * FONT_SIZE; + let dest = Rect::new((CENTER_X - w / 2) as i32, (CENTER_Y - h / 2) as i32, w, h); + canvas.copy(&timer_tex, None, dest).unwrap(); + }, } canvas.present(); - std::thread::sleep(std::time::Duration::new(0, 30_000_000)); + if timer.state != time::State::Active { + std::thread::sleep(std::time::Duration::new(0, 40_000_000)); + } else { + std::thread::sleep(std::time::Duration::new(0, 10_000_000)); + } } } + +/* inactive (all black) + * +------------+---------------------+ + * | history | scramble | + * | | | + * | | | + * | | | + * | |---------------------| + * | | | + * | | timer | + * | | | + * | | | + * +------------+---------------------+ + * idle (all yellow) + * +------------+---------------------+ + * | | + * | | + * | | + * | | + * | | + * | | + * | | + * | | + * | | + * +------------+---------------------+ + * active (all green) + * +------------+---------------------+ + * | | + * | | + * | | + * | timer | + * | | + * | | + * | | + * | | + * | | + * +------------+---------------------+ + */ |
