Go to file
tomaka e90f377b9f Merge pull request #565 from tomaka/correct-example
Use modern GL code for the examples
2015-08-07 22:55:54 +02:00
.cargo Add basic support for Android 2014-09-11 18:28:07 +02:00
examples Use modern GL code for the examples 2015-08-05 22:31:34 +02:00
src Correctly handle eglGetDisplay 2015-08-07 16:22:31 +02:00
tests Add test for WindowProxy to implement Send 2015-02-16 10:29:53 +01:00
.gitattributes Initial commit 2014-07-27 11:41:26 +02:00
.gitignore Add basic support for Android 2014-09-11 18:28:07 +02:00
.gitmodules Add basic support for Android 2014-09-11 18:28:07 +02:00
.travis.yml Fix docs publication not working 2015-05-21 19:45:58 +02:00
appveyor.yml Test glutin with MSVC++ 2015-07-04 13:57:29 +02:00
build.rs Merge pull request #565 from tomaka/correct-example 2015-08-07 22:55:54 +02:00
Cargo.toml Publish 0.3.4 2015-07-25 16:15:00 +02:00
LICENSE Initial commit 2014-07-27 11:41:26 +02:00
README.md Remove the is_closed function 2015-06-16 14:03:58 +02:00

glutin - OpenGL, UTilities and INput

![Gitter](https://badges.gitter.im/Join Chat.svg)

Alternative to GLFW in pure Rust.

Build Status Build status

[dependencies]
glutin = "*"

Documentation

Try it!

git clone https://github.com/tomaka/glutin
cd glutin
cargo run --example window

Usage

Glutin is an OpenGL context creation library and doesn't directly provide OpenGL bindings for you.

[dependencies]
gl = "*"
libc = "*"
extern crate gl;
extern crate glutin;
extern crate libc;

fn main() {
    let window = glutin::Window::new().unwrap();

    unsafe { window.make_current() };

    unsafe {
        gl::load_with(|symbol| window.get_proc_address(symbol));

        gl::ClearColor(0.0, 1.0, 0.0, 1.0);
    }

    for event in window.wait_events() {
        unsafe { gl::Clear(gl::COLOR_BUFFER_BIT) };
        window.swap_buffers();

        match event {
            glutin::Event::Closed => break,
            _ => ()
        }
    }
}

Note that glutin aims at being a low-level brick in your rendering infrastructure. You are encouraged to write another layer of abstraction between glutin and your application.

Platform-specific notes

Android

  • To compile the examples for android, initialize the submodules, go to deps/apk-builder/apk-builder and run cargo build, then go back to glutin and call ANDROID_HOME=/path/to/sdk NDK_HOME=/path/to/ndk NDK_STANDALONE=/path/to/standalone cargo test --no-run --target=arm-linux-androideabi

X11

  • The plan is that glutin tries to dynamically link-to and use wayland if possible. If it doesn't work, it will try xlib instead. If it doesn't work, it will try libcaca. This is work-in-progress.