mirror of
https://github.com/bevyengine/bevy
synced 2024-11-25 22:20:20 +00:00
de888a373d
# Objective Another step in the migration to required components: lights! Note that this does not include `EnvironmentMapLight` or reflection probes yet, because their API hasn't been fully chosen yet. ## Solution As per the [selected proposals](https://hackmd.io/@bevy/required_components/%2FLLnzwz9XTxiD7i2jiUXkJg): - Deprecate `PointLightBundle` in favor of the `PointLight` component - Deprecate `SpotLightBundle` in favor of the `PointLight` component - Deprecate `DirectionalLightBundle` in favor of the `DirectionalLight` component ## Testing I ran some examples with lights. --- ## Migration Guide `PointLightBundle`, `SpotLightBundle`, and `DirectionalLightBundle` have been deprecated. Use the `PointLight`, `SpotLight`, and `DirectionalLight` components instead. Adding them will now insert the other components required by them automatically.
89 lines
2.8 KiB
Rust
89 lines
2.8 KiB
Rust
//! A simple scene to demonstrate picking events
|
|
|
|
use bevy::{color::palettes::css::*, prelude::*};
|
|
|
|
fn main() {
|
|
let mut app = App::new();
|
|
app.add_plugins(DefaultPlugins);
|
|
|
|
app.add_systems(Startup, setup);
|
|
|
|
app.run();
|
|
}
|
|
|
|
/// set up a simple 3D scene
|
|
fn setup(
|
|
mut commands: Commands,
|
|
mut meshes: ResMut<Assets<Mesh>>,
|
|
mut materials: ResMut<Assets<StandardMaterial>>,
|
|
) {
|
|
commands
|
|
.spawn((
|
|
TextBundle {
|
|
text: Text::from_section("Click Me to get a box", TextStyle::default()),
|
|
style: Style {
|
|
position_type: PositionType::Absolute,
|
|
top: Val::Percent(12.0),
|
|
left: Val::Percent(12.0),
|
|
..default()
|
|
},
|
|
..Default::default()
|
|
},
|
|
Pickable::default(),
|
|
))
|
|
.observe(
|
|
|_click: Trigger<Pointer<Click>>,
|
|
mut commands: Commands,
|
|
mut meshes: ResMut<Assets<Mesh>>,
|
|
mut materials: ResMut<Assets<StandardMaterial>>,
|
|
mut num: Local<usize>| {
|
|
commands.spawn(PbrBundle {
|
|
mesh: meshes.add(Cuboid::new(1.0, 1.0, 1.0)),
|
|
material: materials.add(Color::srgb_u8(124, 144, 255)),
|
|
transform: Transform::from_xyz(0.0, 0.5 + 1.1 * *num as f32, 0.0),
|
|
..default()
|
|
});
|
|
*num += 1;
|
|
},
|
|
)
|
|
.observe(|evt: Trigger<Pointer<Out>>, mut texts: Query<&mut Text>| {
|
|
let mut text = texts.get_mut(evt.entity()).unwrap();
|
|
let first = text.sections.first_mut().unwrap();
|
|
first.style.color = WHITE.into();
|
|
})
|
|
.observe(|evt: Trigger<Pointer<Over>>, mut texts: Query<&mut Text>| {
|
|
let mut text = texts.get_mut(evt.entity()).unwrap();
|
|
let first = text.sections.first_mut().unwrap();
|
|
first.style.color = BLUE.into();
|
|
});
|
|
// circular base
|
|
commands
|
|
.spawn((
|
|
PbrBundle {
|
|
mesh: meshes.add(Circle::new(4.0)),
|
|
material: materials.add(Color::WHITE),
|
|
transform: Transform::from_rotation(Quat::from_rotation_x(
|
|
-std::f32::consts::FRAC_PI_2,
|
|
)),
|
|
..default()
|
|
},
|
|
Pickable::default(),
|
|
))
|
|
.observe(|click: Trigger<Pointer<Click>>| {
|
|
let click = click.event();
|
|
println!("{click:?}");
|
|
});
|
|
// light
|
|
commands.spawn((
|
|
PointLight {
|
|
shadows_enabled: true,
|
|
..default()
|
|
},
|
|
Transform::from_xyz(4.0, 8.0, 4.0),
|
|
));
|
|
// camera
|
|
commands.spawn(Camera3dBundle {
|
|
transform: Transform::from_xyz(-2.5, 4.5, 9.0).looking_at(Vec3::ZERO, Vec3::Y),
|
|
..default()
|
|
});
|
|
}
|