Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mate-h/bevy-webgpu
https://github.com/mate-h/bevy-webgpu
bevy game-engine hmr rust typescript vite webgpu
Last synced: 23 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/mate-h/bevy-webgpu
- Owner: mate-h
- Created: 2024-08-25T02:46:56.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-31T00:57:48.000Z (4 months ago)
- Last Synced: 2024-10-16T23:18:45.722Z (3 months ago)
- Topics: bevy, game-engine, hmr, rust, typescript, vite, webgpu
- Language: Rust
- Homepage: https://bevy-webgpu.vercel.app
- Size: 74.2 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Bevy WebGPU
Bevy WebGPU is a template repository for getting started with [Bevy game engine](https://bevyengine.org/) for web game development using WebGPU. Efficient hot reloading of Rust and WGSL files with Vite dev server.
Demo: https://bevy-webgpu.vercel.app/
Quickstart:
```bash
pnpx degit mate-h/bevy-webgpu my-project
cd my-project
pnpm i
pnpm run build:wasm
pnpm run dev
```Features:
- WebGPU support with Bevy engine
- TypeScript support with WASM bindings to Rust
- Hot reloading of WGSL files
- Recompiling Rust code with page refresh
- Instant reloading of shaders without refreshing the page
- Support for multiple examples
- Easy to understand and modify templateNo dependencies besides:
- Bevy
- Vite
- Rust
- Node
- WASM
- WebGPU## Recommended setup
Use rust-analyzer for Rust development, as well as wgsl-analyzer for WGSL linting. Fork of the wgsl-analyzer is available [here](https://github.com/mate-h/wgsl-analyzer). This fork includes support for Bevy shaders that use `#import` directives as opposed to `#include`.
It is also recommended to use [Mise en place](https://mise.jdx.dev/getting-started.html) for installing the Rust toolchain and other dependencies.
```bash
mise use -g rust
rustup target add wasm32-unknown-unknown
cargo install wasm-bindgen-cli
```VSCode plugins:
- [Rust Analyzer](https://marketplace.visualstudio.com/items?itemName=rust-lang.rust-analyzer)
- [WGSL Analyzer](https://marketplace.visualstudio.com/items?itemName=wgsl-analyzer.wgsl-analyzer)In order to properly lint Bevy shaders, you need to add the following VSCode configuration.
This is described in [this issue](https://github.com/bevyengine/bevy/issues/5561).VSCode configuration:
```jsonc
{
"rust-analyzer.server.path": "~/.local/share/mise/installs/rust/latest/bin/rust-analyzer",
"rust-analyzer.server.extraEnv": {
"RUSTUP_TOOLCHAIN": "stable"
},
"wgsl-analyzer.server.path": "/your/path/to/wgsl-analyzer/target/release/wgsl_analyzer",
"wgsl-analyzer.customImports": {
"bevy_pbr::mesh_view_bindings": "file:///path/to/bevy/crates/bevy_pbr/src/mesh_view_bindings.wgsl",
// Add more imports here. To obtain the full list, see the linked GitHub issue.
},
"wgsl-analyzer.preprocessor.shaderDefs": [
"VERTEX_UVS",
"VERTEX_TANGENTS",
"VERTEX_COLORS",
"SKINNED",
"STANDARDMATERIAL_NORMAL_MAP",
],
}
```