Sprite Pivot
Show how to pivot a sprite.
The threeforms.png
sprite image for this example is:
With the following threeforms.ron
RON configuration file where pivot is the default pivot:
(pivot_x: Center, pivot_y: Center)
Source
use chuot::{Config, Context, Game, config::RotationAlgorithm};
/// Define a game state for our example.
#[derive(Default)]
struct GameState {
/// Current rotation.
rotation: f32,
}
impl Game for GameState {
/// Update the game.
fn update(&mut self, ctx: Context) {
// Increment the rotation with with the timestep so it rotates smoothly
self.rotation += ctx.delta_time();
}
/// Render the game.
fn render(&mut self, ctx: Context) {
// Draw a sprite at the left top
ctx.sprite("threeforms")
// Override the default pivot
.pivot_top_left()
// Use the UI coordinate system so it's placed at the left top of the screen
.use_ui_camera()
.draw();
// Draw a rotated sprite at the center with a slight pivot offset
ctx.sprite("threeforms")
.rotate(self.rotation)
// Override the default pivot to rotate around the center of the sprite
.pivot_center()
.draw();
}
}
/// Open an empty window.
fn main() {
// Game configuration
let config = Config {
buffer_width: 240.0,
buffer_height: 192.0,
// Apply a minimum of 3 times scaling for the buffer
// Will result in a minimum, and on web exact, window size of 720x576
scaling: 3.0,
// We use a custom rotation algorithm shader so the sprite looks more smooth while rotating with less noisy artifacts, this one is a bit slow
rotation_algorithm: RotationAlgorithm::CleanEdge,
..Default::default()
};
// Spawn the window and run the 'game'
GameState::default().run(chuot::load_assets!(), config);
}
Compatibility
Chuột Version | Example Works |
---|---|
0.3.0 | ✅ |
0.3.1 | ✅ |
Unreleased | ✅ |