good-web-game is a wasm32-unknown-unknown implementation of a ggez subset on top of miniquad. Originally built to run Zemeroth on the web.
It has been recently updated to support much of the ggez 0.6.1 API. If you're already working with ggez you might use this library to port your game to the web (or perhaps even mobile). Since it also runs well on desktop it also offers an alternative implementation of ggez, which might always come in handy.
If you are just looking for a well supported minimal high-level engine on top of miniquad you might want to take a look at macroquad.
"good-web-game" implements most of the ggez 0.6.1 API.
shader
examplequad-storage
)gilrs
depends on wasm-bindgen)You may run into somewhat blurry graphics. This is caused by high-dpi rendering:
When run on a system with a scaling factor unequal to 1 the graphics may appear blurry, due to the drawbuffer being scaled up, to achieve a window of the size requested by your OS.
This size is usually "the size you specified in Conf
" * "your OS scaling factor".
To avoid this set Conf::high_dpi
to true
. This leads to the drawbuffer being the size of your actual physical window. It also means though that you can't be sure how big your drawable space will actually be, as this will then depend on where the program is being run.
We aim towards changing this, so that windows are always created with the physical size specified in Conf
, but that's not directly supported by miniquad currently.
Running Zemeroth: https://not-fl3.github.io/miniquad-samples/zemeroth.html
You can also check out astroblasto running on the web (source).
To build and run an example as a native binary:
rust
cargo run --example 05_astroblasto
If you want to build for WASM take a look at the miniquad instructions for WASM.
Here is how good-web-game
fits into your rust-based game: