leafwing_input_manager::input_processing::dual_axis

Trait CustomDualAxisProcessor

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

A trait for creating custom processor that handles dual-axis input values, accepting a Vec2 input and producing a Vec2 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 its absolute value,
/// and discards results that meet the specified condition on the X-axis.
// 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 DoubleAbsoluteValueThenRejectX(pub f32);

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

        // You can use other processors within this function.
        let value = DualAxisSensitivity::all(2.0).scale(input_value);

        let value = value.abs();
        let new_x = if value.x == self.0 {
            0.0
        } else {
            value.x
        };
        Vec2::new(new_x, value.y)
    }
}

// Unfortunately, manual implementation is required due to the float field.
impl Eq for DoubleAbsoluteValueThenRejectX {}
impl Hash for DoubleAbsoluteValueThenRejectX {
    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_dual_axis_processor::<DoubleAbsoluteValueThenRejectX>();

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

// Rejected X!
assert_eq!(processor.process(Vec2::splat(2.0)), Vec2::new(0.0, 4.0));
assert_eq!(processor.process(Vec2::splat(-2.0)), Vec2::new(0.0, 4.0));

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

// The ways to create a DualAxisProcessor.
let dual_axis_processor = DualAxisProcessor::Custom(Box::new(processor));
assert_eq!(dual_axis_processor, DualAxisProcessor::from(processor));

Required Methods§

source

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

Computes the result by processing the input_value.

Trait Implementations§

source§

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

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 CustomDualAxisProcessor>

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 CustomDualAxisProcessor>

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 CustomDualAxisProcessor + '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 CustomDualAxisProcessor + 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 CustomDualAxisProcessor + 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 CustomDualAxisProcessor + 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 CustomDualAxisProcessor + 'eq>> for Box<dyn CustomDualAxisProcessor + '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 CustomDualAxisProcessor + Send + 'eq>> for Box<dyn CustomDualAxisProcessor + 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 CustomDualAxisProcessor + Send + Sync + 'eq>> for Box<dyn CustomDualAxisProcessor + 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 CustomDualAxisProcessor + Sync + 'eq>> for Box<dyn CustomDualAxisProcessor + 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 CustomDualAxisProcessor + '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 CustomDualAxisProcessor + 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 CustomDualAxisProcessor + 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 CustomDualAxisProcessor + 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 CustomDualAxisProcessor>

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 CustomDualAxisProcessor + '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 CustomDualAxisProcessor>

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 CustomDualAxisProcessor>

source§

fn type_info() -> &'static TypeInfo

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

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

source§

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

source§

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

source§

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

Implementors§