Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aevyrie/bevy_framepace
Framepacing and framelimiting for Bevy
https://github.com/aevyrie/bevy_framepace
bevy bevy-plugin graphics
Last synced: about 12 hours ago
JSON representation
Framepacing and framelimiting for Bevy
- Host: GitHub
- URL: https://github.com/aevyrie/bevy_framepace
- Owner: aevyrie
- License: apache-2.0
- Created: 2022-01-07T02:14:46.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2025-01-05T06:03:58.000Z (19 days ago)
- Last Synced: 2025-01-16T19:15:57.730Z (8 days ago)
- Topics: bevy, bevy-plugin, graphics
- Language: Rust
- Homepage: https://crates.io/crates/bevy_framepace
- Size: 417 KB
- Stars: 257
- Watchers: 2
- Forks: 26
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# bevy_framepace⏱️
**Framepacing and framelimiting for Bevy**
[![crates.io](https://img.shields.io/crates/v/bevy_framepace)](https://crates.io/crates/bevy_framepace)
[![docs.rs](https://docs.rs/bevy_framepace/badge.svg)](https://docs.rs/bevy_framepace)
[![CI](https://github.com/aevyrie/bevy_framepace/workflows/CI/badge.svg?branch=main)](https://github.com/aevyrie/bevy_framepace/actions?query=workflow%3A%22CI%22+branch%3Amain)
[![Bevy](https://img.shields.io/badge/Bevy%20tracking-main-lightblue)](https://github.com/bevyengine/bevy/blob/main/docs/plugins_guidelines.md#main-branch-tracking)### Usage
It's as simple as adding the plugin to your app:
```rs
app.add_plugins(bevy_framepace::FramepacePlugin);
```By default, the plugin will automatically measure your framerate and use this for framepacing.
You can adjust the framerate limit at runtime by modifying the`FramepaceSettings` resource. For
example, to set the framerate limit to 30fps:```rs
settings.limiter = Limiter::from_framerate(30.0),
```See `demo.rs` in the examples folder, or run with:
```console
cargo run --release --example demo
```## How it works
The plugin works by recording how long it takes to render each frame, and sleeping the main thread
until the desired frametime is reached. This ensures the next frame isn't started until the very
last moment, delaying the event loop from restarting. By delaying the event loop, and thus input
collection, this reduces motion-to-photon latency by moving reading input closer to rendering the
frame.The `spin_sleep` dependency is needed for precise sleep times. The sleep function in the standard
library is not accurate enough for this application, especially on Windows.## Bevy Version Support
I intend to track the `main` branch of Bevy. PRs supporting this are welcome!
| bevy | bevy_framepace |
| ---- | ------------------- |
| 0.15 | 0.18 |
| 0.14 | 0.17 |
| 0.13 | 0.15, 0.16 |
| 0.12 | 0.14 |
| 0.11 | 0.13 |
| 0.10 | 0.12 |
| 0.9 | 0.7, 0.8, 0.9, 0.10, 0.11 |
| 0.8 | 0.5, 0.6 |
| 0.7 | 0.4 |
| 0.6 | 0.3 |## License
`bevy_framepace` is free, open source and permissively licensed! Except where noted (below and/or in
individual files), all code in this repository is dual-licensed under either:* MIT License ([LICENSE-MIT](LICENSE-MIT) or
[http://opensource.org/licenses/MIT](http://opensource.org/licenses/MIT))
* Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or
[http://www.apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0))at your option. This means you can select the license you prefer! This dual-licensing approach is
the de-facto standard in the Rust ecosystem and there are very good reasons to include both.### Your contributions
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the
work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any
additional terms or conditions.