leafwing_input_manager::input_processing::single_axis

Trait CustomAxisProcessor

source
pub trait CustomAxisProcessor:
    Send
    + Sync
    + Debug
    + DynClone
    + DynEq
    + DynHash
    + Reflect
    + Serialize {
    // Required method
    fn process(&self, input_value: f32) -> f32;
}
Expand description

A trait for creating custom processor that handles single-axis input values, accepting a f32 input and producing a f32 output.

§Examples

use std::hash::{Hash, Hasher};
use bevy::prelude::*;
use bevy::math::FloatOrd;
use serde::{Deserialize, Serialize};
use leafwing_input_manager::prelude::*;

/// Doubles the input, takes the absolute value,
/// and discards results that meet the specified condition.
// If your processor includes fields not implemented Eq and Hash,
// implementation is necessary as shown below.
// Otherwise, you can derive Eq and Hash directly.
#[derive(Debug, Clone, Copy, PartialEq, Reflect, Serialize, Deserialize)]
pub struct DoubleAbsoluteValueThenIgnored(pub f32);

// Add this attribute for ensuring proper serialization and deserialization.
#[serde_typetag]
impl CustomAxisProcessor for DoubleAbsoluteValueThenIgnored {
    fn process(&self, input_value: f32) -> f32 {
        // Implement the logic just like you would in a normal function.

        // You can use other processors within this function.
        let value = AxisProcessor::Sensitivity(2.0).process(input_value);

        let value = value.abs();
        if value == self.0 {
            0.0
        } else {
            value
        }
    }
}

// Unfortunately, manual implementation is required due to the float field.
impl Eq for DoubleAbsoluteValueThenIgnored {}
impl Hash for DoubleAbsoluteValueThenIgnored {
    fn hash<H: Hasher>(&self, state: &mut H) {
        // Encapsulate the float field for hashing.
        FloatOrd(self.0).hash(state);
    }
}

// Remember to register your processor - it will ensure everything works smoothly!
let mut app = App::new();
app.register_axis_processor::<DoubleAbsoluteValueThenIgnored>();

// Now you can use it!
let processor = DoubleAbsoluteValueThenIgnored(4.0);

// Rejected!
assert_eq!(processor.process(2.0), 0.0);
assert_eq!(processor.process(-2.0), 0.0);

// Others are just doubled absolute value.
assert_eq!(processor.process(6.0), 12.0);
assert_eq!(processor.process(4.0), 8.0);
assert_eq!(processor.process(0.0), 0.0);
assert_eq!(processor.process(-4.0), 8.0);
assert_eq!(processor.process(-6.0), 12.0);

// The ways to create an AxisProcessor.
let axis_processor = AxisProcessor::Custom(Box::new(processor));
assert_eq!(axis_processor, AxisProcessor::from(processor));

Required Methods§

source

fn process(&self, input_value: f32) -> f32

Computes the result by processing the input_value.

Trait Implementations§

source§

impl<'de> Deserialize<'de> for Box<dyn CustomAxisProcessor>

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 FromReflect for Box<dyn CustomAxisProcessor>

source§

fn from_reflect(reflect: &dyn Reflect) -> Option<Self>

Constructs a concrete instance of Self from a reflected value.
source§

fn take_from_reflect( reflect: Box<dyn Reflect>, ) -> Result<Self, Box<dyn Reflect>>

Attempts to downcast the given value to Self using, constructing the value using from_reflect if that fails. Read more
source§

impl GetTypeRegistration for Box<dyn CustomAxisProcessor>

source§

fn get_type_registration() -> TypeRegistration

Returns the default TypeRegistration for this type.
source§

fn register_type_dependencies(registry: &mut TypeRegistry)

Registers other types needed by this type. Read more
source§

impl<'hash> Hash for dyn CustomAxisProcessor + 'hash

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
source§

impl<'hash> Hash for dyn CustomAxisProcessor + Send + 'hash

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
source§

impl<'hash> Hash for dyn CustomAxisProcessor + Send + Sync + 'hash

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
source§

impl<'hash> Hash for dyn CustomAxisProcessor + Sync + 'hash

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
source§

impl<'eq> PartialEq<&Box<dyn CustomAxisProcessor + 'eq>> for Box<dyn CustomAxisProcessor + 'eq>

source§

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

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

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

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

impl<'eq> PartialEq<&Box<dyn CustomAxisProcessor + Send + 'eq>> for Box<dyn CustomAxisProcessor + Send + 'eq>

source§

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

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

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

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

impl<'eq> PartialEq<&Box<dyn CustomAxisProcessor + Sync + Send + 'eq>> for Box<dyn CustomAxisProcessor + Send + Sync + 'eq>

source§

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

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

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

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

impl<'eq> PartialEq<&Box<dyn CustomAxisProcessor + Sync + 'eq>> for Box<dyn CustomAxisProcessor + Sync + 'eq>

source§

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

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

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

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

impl<'eq> PartialEq for dyn CustomAxisProcessor + 'eq

source§

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

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

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

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

impl<'eq> PartialEq for dyn CustomAxisProcessor + Send + 'eq

source§

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

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

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

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

impl<'eq> PartialEq for dyn CustomAxisProcessor + Send + Sync + 'eq

source§

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

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

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

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

impl<'eq> PartialEq for dyn CustomAxisProcessor + Sync + 'eq

source§

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

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

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

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

impl Reflect for Box<dyn CustomAxisProcessor>

source§

fn get_represented_type_info(&self) -> Option<&'static TypeInfo>

Returns the TypeInfo of the type represented by this value. Read more
source§

fn into_any(self: Box<Self>) -> Box<dyn Any>

Returns the value as a Box<dyn Any>.
source§

fn as_any(&self) -> &dyn Any

Returns the value as a &dyn Any.
source§

fn as_any_mut(&mut self) -> &mut dyn Any

Returns the value as a &mut dyn Any.
source§

fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>

Casts this type to a boxed reflected value.
source§

fn as_reflect(&self) -> &dyn Reflect

Casts this type to a reflected value.
source§

fn as_reflect_mut(&mut self) -> &mut dyn Reflect

Casts this type to a mutable reflected value.
source§

fn apply(&mut self, value: &dyn Reflect)

Applies a reflected value to this value. Read more
source§

fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>

Performs a type-checked assignment of a reflected value to this value. Read more
source§

fn reflect_kind(&self) -> ReflectKind

Returns a zero-sized enumeration of “kinds” of type. Read more
source§

fn reflect_ref(&self) -> ReflectRef<'_>

Returns an immutable enumeration of “kinds” of type. Read more
source§

fn reflect_mut(&mut self) -> ReflectMut<'_>

Returns a mutable enumeration of “kinds” of type. Read more
source§

fn reflect_owned(self: Box<Self>) -> ReflectOwned

Returns an owned enumeration of “kinds” of type. Read more
source§

fn clone_value(&self) -> Box<dyn Reflect>

Clones the value as a Reflect trait object. Read more
source§

fn reflect_hash(&self) -> Option<u64>

Returns a hash of the value (which includes the type). Read more
source§

fn reflect_partial_eq(&self, value: &dyn Reflect) -> Option<bool>

Returns a “partial equality” comparison result. Read more
source§

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

Debug formatter for the value. Read more
source§

fn try_apply(&mut self, value: &dyn Reflect) -> Result<(), ApplyError>

Tries to apply a reflected value to this value. Read more
source§

fn serializable(&self) -> Option<Serializable<'_>>

Returns a serializable version of the value. Read more
source§

fn is_dynamic(&self) -> bool

Indicates whether or not this type is a dynamic type. Read more
source§

impl<'a> Serialize for dyn CustomAxisProcessor + 'a

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 TypePath for Box<dyn CustomAxisProcessor>

source§

fn type_path() -> &'static str

Returns the fully qualified path of the underlying type. Read more
source§

fn short_type_path() -> &'static str

Returns a short, pretty-print enabled path to the type. Read more
source§

fn type_ident() -> Option<&'static str>

Returns the name of the type, or None if it is anonymous. Read more
source§

fn crate_name() -> Option<&'static str>

Returns the name of the crate the type is in, or None if it is anonymous. Read more
source§

fn module_path() -> Option<&'static str>

Returns the path to the module the type is in, or None if it is anonymous. Read more
source§

impl Typed for Box<dyn CustomAxisProcessor>

source§

fn type_info() -> &'static TypeInfo

Returns the compile-time info for the underlying type.
source§

impl<'eq> Eq for dyn CustomAxisProcessor + 'eq

source§

impl<'eq> Eq for dyn CustomAxisProcessor + Send + 'eq

source§

impl<'eq> Eq for dyn CustomAxisProcessor + Send + Sync + 'eq

source§

impl<'eq> Eq for dyn CustomAxisProcessor + Sync + 'eq

Implementors§