pub struct BoxWidget {
pub center: Vec3,
pub half_extents: Vec3,
pub rotation: Quat,
pub colour: [f32; 4],
pub handle_colour: [f32; 4],
/* private fields */
}Expand description
An interactive oriented box widget with translation, resize, and rotation handles.
The box orientation is controlled by rotation (default Quat::IDENTITY for axis-aligned).
Three rotation arc handles (one per world axis) are rendered as circle overlays.
Use wireframe_item() for the box outline, rotation_arcs_item() for the arc circles,
and handle_glyphs() for all 10 draggable sphere handles.
§Usage
let mut bw = BoxWidget::new(glam::Vec3::ZERO, glam::Vec3::splat(2.0));
// Each frame:
bw.update(&ctx);
fd.scene.polylines.push(bw.wireframe_item(BOX_ID));
fd.scene.polylines.push(bw.rotation_arcs_item(ARC_ID));
fd.scene.glyphs.push(bw.handle_glyphs(HANDLE_ID, &ctx));Fields§
§center: Vec3World-space center of the box.
half_extents: Vec3Half-extents along the box’s local X, Y, Z axes.
rotation: QuatOrientation of the box (rotates the local axes).
colour: [f32; 4]RGBA colour for the wireframe outline.
handle_colour: [f32; 4]RGBA colour for the drag handles. When set (non-zero alpha), overrides the default LUT colouring.
Implementations§
Source§impl BoxWidget
impl BoxWidget
Sourcepub fn new(center: Vec3, half_extents: Vec3) -> Self
pub fn new(center: Vec3, half_extents: Vec3) -> Self
Create a new axis-aligned box widget (rotation defaults to identity).
Sourcepub fn obb(&self) -> (Vec3, Vec3, Quat)
pub fn obb(&self) -> (Vec3, Vec3, Quat)
Returns (center, half_extents, rotation) for this oriented box.
Sourcepub fn aabb(&self) -> Aabb
pub fn aabb(&self) -> Aabb
World-space AABB that conservatively bounds the oriented box.
When rotation is identity this equals the exact box. Otherwise it is a
tight enclosing axis-aligned box computed from all 8 oriented corners.
Sourcepub fn contains_point(&self, point: Vec3) -> bool
pub fn contains_point(&self, point: Vec3) -> bool
Returns true if point lies inside the oriented box.
Sourcepub fn update(&mut self, ctx: &WidgetContext) -> WidgetResult
pub fn update(&mut self, ctx: &WidgetContext) -> WidgetResult
Process input for this frame. Returns Updated if state changed.
Sourcepub fn wireframe_item(&self, id: u64) -> PolylineItem
pub fn wireframe_item(&self, id: u64) -> PolylineItem
Build a PolylineItem for the oriented box wireframe (12 edges).
id is the pick ID (0 = not pickable).
Sourcepub fn rotation_arcs_item(&self, id: u64) -> PolylineItem
pub fn rotation_arcs_item(&self, id: u64) -> PolylineItem
Build a PolylineItem containing three rotation arcs (one per world axis).
Each arc is a full circle at radius arc_radius() around the box center.
Arc colours: X = red, Y = green, Z = blue (semi-transparent).
Sourcepub fn handle_glyphs(&self, id_base: u64, ctx: &WidgetContext) -> GlyphItem
pub fn handle_glyphs(&self, id_base: u64, ctx: &WidgetContext) -> GlyphItem
Build a GlyphItem with 10 sphere handles: center, 6 face handles, and 3 rotation grips.
Pick IDs: id_base = center, id_base + 1..6 = faces (+X,-X,+Y,-Y,+Z,-Z),
id_base + 7..9 = rotation arc grips (X, Y, Z).
Auto Trait Implementations§
impl Freeze for BoxWidget
impl RefUnwindSafe for BoxWidget
impl Send for BoxWidget
impl Sync for BoxWidget
impl Unpin for BoxWidget
impl UnsafeUnpin for BoxWidget
impl UnwindSafe for BoxWidget
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.