Cross-platform, safe, pure-rust graphics api.
Go to file
bors[bot] a1908c1873 Merge #142
142: Correct Link r=kvark a=ShalokShalom



Co-authored-by: ShalokShalom <shalokshalom@protonmail.ch>
2019-04-28 02:14:02 +00:00
etc Screenshots in the README 2019-02-28 17:20:09 -05:00
examples Support dynamic offsets 2019-04-26 22:20:54 +02:00
gfx-examples Support dynamic offsets 2019-04-26 22:20:54 +02:00
wgpu-bindings Support dynamic offsets 2019-04-26 22:20:54 +02:00
wgpu-native Support dynamic offsets 2019-04-26 22:20:54 +02:00
wgpu-remote run cargo fmt 2019-03-05 20:41:24 -08:00
wgpu-rs Support dynamic offsets 2019-04-26 22:20:54 +02:00
.clang-format Reduce left indentation for nested structs 2019-03-08 07:15:36 -07:00
.gitignore Convert shadow sample to map_async 2019-03-05 19:04:21 -08:00
.rustfmt.toml Format code using 'cargo fmt' 2019-04-26 22:01:47 +05:30
.travis.yml Update OSX CI version to 9.4 2019-04-25 08:29:53 -04:00
bors.toml CI scripts 2018-09-14 11:39:24 -04:00
Cargo.lock Track epochs of the frame semaphores to wait for 2019-04-03 17:48:26 -04:00
Cargo.toml First bits of wgpu-remote 2019-02-26 10:10:07 -05:00
CHANGELOG.md Update changelog and versions 2019-03-31 20:04:39 -04:00
LICENSE Initial commit 2018-09-13 15:18:51 -04:00
Makefile Unpin nightly date 2019-02-28 21:18:16 -07:00
README.md Correct Link 2019-04-27 21:05:39 +02:00
rustfmt.toml Epoch tracking of indices 2019-02-26 10:12:11 -05: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

Supported platforms:

  • Vulkan on Windows and Linux
  • D3D12 and D3D11 on Windows
  • Metal on macOS and iOS

Examples

Cube Shadow

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 gfx-rs guide.