2016-01-04 22:40:38 +01:00
[![Crates.io ](https://img.shields.io/crates/v/minifb.svg )](https://crates.io/crates/minifb)
2016-01-04 22:58:47 +01:00
[![Build Status ](https://travis-ci.org/emoon/rust_minifb.svg )](https://travis-ci.org/emoon/rust_minifb)
2016-01-04 23:18:04 +01:00
[![Build Status ](https://ci.appveyor.com/api/projects/status/sfvgqq4d4sjulkbx?svg=true )](https://ci.appveyor.com/project/emoon/rust-minifb)
2016-09-18 10:18:11 +02:00
[![Documentation ](https://docs.rs/minifb/badge.svg )](https://docs.rs/minifb)
2015-11-22 18:55:38 +01:00
2016-07-26 14:43:45 +03:00
minifb is a cross platform library written in [Rust ](https://www.rust-lang.org ) and that makes it easy to setup a window and to (optional) display a 32-bit pixel buffer. It also makes it easy to get input from keyboard and mouse.
2016-01-31 18:34:05 +01:00
An example is the best way to show how it works:
2015-11-23 19:46:51 +01:00
2016-09-18 10:18:11 +02:00
[Changelog ](https://github.com/emoon/rust_minifb/blob/master/CHANGELOG.md )
2016-01-04 22:40:38 +01:00
2016-01-03 08:29:37 +01:00
Usage
-----
```toml
# Cargo.toml
[dependencies]
2018-12-19 23:22:36 -07:00
minifb = "0.11.2"
2016-01-03 08:29:37 +01:00
```
Example
-------
2015-11-22 18:55:38 +01:00
2015-11-22 19:00:35 +01:00
```rust
extern crate minifb;
2015-11-22 18:55:38 +01:00
2016-11-20 07:37:49 +01:00
use minifb::{Key, WindowOptions, Window};
2016-01-19 14:42:58 -02:00
2015-12-25 10:37:13 +01:00
const WIDTH: usize = 640;
const HEIGHT: usize = 360;
2015-11-22 18:55:38 +01:00
2015-11-22 19:00:35 +01:00
fn main() {
2016-01-05 21:29:52 +01:00
let mut buffer: Vec< u32 > = vec![0; WIDTH * HEIGHT];
2015-11-22 18:55:38 +01:00
2016-09-18 10:25:08 +02:00
let mut window = Window::new("Test - ESC to exit",
WIDTH,
HEIGHT,
WindowOptions::default()).unwrap_or_else(|e| {
panic!("{}", e);
});
2015-11-22 18:55:38 +01:00
2015-12-25 10:37:13 +01:00
while window.is_open() & & !window.is_key_down(Key::Escape) {
2015-11-22 19:00:35 +01:00
for i in buffer.iter_mut() {
2015-12-25 10:37:13 +01:00
*i = 0; // write something more funny here!
2015-11-22 19:00:35 +01:00
}
2015-11-22 18:55:38 +01:00
2017-08-11 12:41:24 +02:00
// We unwrap here as we want this code to exit if it fails. Real applications may want to handle this in a different way
window.update_with_buffer(&buffer).unwrap();
2015-12-25 10:37:13 +01:00
}
2015-11-22 19:01:34 +01:00
}
2015-11-22 19:00:35 +01:00
```
2015-11-22 18:55:38 +01:00
2015-11-23 19:46:51 +01:00
Status
------
2017-08-11 12:57:18 +02:00
Currently Mac, Redox, Linux and Windows (64-bit and 32-bit) are the current supported platforms. X11 (Linux/FreeBSD/etc) support has been tested on Ubuntu (x64). Bug report(s) for other OSes/CPUs are welcome!
2015-11-23 19:46:51 +01:00
2016-01-03 08:29:37 +01:00
Build instructions
2015-11-22 18:55:38 +01:00
------------------
2015-11-23 19:27:18 +01:00
```
2015-11-22 19:00:35 +01:00
cargo build
2016-03-04 17:36:28 +01:00
cargo run --example noise
2015-11-23 19:27:18 +01:00
```
2015-11-23 19:26:27 +01:00
2018-11-13 21:41:00 +01:00
This will run the [noise example ](https://github.com/emoon/rust_minifb/blob/master/examples/noise.rs )
2016-01-10 18:36:57 +01:00
## License
Licensed under either of
* Apache License, Version 2.0 ([LICENSE-APACHE ](LICENSE-APACHE ) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT ](LICENSE-MIT ) or http://opensource.org/licenses/MIT)
at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.