winit-sonoma-fix/README.md

56 lines
2 KiB
Markdown
Raw Normal View History

2016-10-31 17:19:37 +01:00
# winit - Cross-platform window creation and management in Rust
2014-07-27 10:55:37 +02:00
2016-10-31 17:19:37 +01:00
[![](http://meritbadge.herokuapp.com/winit)](https://crates.io/crates/winit)
2015-05-04 15:18:03 +02:00
2016-10-31 17:19:37 +01:00
[![Docs.rs](https://docs.rs/winit/badge.svg)](https://docs.rs/winit)
2016-09-05 22:10:15 +03:00
2016-10-31 17:19:37 +01:00
[![Build Status](https://travis-ci.org/tomaka/winit.png?branch=master)](https://travis-ci.org/tomaka/winit)
[![Build status](https://ci.appveyor.com/api/projects/status/5h87hj0g4q2xe3j9/branch/master?svg=true)](https://ci.appveyor.com/project/tomaka/winit/branch/master)
2014-09-19 19:51:54 +02:00
2015-02-15 18:28:12 +01:00
```toml
[dependencies]
2017-06-24 17:08:05 +10:00
winit = "0.7"
2015-02-15 18:28:12 +01:00
```
2016-10-31 17:19:37 +01:00
## [Documentation](https://docs.rs/winit)
2014-07-28 11:45:59 +02:00
2014-07-27 15:59:58 +02:00
## Usage
2016-10-31 17:33:36 +01:00
Winit is a window creation and management library. It can create windows and lets you handle
events (for example: the window being resized, a key being pressed, a mouse mouvement, etc.)
2016-10-31 17:19:37 +01:00
produced by window.
2015-02-22 11:31:27 +01:00
2016-10-31 17:19:37 +01:00
Winit is designed to be a low-level brick in a hierarchy of libraries. Consequently, in order to
show something on the window you need to use the platform-specific getters provided by winit, or
another library.
2015-02-22 11:31:27 +01:00
2014-07-27 15:59:58 +02:00
```rust
2016-10-31 17:19:37 +01:00
extern crate winit;
2014-07-27 15:59:58 +02:00
fn main() {
let mut events_loop = winit::EventsLoop::new();
let window = winit::Window::new(&events_loop).unwrap();
2014-07-27 15:59:58 +02:00
events_loop.run_forever(|event| {
2015-06-16 13:48:08 +02:00
match event {
winit::Event::WindowEvent { event: winit::WindowEvent::Closed, .. } => {
2017-06-20 21:34:00 +10:00
winit::ControlFlow::Break
},
_ => winit::ControlFlow::Continue,
2015-06-16 13:48:08 +02:00
}
});
2014-07-27 15:59:58 +02:00
}
```
### Platform-specific usage
#### Emscripten and WebAssembly
Building a binary will yield a `.js` file. In order to use it in an HTML file, you need to:
- Put a `<canvas id="my_id"></canvas>` element somewhere. A canvas corresponds to a winit "window".
- Write a Javascript code that creates a global variable named `Module`. Set `Module.canvas` to
the ID of the `<canvas>` element (in the example this would be `"my_id"`). More information
[here](https://kripken.github.io/emscripten-site/docs/api_reference/module.html).
- Make sure that you insert the `.js` file generated by Rust after the `Module` variable is created.