mirror of
https://github.com/bevyengine/bevy
synced 2024-11-29 08:00:20 +00:00
7d40e3ec87
# Objective Continue migration of bevy APIs to required components, following guidance of https://hackmd.io/@bevy/required_components/ ## Solution - Make `Sprite` require `Transform` and `Visibility` and `SyncToRenderWorld` - move image and texture atlas handles into `Sprite` - deprecate `SpriteBundle` - remove engine uses of `SpriteBundle` ## Testing ran cargo tests on bevy_sprite and tested several sprite examples. --- ## Migration Guide Replace all uses of `SpriteBundle` with `Sprite`. There are several new convenience constructors: `Sprite::from_image`, `Sprite::from_atlas_image`, `Sprite::from_color`. WARNING: use of `Handle<Image>` and `TextureAtlas` as components on sprite entities will NO LONGER WORK. Use the fields on `Sprite` instead. I would have removed the `Component` impls from `TextureAtlas` and `Handle<Image>` except it is still used within ui. We should fix this moving forward with the migration.
47 lines
1.2 KiB
Rust
47 lines
1.2 KiB
Rust
//! Displays a single [`Sprite`] tiled in a grid, with a scaling animation
|
|
|
|
use bevy::prelude::*;
|
|
|
|
fn main() {
|
|
App::new()
|
|
.add_plugins(DefaultPlugins)
|
|
.add_systems(Startup, setup)
|
|
.add_systems(Update, animate)
|
|
.run();
|
|
}
|
|
|
|
#[derive(Resource)]
|
|
struct AnimationState {
|
|
min: f32,
|
|
max: f32,
|
|
current: f32,
|
|
speed: f32,
|
|
}
|
|
|
|
fn setup(mut commands: Commands, asset_server: Res<AssetServer>) {
|
|
commands.spawn(Camera2d);
|
|
commands.insert_resource(AnimationState {
|
|
min: 128.0,
|
|
max: 512.0,
|
|
current: 128.0,
|
|
speed: 50.0,
|
|
});
|
|
commands.spawn((
|
|
Sprite::from_image(asset_server.load("branding/icon.png")),
|
|
ImageScaleMode::Tiled {
|
|
tile_x: true,
|
|
tile_y: true,
|
|
stretch_value: 0.5, // The image will tile every 128px
|
|
},
|
|
));
|
|
}
|
|
|
|
fn animate(mut sprites: Query<&mut Sprite>, mut state: ResMut<AnimationState>, time: Res<Time>) {
|
|
if state.current >= state.max || state.current <= state.min {
|
|
state.speed = -state.speed;
|
|
};
|
|
state.current += state.speed * time.delta_seconds();
|
|
for mut sprite in &mut sprites {
|
|
sprite.custom_size = Some(Vec2::splat(state.current));
|
|
}
|
|
}
|