Cross-platform, safe, pure-rust graphics api.
Go to file
bors[bot] 3274fc92f5 Merge #54
54: Document how to run examples r=grovesNL a=rukai

I had assumed the triangle example wasn't functional yet, because I didn't realize I had to specify a feature. I only realized it was supposed to work when I saw a screenshot of the cube example.

I'm not sure what the future is of the triangle example? Will it remain outside of the gfx-examples folder?

Co-authored-by: Rukai <rubickent@gmail.com>
2019-02-12 14:30:30 +00:00
examples Merge #54 2019-02-12 14:30:30 +00:00
gfx-examples Document how to run examples 2019-02-12 22:01:49 +11:00
wgpu-bindings Rust and C API for transfers 2019-02-07 08:17:13 -05:00
wgpu-native Initial compute pipeline support 2019-02-11 19:02:18 -08:00
wgpu-rs Initial compute pipeline support 2019-02-11 19:02:18 -08:00
.gitignore Create C example 2018-09-23 13:25:05 -06:00
.travis.yml Remove examples Makefile from CI 2019-01-24 12:08:32 -05:00
bors.toml CI scripts 2018-09-14 11:39:24 -04:00
Cargo.lock Depenency gfx update to 0.1.1 2019-02-05 09:45:52 -05:00
Cargo.toml Basic gfx-examples framework 2019-02-02 21:02:33 -05:00
LICENSE Initial commit 2018-09-13 15:18:51 -04:00
Makefile Linux support for GLFW example 2019-01-24 12:33:34 -05:00
README.md Document how to run examples 2019-02-12 22:01:49 +11:00
rustfmt.toml CI scripts 2018-09-14 11:39:24 -04:00

WebGPU

Build Status Crates.io Gitter

This is an experimental WebGPU implementation as a native static library. It's written in Rust and is based on gfx-hal and satellite libraries. The corresponding WebIDL specification can be found at gpuweb project.

The implementation consists of the following parts:

  • wgpu-native - the native implementation of WebGPU as a C API library
  • wgpu-bindings - automatic generator of actual C headers
  • wgpu-remote - remoting layer to work with WebGPU across the process boundary
  • wgpu-rs - idiomatic Rust wrapper of the native library

Example

To run an example, simply cd to the examples or gfx-examples directory, then use cargo run with --features {backend} to specify the backend (where {backend} is either vulkan, dx12, dx11 or metal). For example:

# Clone the wgpu repository
git clone https://github.com/gfx-rs/wgpu
# Change directory to `examples`
cd wgpu/examples
# Vulkan (Linux/Windows)
cargo run --bin hello_triangle --features vulkan
# Metal (macOS/iOS)
cargo run --bin hello_triangle --features metal
# DirectX12 (Windows)
cargo run --bin hello_triangle --features dx12

cd ../gfx-examples
# Vulkan (Linux/Windows)
cargo run --bin cube --features vulkan
# Metal (macOS/iOS)
cargo run --bin cube --features metal
# DirectX12 (Windows)
cargo run --bin cube --features dx12

These examples assume that necessary dependencies for the graphics backend are already installed. For more information about installation and usage, refer to the Getting Started guide.