mirror of
https://github.com/bevyengine/bevy
synced 2025-01-12 05:09:00 +00:00
21b78b5990
# Objective Several of our APIs (namely gizmos and bounding) use isometries on current Bevy main. This is nicer than separate properties in a lot of cases, but users have still expressed usability concerns. One problem is that in a lot of cases, you only care about e.g. translation, so you end up with this: ```rust gizmos.cross_2d( Isometry2d::from_translation(Vec2::new(-160.0, 120.0)), 12.0, FUCHSIA, ); ``` The isometry adds quite a lot of length and verbosity, and isn't really that relevant since only the translation is important here. It would be nice if you could use the translation directly, and only supply an isometry if both translation and rotation are needed. This would make the following possible: ```rust gizmos.cross_2d(Vec2::new(-160.0, 120.0), 12.0, FUCHSIA); ``` removing a lot of verbosity. ## Solution Implement `From<Vec2>` and `From<Rot2>` for `Isometry2d`, and `From<Vec3>`, `From<Vec3A>`, and `From<Quat>` for `Isometry3d`. These are lossless conversions that fit the semantics of `From`. This makes the proposed API possible! The methods must now simply take an `impl Into<IsometryNd>`, and this works: ```rust gizmos.cross_2d(Vec2::new(-160.0, 120.0), 12.0, FUCHSIA); ```
83 lines
2.6 KiB
Rust
83 lines
2.6 KiB
Rust
//! Additional [`Gizmos`] Functions -- Crosses
|
|
//!
|
|
//! Includes the implementation of [`Gizmos::cross`] and [`Gizmos::cross_2d`],
|
|
//! and assorted support items.
|
|
|
|
use crate::prelude::{GizmoConfigGroup, Gizmos};
|
|
use bevy_color::Color;
|
|
use bevy_math::{Isometry2d, Isometry3d, Vec2, Vec3};
|
|
|
|
impl<Config> Gizmos<'_, '_, Config>
|
|
where
|
|
Config: GizmoConfigGroup,
|
|
{
|
|
/// Draw a cross in 3D with the given `isometry` applied.
|
|
///
|
|
/// If `isometry == Isometry3d::IDENTITY` then
|
|
///
|
|
/// - the center is at `Vec3::ZERO`
|
|
/// - the `half_size`s are aligned with the `Vec3::X`, `Vec3::Y` and `Vec3::Z` axes.
|
|
///
|
|
/// This should be called for each frame the cross needs to be rendered.
|
|
///
|
|
/// # Example
|
|
/// ```
|
|
/// # use bevy_gizmos::prelude::*;
|
|
/// # use bevy_math::prelude::*;
|
|
/// # use bevy_color::palettes::basic::WHITE;
|
|
/// fn system(mut gizmos: Gizmos) {
|
|
/// gizmos.cross(Isometry3d::IDENTITY, 0.5, WHITE);
|
|
/// }
|
|
/// # bevy_ecs::system::assert_is_system(system);
|
|
/// ```
|
|
pub fn cross(
|
|
&mut self,
|
|
isometry: impl Into<Isometry3d>,
|
|
half_size: f32,
|
|
color: impl Into<Color>,
|
|
) {
|
|
let isometry = isometry.into();
|
|
let color: Color = color.into();
|
|
[Vec3::X, Vec3::Y, Vec3::Z]
|
|
.map(|axis| axis * half_size)
|
|
.into_iter()
|
|
.for_each(|axis| {
|
|
self.line(isometry * axis, isometry * (-axis), color);
|
|
});
|
|
}
|
|
|
|
/// Draw a cross in 2D with the given `isometry` applied.
|
|
///
|
|
/// If `isometry == Isometry2d::IDENTITY` then
|
|
///
|
|
/// - the center is at `Vec3::ZERO`
|
|
/// - the `half_size`s are aligned with the `Vec3::X` and `Vec3::Y` axes.
|
|
///
|
|
/// This should be called for each frame the cross needs to be rendered.
|
|
///
|
|
/// # Example
|
|
/// ```
|
|
/// # use bevy_gizmos::prelude::*;
|
|
/// # use bevy_math::prelude::*;
|
|
/// # use bevy_color::palettes::basic::WHITE;
|
|
/// fn system(mut gizmos: Gizmos) {
|
|
/// gizmos.cross_2d(Isometry2d::IDENTITY, 0.5, WHITE);
|
|
/// }
|
|
/// # bevy_ecs::system::assert_is_system(system);
|
|
/// ```
|
|
pub fn cross_2d(
|
|
&mut self,
|
|
isometry: impl Into<Isometry2d>,
|
|
half_size: f32,
|
|
color: impl Into<Color>,
|
|
) {
|
|
let isometry = isometry.into();
|
|
let color: Color = color.into();
|
|
[Vec2::X, Vec2::Y]
|
|
.map(|axis| axis * half_size)
|
|
.into_iter()
|
|
.for_each(|axis| {
|
|
self.line_2d(isometry * axis, isometry * (-axis), color);
|
|
});
|
|
}
|
|
}
|