2016-11-01 03:19:37 +11:00
|
|
|
# winit - Cross-platform window creation and management in Rust
|
2014-07-27 18:55:37 +10:00
|
|
|
|
2016-11-01 03:19:37 +11:00
|
|
|
[![](http://meritbadge.herokuapp.com/winit)](https://crates.io/crates/winit)
|
|
|
|
[![Docs.rs](https://docs.rs/winit/badge.svg)](https://docs.rs/winit)
|
2019-04-25 15:20:54 +10:00
|
|
|
[![Build Status](https://travis-ci.org/rust-windowing/winit.svg?branch=master)](https://travis-ci.org/rust-windowing/winit)
|
|
|
|
[![Build status](https://ci.appveyor.com/api/projects/status/hr89but4x1n3dphq/branch/master?svg=true)](https://ci.appveyor.com/project/Osspial/winit/branch/master)
|
2014-09-20 03:51:54 +10:00
|
|
|
|
2015-02-16 04:28:12 +11:00
|
|
|
```toml
|
|
|
|
[dependencies]
|
2019-06-22 01:33:44 +10:00
|
|
|
winit = "0.20.0-alpha1"
|
2015-02-16 04:28:12 +11:00
|
|
|
```
|
|
|
|
|
2016-11-01 03:19:37 +11:00
|
|
|
## [Documentation](https://docs.rs/winit)
|
2014-07-28 19:45:59 +10:00
|
|
|
|
2019-03-20 13:20:03 +11:00
|
|
|
## Contact Us
|
|
|
|
|
|
|
|
Join us in any of these:
|
|
|
|
|
|
|
|
[![Freenode](https://img.shields.io/badge/freenode.net-%23glutin-red.svg)](http://webchat.freenode.net?channels=%23glutin&uio=MTY9dHJ1ZSYyPXRydWUmND10cnVlJjExPTE4NSYxMj10cnVlJjE1PXRydWU7a)
|
|
|
|
[![Matrix](https://img.shields.io/badge/Matrix-%23Glutin%3Amatrix.org-blueviolet.svg)](https://matrix.to/#/#Glutin:matrix.org)
|
|
|
|
[![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/tomaka/glutin?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
|
|
|
|
2014-07-27 23:59:58 +10:00
|
|
|
## Usage
|
|
|
|
|
2016-11-01 03:33:36 +11:00
|
|
|
Winit is a window creation and management library. It can create windows and lets you handle
|
2017-12-18 06:13:16 +11:00
|
|
|
events (for example: the window being resized, a key being pressed, a mouse movement, etc.)
|
2016-11-01 03:19:37 +11:00
|
|
|
produced by window.
|
2015-02-22 21:31:27 +11:00
|
|
|
|
2016-11-01 03:19:37 +11: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 21:31:27 +11:00
|
|
|
|
2014-07-27 23:59:58 +10:00
|
|
|
```rust
|
2019-06-22 01:33:15 +10:00
|
|
|
use winit::{
|
|
|
|
event::{Event, WindowEvent},
|
|
|
|
event_loop::{ControlFlow, EventLoop},
|
|
|
|
window::WindowBuilder,
|
|
|
|
};
|
2014-07-27 23:59:58 +10:00
|
|
|
|
|
|
|
fn main() {
|
2019-06-19 01:15:55 +10:00
|
|
|
let event_loop = EventLoop::new();
|
|
|
|
let window = WindowBuilder::new().build(&event_loop).unwrap();
|
2014-07-27 23:59:58 +10:00
|
|
|
|
2019-06-19 01:15:55 +10:00
|
|
|
event_loop.run(move |event, _, control_flow| {
|
2015-06-16 21:48:08 +10:00
|
|
|
match event {
|
2019-06-19 01:15:55 +10:00
|
|
|
Event::WindowEvent {
|
|
|
|
event: WindowEvent::CloseRequested,
|
|
|
|
window_id,
|
|
|
|
} if window_id == window.id() => *control_flow = ControlFlow::Exit,
|
|
|
|
_ => *control_flow = ControlFlow::Wait,
|
2015-06-16 21:48:08 +10:00
|
|
|
}
|
2017-05-22 15:03:22 +10:00
|
|
|
});
|
2014-07-27 23:59:58 +10:00
|
|
|
}
|
|
|
|
```
|
2017-09-15 00:31:34 +10:00
|
|
|
|
2018-12-30 13:02:02 +11:00
|
|
|
Winit is only officially supported on the latest stable version of the Rust compiler.
|
2018-11-20 08:56:11 +11:00
|
|
|
|
2018-11-01 19:24:56 +11:00
|
|
|
### Cargo Features
|
|
|
|
|
|
|
|
Winit provides the following features, which can be enabled in your `Cargo.toml` file:
|
|
|
|
* `serde`: Enables serialization/deserialization of certain types with [Serde](https://crates.io/crates/serde).
|
|
|
|
|
2017-09-15 00:31:34 +10: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
|
2018-03-23 03:56:21 +11:00
|
|
|
the element of the `<canvas>` element (in the example you would retrieve it via `document.getElementById("my_id")`).
|
|
|
|
More information [here](https://kripken.github.io/emscripten-site/docs/api_reference/module.html).
|
2017-09-15 00:31:34 +10:00
|
|
|
- Make sure that you insert the `.js` file generated by Rust after the `Module` variable is created.
|