Struct re_types::archetypes::ViewCoordinates

source ·
#[repr(transparent)]
pub struct ViewCoordinates { pub xyz: ViewCoordinates, }
Expand description

Archetype: How we interpret the coordinate system of an entity/space.

For instance: What is “up”? What does the Z axis mean? Is this right-handed or left-handed?

The three coordinates are always ordered as [x, y, z].

For example [Right, Down, Forward] means that the X axis points to the right, the Y axis points down, and the Z axis points forward.

§Example

§View coordinates for adjusting the eye camera

fn main() -> Result<(), Box<dyn std::error::Error>> {
    let rec = rerun::RecordingStreamBuilder::new("rerun_example_view_coordinates").spawn()?;

    rec.log_static("world", &rerun::ViewCoordinates::RIGHT_HAND_Z_UP)?; // Set an up-axis
    rec.log(
        "world/xyz",
        &rerun::Arrows3D::from_vectors(
            [[1.0, 0.0, 0.0], [0.0, 1.0, 0.0], [0.0, 0.0, 1.0]], //
        )
        .with_colors([[255, 0, 0], [0, 255, 0], [0, 0, 255]]),
    )?;

    Ok(())
}

Fields§

§xyz: ViewCoordinates

The directions of the [x, y, z] axes.

Implementations§

source§

impl ViewCoordinates

source

pub const NUM_COMPONENTS: usize = 2usize

The total number of components in the archetype: 1 required, 1 recommended, 0 optional

source§

impl ViewCoordinates

source

pub fn new(xyz: impl Into<ViewCoordinates>) -> Self

Create a new ViewCoordinates.

source§

impl ViewCoordinates

source

pub const ULF: Self = _

X=Up, Y=Left, Z=Forward

source

pub const UFL: Self = _

X=Up, Y=Forward, Z=Left

source

pub const LUF: Self = _

X=Left, Y=Up, Z=Forward

source

pub const LFU: Self = _

X=Left, Y=Forward, Z=Up

source

pub const FUL: Self = _

X=Forward, Y=Up, Z=Left

source

pub const FLU: Self = _

X=Forward, Y=Left, Z=Up

source

pub const ULB: Self = _

X=Up, Y=Left, Z=Back

source

pub const UBL: Self = _

X=Up, Y=Back, Z=Left

source

pub const LUB: Self = _

X=Left, Y=Up, Z=Back

source

pub const LBU: Self = _

X=Left, Y=Back, Z=Up

source

pub const BUL: Self = _

X=Back, Y=Up, Z=Left

source

pub const BLU: Self = _

X=Back, Y=Left, Z=Up

source

pub const URF: Self = _

X=Up, Y=Right, Z=Forward

source

pub const UFR: Self = _

X=Up, Y=Forward, Z=Right

source

pub const RUF: Self = _

X=Right, Y=Up, Z=Forward

source

pub const RFU: Self = _

X=Right, Y=Forward, Z=Up

source

pub const FUR: Self = _

X=Forward, Y=Up, Z=Right

source

pub const FRU: Self = _

X=Forward, Y=Right, Z=Up

source

pub const URB: Self = _

X=Up, Y=Right, Z=Back

source

pub const UBR: Self = _

X=Up, Y=Back, Z=Right

source

pub const RUB: Self = _

X=Right, Y=Up, Z=Back

source

pub const RBU: Self = _

X=Right, Y=Back, Z=Up

source

pub const BUR: Self = _

X=Back, Y=Up, Z=Right

source

pub const BRU: Self = _

X=Back, Y=Right, Z=Up

source

pub const DLF: Self = _

X=Down, Y=Left, Z=Forward

source

pub const DFL: Self = _

X=Down, Y=Forward, Z=Left

source

pub const LDF: Self = _

X=Left, Y=Down, Z=Forward

source

pub const LFD: Self = _

X=Left, Y=Forward, Z=Down

source

pub const FDL: Self = _

X=Forward, Y=Down, Z=Left

source

pub const FLD: Self = _

X=Forward, Y=Left, Z=Down

source

pub const DLB: Self = _

X=Down, Y=Left, Z=Back

source

pub const DBL: Self = _

X=Down, Y=Back, Z=Left

source

pub const LDB: Self = _

X=Left, Y=Down, Z=Back

source

pub const LBD: Self = _

X=Left, Y=Back, Z=Down

source

pub const BDL: Self = _

X=Back, Y=Down, Z=Left

source

pub const BLD: Self = _

X=Back, Y=Left, Z=Down

source

pub const DRF: Self = _

X=Down, Y=Right, Z=Forward

source

pub const DFR: Self = _

X=Down, Y=Forward, Z=Right

source

pub const RDF: Self = _

X=Right, Y=Down, Z=Forward

source

pub const RFD: Self = _

X=Right, Y=Forward, Z=Down

source

pub const FDR: Self = _

X=Forward, Y=Down, Z=Right

source

pub const FRD: Self = _

X=Forward, Y=Right, Z=Down

source

pub const DRB: Self = _

X=Down, Y=Right, Z=Back

source

pub const DBR: Self = _

X=Down, Y=Back, Z=Right

source

pub const RDB: Self = _

X=Right, Y=Down, Z=Back

source

pub const RBD: Self = _

X=Right, Y=Back, Z=Down

source

pub const BDR: Self = _

X=Back, Y=Down, Z=Right

source

pub const BRD: Self = _

X=Back, Y=Right, Z=Down

source

pub const RIGHT_HAND_X_UP: Self = _

X=Up, Y=Right, Z=Forward

source

pub const RIGHT_HAND_X_DOWN: Self = _

X=Down, Y=Right, Z=Back

source

pub const RIGHT_HAND_Y_UP: Self = _

X=Right, Y=Up, Z=Back

source

pub const RIGHT_HAND_Y_DOWN: Self = _

X=Right, Y=Down, Z=Forward

source

pub const RIGHT_HAND_Z_UP: Self = _

X=Right, Y=Forward, Z=Up

source

pub const RIGHT_HAND_Z_DOWN: Self = _

X=Right, Y=Back, Z=Down

source

pub const LEFT_HAND_X_UP: Self = _

X=Up, Y=Right, Z=Back

source

pub const LEFT_HAND_X_DOWN: Self = _

X=Down, Y=Right, Z=Forward

source

pub const LEFT_HAND_Y_UP: Self = _

X=Right, Y=Up, Z=Forward

source

pub const LEFT_HAND_Y_DOWN: Self = _

X=Right, Y=Down, Z=Back

source

pub const LEFT_HAND_Z_UP: Self = _

X=Right, Y=Back, Z=Up

source

pub const LEFT_HAND_Z_DOWN: Self = _

X=Right, Y=Forward, Z=Down

Trait Implementations§

source§

impl Archetype for ViewCoordinates

§

type Indicator = GenericIndicatorComponent<ViewCoordinates>

The associated indicator component, whose presence indicates that the high-level archetype-based APIs were used to log the data. Read more
source§

fn name() -> ArchetypeName

The fully-qualified name of this archetype, e.g. rerun.archetypes.Points2D.
source§

fn indicator() -> MaybeOwnedComponentBatch<'static>

Creates a ComponentBatch out of the associated Self::Indicator component. Read more
source§

fn required_components() -> Cow<'static, [ComponentName]>

Returns the names of all components that must be provided by the user when constructing this archetype.
source§

fn recommended_components() -> Cow<'static, [ComponentName]>

Returns the names of all components that should be provided by the user when constructing this archetype.
source§

fn optional_components() -> Cow<'static, [ComponentName]>

Returns the names of all components that may be provided by the user when constructing this archetype.
source§

fn all_components() -> Cow<'static, [ComponentName]>

Returns the names of all components that must, should and may be provided by the user when constructing this archetype. Read more
source§

fn from_arrow_components( arrow_data: impl IntoIterator<Item = (ComponentName, Box<dyn Array>)> ) -> DeserializationResult<Self>

Given an iterator of Arrow arrays and their respective ComponentNames, deserializes them into this archetype. Read more
source§

fn from_arrow( data: impl IntoIterator<Item = (Field, Box<dyn Array>)> ) -> Result<Self, DeserializationError>
where Self: Sized,

Given an iterator of Arrow arrays and their respective field metadata, deserializes them into this archetype. Read more
source§

impl AsComponents for ViewCoordinates

source§

fn as_component_batches(&self) -> Vec<MaybeOwnedComponentBatch<'_>>

Exposes the object’s contents as a set of ComponentBatchs. Read more
source§

fn to_arrow(&self) -> Result<Vec<(Field, Box<dyn Array>)>, SerializationError>

Serializes all non-null Components of this bundle into Arrow arrays. Read more
source§

impl Clone for ViewCoordinates

source§

fn clone(&self) -> ViewCoordinates

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for ViewCoordinates

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl PartialEq for ViewCoordinates

source§

fn eq(&self, other: &ViewCoordinates) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl SizeBytes for ViewCoordinates

source§

fn heap_size_bytes(&self) -> u64

Returns the total size of self on the heap, in bytes.
source§

fn is_pod() -> bool

Is Self just plain old data? Read more
source§

fn total_size_bytes(&self) -> u64

Returns the total size of self in bytes, accounting for both stack and heap space.
source§

fn stack_size_bytes(&self) -> u64

Returns the total size of self on the stack, in bytes. Read more
source§

impl Zeroable for ViewCoordinates

source§

fn zeroed() -> Self

source§

impl Copy for ViewCoordinates

source§

impl Eq for ViewCoordinates

source§

impl Pod for ViewCoordinates

source§

impl StructuralPartialEq for ViewCoordinates

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CheckedBitPattern for T
where T: AnyBitPattern,

§

type Bits = T

Self must have the same layout as the specified Bits except for the possible invalid bit patterns being checked during is_valid_bit_pattern.
source§

fn is_valid_bit_pattern(_bits: &T) -> bool

If this function returns true, then it must be valid to reinterpret bits as &Self.
source§

impl<T> DynClone for T
where T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> AnyBitPattern for T
where T: Pod,

source§

impl<T> NoUninit for T
where T: Pod,