# Objective Make the examples look more uniform and more polished. following the issue #17167 ## Solution - [x] Added a minimal UI explaining how to interact with the examples only when needed. - [x] Used the same notation for interactions ex : "Up Arrow: Move Forward \nLeft / Right Arrow: Turn" - [x] Set the color to [GRAY](https://github.com/bevyengine/bevy/pull/17237#discussion_r1907560092) when it's not visible enough - [x] Changed some colors to be easy on the eyes - [x] removed the //camera comment - [x] Unified the use of capital letters in the examples. - [x] Simplified the mesh2d_arc offset calculations. ... --------- Co-authored-by: Alice Cecile <alice.i.cecile@gmail.com> Co-authored-by: Rob Parrett <robparrett@gmail.com>
		
			
				
	
	
		
			68 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
//! Renders an animated sprite by loading all animation frames from a single image (a sprite sheet)
 | 
						|
//! into a texture atlas, and changing the displayed image periodically.
 | 
						|
 | 
						|
use bevy::prelude::*;
 | 
						|
 | 
						|
fn main() {
 | 
						|
    App::new()
 | 
						|
        .add_plugins(DefaultPlugins.set(ImagePlugin::default_nearest())) // prevents blurry sprites
 | 
						|
        .add_systems(Startup, setup)
 | 
						|
        .add_systems(Update, animate_sprite)
 | 
						|
        .run();
 | 
						|
}
 | 
						|
 | 
						|
#[derive(Component)]
 | 
						|
struct AnimationIndices {
 | 
						|
    first: usize,
 | 
						|
    last: usize,
 | 
						|
}
 | 
						|
 | 
						|
#[derive(Component, Deref, DerefMut)]
 | 
						|
struct AnimationTimer(Timer);
 | 
						|
 | 
						|
fn animate_sprite(
 | 
						|
    time: Res<Time>,
 | 
						|
    mut query: Query<(&AnimationIndices, &mut AnimationTimer, &mut Sprite)>,
 | 
						|
) {
 | 
						|
    for (indices, mut timer, mut sprite) in &mut query {
 | 
						|
        timer.tick(time.delta());
 | 
						|
 | 
						|
        if timer.just_finished() {
 | 
						|
            if let Some(atlas) = &mut sprite.texture_atlas {
 | 
						|
                atlas.index = if atlas.index == indices.last {
 | 
						|
                    indices.first
 | 
						|
                } else {
 | 
						|
                    atlas.index + 1
 | 
						|
                };
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
fn setup(
 | 
						|
    mut commands: Commands,
 | 
						|
    asset_server: Res<AssetServer>,
 | 
						|
    mut texture_atlas_layouts: ResMut<Assets<TextureAtlasLayout>>,
 | 
						|
) {
 | 
						|
    let texture = asset_server.load("textures/rpg/chars/gabe/gabe-idle-run.png");
 | 
						|
    let layout = TextureAtlasLayout::from_grid(UVec2::splat(24), 7, 1, None, None);
 | 
						|
    let texture_atlas_layout = texture_atlas_layouts.add(layout);
 | 
						|
    // Use only the subset of sprites in the sheet that make up the run animation
 | 
						|
    let animation_indices = AnimationIndices { first: 1, last: 6 };
 | 
						|
 | 
						|
    commands.spawn(Camera2d);
 | 
						|
 | 
						|
    commands.spawn((
 | 
						|
        Sprite::from_atlas_image(
 | 
						|
            texture,
 | 
						|
            TextureAtlas {
 | 
						|
                layout: texture_atlas_layout,
 | 
						|
                index: animation_indices.first,
 | 
						|
            },
 | 
						|
        ),
 | 
						|
        Transform::from_scale(Vec3::splat(6.0)),
 | 
						|
        animation_indices,
 | 
						|
        AnimationTimer(Timer::from_seconds(0.1, TimerMode::Repeating)),
 | 
						|
    ));
 | 
						|
}
 |