aboutsummaryrefslogtreecommitdiffstats
path: root/examples/vsync.rs
blob: 4ae25984fb168d435288306f422e60e0eef0a3f2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#[cfg(target_os = "android")]
#[macro_use]
extern crate android_glue;

extern crate clock_ticks;
extern crate glutin;

mod support;

#[cfg(target_os = "android")]
android_start!(main);

#[cfg(not(feature = "window"))]
fn main() { println!("This example requires glutin to be compiled with the `window` feature"); }

#[cfg(feature = "window")]
fn resize_callback(width: u32, height: u32) {
    println!("Window resized to {}x{}", width, height);
}

#[cfg(feature = "window")]
fn main() {
    println!("Vsync example. This example may panic if your driver or your system forces \
              you out of vsync. This is intended when `build_strict` is used.");

    let mut window = glutin::WindowBuilder::new().with_gl_profile(glutin::GlProfile::Compatibility)
                                                 .with_vsync()
                                                 .build_strict().unwrap();
    window.set_window_resize_callback(Some(resize_callback as fn(u32, u32)));
    unsafe { window.make_current() };

    let context = support::load(&window);

    while !window.is_closed() {
        let before = clock_ticks::precise_time_ns();

        context.draw_frame((0.0, 1.0, 0.0, 1.0));
        window.swap_buffers();

        for ev in window.poll_events() {
            println!("{:?}", ev);
        }

        let after = clock_ticks::precise_time_ns();
        println!("Vsync example - Time of previous frame: {}ms",
                 (after - before) as f32 / 1000000.0);
    }
}