rust_minifb/README.md

64 lines
1.8 KiB
Markdown
Raw Normal View History

[![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)
2015-11-22 18:55:38 +01:00
2015-11-23 19:46:51 +01:00
rust_minifb (Mini FrameBuffer) is a small cross platform library written in [Rust](https://www.rust-lang.org) and that makes it easy to render (32-bit) pixels in a window. An example is the best way to show how it works:
[Documentation](http://prodbg.com/minifb/minifb/index.html)
2016-01-03 08:29:37 +01:00
Usage
-----
```toml
# Cargo.toml
[dependencies]
minifb = "0.2.4"
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
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() {
let mut buffer: Vec<u32> = vec![0; WIDTH * HEIGHT];
2015-11-22 18:55:38 +01:00
2016-01-03 08:29:37 +01:00
let mut window = match minifb::Window::new("Test - ESC to exit", WIDTH, HEIGHT, Scale::X1) {
Ok(win) => win,
Err(err) => {
println!("Unable to create window {}", err);
return;
}
};
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
2015-12-25 10:37:13 +01:00
window.update(&buffer);
}
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
------
2016-01-05 21:22:20 +01:00
Currently Mac, 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
2015-11-23 19:39:43 +01:00
cargo run --example noise
2015-11-23 19:27:18 +01:00
```
2015-11-23 19:26:27 +01:00
2016-01-03 08:31:51 +01:00
This will run the [noise example](https://github.com/emoon/rust_minifb/blob/master/examples/noise.rs) which should look something like this (Mac screenshot)
2015-11-23 19:39:43 +01:00
2015-11-23 19:26:27 +01:00
![mac_screenshot](https://dl.dropboxusercontent.com/u/5205843/rust_minifb/noise_screen.png)