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 | ✅ |