#[non_exhaustive]pub struct TensorGlyphItem {
pub positions: Vec<[f32; 3]>,
pub eigenvalues: Vec<[f32; 3]>,
pub eigenvectors: Vec<[[f32; 3]; 3]>,
pub scale: f32,
pub colour_attribute: Option<Vec<f32>>,
pub scalar_range: Option<(f32, f32)>,
pub colourmap_id: Option<ColourmapId>,
pub model: [[f32; 4]; 4],
pub id: u64,
pub appearance: AppearanceSettings,
pub selected: bool,
}Expand description
A set of instanced tensor glyphs for stress/strain visualization.
Each instance is an ellipsoid at positions[i], scaled anisotropically by the
absolute eigenvalues along the eigenvector axes. Colour comes from colour_attribute
if provided, otherwise from the sign of the first (dominant) eigenvalue.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.positions: Vec<[f32; 3]>World-space positions, one per instance.
eigenvalues: Vec<[f32; 3]>Per-instance eigenvalues [lambda0, lambda1, lambda2].
The ellipsoid is scaled by |lambda_i| * scale along each eigenvector axis.
eigenvectors: Vec<[[f32; 3]; 3]>Per-instance eigenvectors as column vectors [[e0x,e0y,e0z], [e1x,...], [e2x,...]].
Must form an orthonormal basis. Length must match positions.
scale: f32Global scale factor applied to all instances. Default: 1.0.
colour_attribute: Option<Vec<f32>>Optional per-instance scalar values for LUT colouring.
When None, colours by sign of eigenvalues[i][0]: positive -> upper LUT, negative -> lower LUT.
scalar_range: Option<(f32, f32)>Scalar range for LUT mapping. None = auto from data.
colourmap_id: Option<ColourmapId>Colourmap for scalar colouring. None = viridis. For sign colouring, a diverging map works best.
model: [[f32; 4]; 4]World-space model matrix. Default: identity.
id: u64Unique ID for picking. 0 = not pickable.
appearance: AppearanceSettingsPer-item appearance overrides (hidden, unlit, opacity, wireframe).
selected: boolWhether this tensor glyph set is selected at object level. Default: false.
Trait Implementations§
Source§impl Clone for TensorGlyphItem
impl Clone for TensorGlyphItem
Source§fn clone(&self) -> TensorGlyphItem
fn clone(&self) -> TensorGlyphItem
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl Freeze for TensorGlyphItem
impl RefUnwindSafe for TensorGlyphItem
impl Send for TensorGlyphItem
impl Sync for TensorGlyphItem
impl Unpin for TensorGlyphItem
impl UnsafeUnpin for TensorGlyphItem
impl UnwindSafe for TensorGlyphItem
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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.