πŸ“¦ aevyrie / bevy_framepace

Framepacing and framelimiting for Bevy

β˜… 337 stars β‘‚ 36 forks πŸ‘ 337 watching βš–οΈ Apache License 2.0
bevybevy-plugingraphics
πŸ“₯ Clone https://github.com/aevyrie/bevy_framepace.git
HTTPS git clone https://github.com/aevyrie/bevy_framepace.git
SSH git clone git@github.com:aevyrie/bevy_framepace.git
CLI gh repo clone aevyrie/bevy_framepace
recatek recatek Updating to bevy 0.18 (#75) 9be8f16 4 days ago πŸ“ History
πŸ“‚ main View all commits β†’
πŸ“ .github
πŸ“ examples
πŸ“ src
πŸ“„ .gitignore
πŸ“„ Cargo.toml
πŸ“„ CHANGELOG.md
πŸ“„ LICENSE-APACHE
πŸ“„ LICENSE-MIT
πŸ“„ README.md
πŸ“„ README.md

bevy_framepace⏱️

Framepacing and framelimiting for Bevy crates.io docs.rs CI

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 theFramepaceSettings 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 spinsleep 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.17 | 0.20 | | 0.16 | 0.19 | | 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 bevyframepace` 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: http://opensource.org/licenses/MIT) 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.