pub struct MsgWheeltick {
    pub sender_id: Option<u16>,
    pub time: u64,
    pub flags: u8,
    pub source: u8,
    pub ticks: i32,
}
Expand description

Accumulated wheeltick count message

Message containing the accumulated distance travelled by a wheel located at an odometry reference point defined by the user. The offset for the odometry reference point and the definition and origin of the user frame are defined through the device settings interface. The source of this message is identified by the source field, which is an integer ranging from 0 to 255. The timestamp associated with this message should represent the time when the accumulated tick count reached the value given by the contents of this message as accurately as possible. If using “local CPU time” time tags, the receiving end will also expect either MSG_GNSS_TIME_OFFSET or MSG_PPS_TIME to sync incoming wheeltick data to GNSS time. Local CPU time shall roll over to zero after one week.

Fields§

§sender_id: Option<u16>

The message sender_id

§time: u64

Time field representing either microseconds since the last PPS, microseconds in the GPS Week or local CPU time from the producing system in microseconds. See the synch_type field for the exact meaning of this timestamp.

§flags: u8

Field indicating the type of timestamp contained in the time field.

§source: u8

ID of the sensor producing this message

§ticks: i32

Free-running counter of the accumulated distance for this sensor. The counter should be incrementing if travelling into one direction and decrementing when travelling in the opposite direction.

Implementations§

source§

impl MsgWheeltick

source

pub fn vehicle_metadata(&self) -> Result<VehicleMetadata, u8>

Gets the VehicleMetadata stored in the flags bitfield.

Returns Ok if the bitrange contains a known VehicleMetadata variant. Otherwise the value of the bitrange is returned as an Err(u8). This may be because of a malformed message, or because new variants of VehicleMetadata were added.

source

pub fn set_vehicle_metadata(&mut self, vehicle_metadata: VehicleMetadata)

Set the bitrange corresponding to the VehicleMetadata of the flags bitfield.

source

pub fn synchronization_type(&self) -> Result<SynchronizationType, u8>

Gets the SynchronizationType stored in the flags bitfield.

Returns Ok if the bitrange contains a known SynchronizationType variant. Otherwise the value of the bitrange is returned as an Err(u8). This may be because of a malformed message, or because new variants of SynchronizationType were added.

source

pub fn set_synchronization_type( &mut self, synchronization_type: SynchronizationType )

Set the bitrange corresponding to the SynchronizationType of the flags bitfield.

Trait Implementations§

source§

impl Clone for MsgWheeltick

source§

fn clone(&self) -> MsgWheeltick

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 ConcreteMessage for MsgWheeltick

source§

const MESSAGE_TYPE: u16 = 2_308u16

The message type.
source§

const MESSAGE_NAME: &'static str = "MSG_WHEELTICK"

The message name.
source§

impl Debug for MsgWheeltick

source§

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

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

impl<'de> Deserialize<'de> for MsgWheeltick

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl FriendlyName for MsgWheeltick

source§

fn friendly_name() -> &'static str

source§

impl From<MsgWheeltick> for Sbp

source§

fn from(msg: MsgWheeltick) -> Self

Converts to this type from the input type.
source§

impl PartialEq for MsgWheeltick

source§

fn eq(&self, other: &MsgWheeltick) -> 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 SbpMessage for MsgWheeltick

source§

fn message_name(&self) -> &'static str

Get the message name.
source§

fn message_type(&self) -> Option<u16>

Get the message type.
source§

fn sender_id(&self) -> Option<u16>

Get the sender_id if it is set.
source§

fn set_sender_id(&mut self, new_id: u16)

Set the sender id.
source§

fn encoded_len(&self) -> usize

Number of bytes this message will take on the wire.
source§

fn is_valid(&self) -> bool

Tells you if the message is valid or if it is not a valid message and may need to be special cased at certain points.
source§

fn into_valid_msg(self) -> Result<Self, Invalid>

source§

fn gps_time(&self) -> Option<Result<MessageTime, GpsTimeError>>

Get the GPS time associated with the message.
source§

fn friendly_name(&self) -> &'static str

Get friendly name associated with the message.
source§

impl Serialize for MsgWheeltick

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl TryFrom<Sbp> for MsgWheeltick

§

type Error = TryFromSbpError

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

fn try_from(msg: Sbp) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl StructuralPartialEq for MsgWheeltick

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> Event for T
where T: ConcreteMessage,

source§

const MESSAGE_TYPES: &'static [u16] = const MESSAGE_TYPES: &'static [u16] = &[T::MESSAGE_TYPE];

The message types that correspond to this event. An empty slice means all messages.
source§

fn from_sbp(msg: Sbp) -> T

Create an instance of this event from an SBP message. This message will only be called if the message type is in Event::MESSAGE_TYPES.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

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> 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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,