pub struct DualAxisExclusion {
pub exclusion_x: AxisExclusion,
pub exclusion_y: AxisExclusion,
}
Expand description
Specifies a cross-shaped region for excluding dual-axis inputs, with min-max independent min-max ranges for each axis, resulting in a per-axis “snapping” effect, helping filter out minor fluctuations to enhance control precision for pure axial motion.
In simple terms, this processor is just the dual-axis version of AxisExclusion
.
Helpers like AxisExclusion::extend_dual()
and its peers can be used to create a DualAxisExclusion
.
use bevy::prelude::*;
use leafwing_input_manager::prelude::*;
// Exclude X within [-0.2, 0.3] and Y within [-0.1, 0.4].
let exclusion = DualAxisExclusion::new((-0.2, 0.3), (-0.1, 0.4));
assert_eq!(exclusion.exclusion_x().min_max(), (-0.2, 0.3));
assert_eq!(exclusion.exclusion_y().min_max(), (-0.1, 0.4));
// Another way to create a DualAxisExclusion.
let exclusion_x = AxisExclusion::new(-0.2, 0.3);
let exclusion_y = AxisExclusion::new(-0.1, 0.4);
assert_eq!(exclusion_x.extend_dual_with_y(exclusion_y), exclusion);
for x in -300..300 {
let x = x as f32 * 0.01;
for y in -300..300 {
let y = y as f32 * 0.01;
let value = Vec2::new(x, y);
assert_eq!(exclusion.exclude(value).x, exclusion_x.exclude(x));
assert_eq!(exclusion.exclude(value).y, exclusion_y.exclude(y));
}
}
Fields§
§exclusion_x: AxisExclusion
The AxisExclusion
for the X-axis inputs.
exclusion_y: AxisExclusion
The AxisExclusion
for the Y-axis inputs.
Implementations§
source§impl DualAxisExclusion
impl DualAxisExclusion
sourcepub const ZERO: Self = _
pub const ZERO: Self = _
Zero-size DualAxisExclusion
, leaving values as is.
sourcepub fn new(
(x_negative_max, x_positive_min): (f32, f32),
(y_negative_max, y_positive_min): (f32, f32),
) -> Self
pub fn new( (x_negative_max, x_positive_min): (f32, f32), (y_negative_max, y_positive_min): (f32, f32), ) -> Self
Creates a DualAxisExclusion
that ignores values within the range [negative_max, positive_min]
on each axis.
§Requirements
negative_max
<=0.0
<=positive_min
on each axis.
§Panics
Panics if the requirements aren’t met.
sourcepub fn all(negative_max: f32, positive_min: f32) -> Self
pub fn all(negative_max: f32, positive_min: f32) -> Self
Creates a DualAxisExclusion
that ignores values within the range [negative_max, positive_min]
on both axes.
§Requirements
negative_max
<=0.0
<=positive_min
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_x(negative_max: f32, positive_min: f32) -> Self
pub fn only_x(negative_max: f32, positive_min: f32) -> Self
Creates a DualAxisExclusion
that only ignores X values within the range [negative_max, positive_min]
.
§Requirements
negative_max
<=0.0
<=positive_min
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_y(negative_max: f32, positive_min: f32) -> Self
pub fn only_y(negative_max: f32, positive_min: f32) -> Self
Creates a DualAxisExclusion
that only ignores Y values within the range [negative_max, positive_min]
.
§Requirements
negative_max
<=0.0
<=positive_min
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn symmetric(threshold_x: f32, threshold_y: f32) -> Self
pub fn symmetric(threshold_x: f32, threshold_y: f32) -> Self
Creates a DualAxisExclusion
that ignores values within the range [-threshold, threshold]
on each axis.
§Requirements
threshold
>=0.0
on each axis.
§Panics
Panics if the requirements aren’t met.
sourcepub fn symmetric_all(threshold: f32) -> Self
pub fn symmetric_all(threshold: f32) -> Self
Creates a DualAxisExclusion
that ignores values within the range [-threshold, threshold]
on both axes.
§Requirements
threshold
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn symmetric_only_x(threshold: f32) -> Self
pub fn symmetric_only_x(threshold: f32) -> Self
Creates a DualAxisExclusion
that only ignores X values within the range [-threshold, threshold]
.
§Requirements
threshold
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn symmetric_only_y(threshold: f32) -> Self
pub fn symmetric_only_y(threshold: f32) -> Self
Creates a DualAxisExclusion
that only ignores Y values within the range [-threshold, threshold]
.
§Requirements
threshold
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_positive(x_positive_min: f32, y_positive_min: f32) -> Self
pub fn only_positive(x_positive_min: f32, y_positive_min: f32) -> Self
Creates a DualAxisExclusion
that only passes positive values that greater than positive_min
on each axis.
§Requirements
positive_min
>=0.0
on each axis.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_positive_all(positive_min: f32) -> Self
pub fn only_positive_all(positive_min: f32) -> Self
Creates a DualAxisExclusion
that only passes positive values that greater than positive_min
on both axes.
§Requirements
positive_min
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_positive_x(positive_min: f32) -> Self
pub fn only_positive_x(positive_min: f32) -> Self
Creates a DualAxisExclusion
that only passes positive X values that greater than positive_min
.
§Requirements
positive_min
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_positive_y(positive_min: f32) -> Self
pub fn only_positive_y(positive_min: f32) -> Self
Creates a DualAxisExclusion
that only passes positive Y values that greater than positive_min
.
§Requirements
positive_min
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_negative(x_negative_max: f32, y_negative_max: f32) -> Self
pub fn only_negative(x_negative_max: f32, y_negative_max: f32) -> Self
Creates a DualAxisExclusion
that only passes negative values that less than negative_max
on each axis.
§Requirements
negative_max
<=0.0
on each axis.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_negative_all(negative_max: f32) -> Self
pub fn only_negative_all(negative_max: f32) -> Self
Creates a DualAxisExclusion
that only passes negative values that less than negative_max
on both axes.
§Requirements
negative_max
<=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_negative_x(negative_max: f32) -> Self
pub fn only_negative_x(negative_max: f32) -> Self
Creates a DualAxisExclusion
that only passes negative X values that less than negative_max
.
§Requirements
positive_min
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn only_negative_y(negative_max: f32) -> Self
pub fn only_negative_y(negative_max: f32) -> Self
Creates a DualAxisExclusion
that only passes negative Y values that less than negative_max
.
§Requirements
positive_min
>=0.0
.
§Panics
Panics if the requirements aren’t met.
sourcepub fn exclusions(&self) -> (AxisExclusion, AxisExclusion)
pub fn exclusions(&self) -> (AxisExclusion, AxisExclusion)
Returns the exclusion ranges for inputs along each axis.
sourcepub fn exclusion_x(&self) -> AxisExclusion
pub fn exclusion_x(&self) -> AxisExclusion
Returns the exclusion range for the X-axis inputs.
sourcepub fn exclusion_y(&self) -> AxisExclusion
pub fn exclusion_y(&self) -> AxisExclusion
Returns the exclusion range for the Y-axis inputs.
sourcepub fn contains(&self, input_value: Vec2) -> BVec2
pub fn contains(&self, input_value: Vec2) -> BVec2
Is the input_value
within the exclusion range?
sourcepub fn scaled(self) -> DualAxisDeadZone
pub fn scaled(self) -> DualAxisDeadZone
Creates a DualAxisDeadZone
using self
as the exclusion range.
Trait Implementations§
source§impl Clone for DualAxisExclusion
impl Clone for DualAxisExclusion
source§fn clone(&self) -> DualAxisExclusion
fn clone(&self) -> DualAxisExclusion
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for DualAxisExclusion
impl Debug for DualAxisExclusion
source§impl Default for DualAxisExclusion
impl Default for DualAxisExclusion
source§fn default() -> Self
fn default() -> Self
Creates a DualAxisExclusion
that excludes input values within [-1.0, 1.0]
on both axes.
source§impl<'de> Deserialize<'de> for DualAxisExclusion
impl<'de> Deserialize<'de> for DualAxisExclusion
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
source§impl From<DualAxisExclusion> for DualAxisDeadZone
impl From<DualAxisExclusion> for DualAxisDeadZone
source§fn from(exclusion: DualAxisExclusion) -> Self
fn from(exclusion: DualAxisExclusion) -> Self
source§impl From<DualAxisExclusion> for DualAxisProcessor
impl From<DualAxisExclusion> for DualAxisProcessor
source§fn from(value: DualAxisExclusion) -> Self
fn from(value: DualAxisExclusion) -> Self
source§impl FromReflect for DualAxisExclusion
impl FromReflect for DualAxisExclusion
source§fn from_reflect(reflect: &dyn Reflect) -> Option<Self>
fn from_reflect(reflect: &dyn Reflect) -> Option<Self>
Self
from a reflected value.source§fn take_from_reflect(
reflect: Box<dyn Reflect>,
) -> Result<Self, Box<dyn Reflect>>
fn take_from_reflect( reflect: Box<dyn Reflect>, ) -> Result<Self, Box<dyn Reflect>>
Self
using,
constructing the value using from_reflect
if that fails. Read moresource§impl GetTypeRegistration for DualAxisExclusion
impl GetTypeRegistration for DualAxisExclusion
source§fn get_type_registration() -> TypeRegistration
fn get_type_registration() -> TypeRegistration
TypeRegistration
for this type.source§fn register_type_dependencies(registry: &mut TypeRegistry)
fn register_type_dependencies(registry: &mut TypeRegistry)
source§impl Hash for DualAxisExclusion
impl Hash for DualAxisExclusion
source§impl PartialEq for DualAxisExclusion
impl PartialEq for DualAxisExclusion
source§impl Reflect for DualAxisExclusion
impl Reflect for DualAxisExclusion
source§fn get_represented_type_info(&self) -> Option<&'static TypeInfo>
fn get_represented_type_info(&self) -> Option<&'static TypeInfo>
source§fn as_any_mut(&mut self) -> &mut dyn Any
fn as_any_mut(&mut self) -> &mut dyn Any
&mut dyn Any
.source§fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>
fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>
source§fn as_reflect(&self) -> &dyn Reflect
fn as_reflect(&self) -> &dyn Reflect
source§fn as_reflect_mut(&mut self) -> &mut dyn Reflect
fn as_reflect_mut(&mut self) -> &mut dyn Reflect
source§fn clone_value(&self) -> Box<dyn Reflect>
fn clone_value(&self) -> Box<dyn Reflect>
Reflect
trait object. Read moresource§fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>
fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>
source§fn reflect_kind(&self) -> ReflectKind
fn reflect_kind(&self) -> ReflectKind
source§fn reflect_ref(&self) -> ReflectRef<'_>
fn reflect_ref(&self) -> ReflectRef<'_>
source§fn reflect_mut(&mut self) -> ReflectMut<'_>
fn reflect_mut(&mut self) -> ReflectMut<'_>
source§fn reflect_owned(self: Box<Self>) -> ReflectOwned
fn reflect_owned(self: Box<Self>) -> ReflectOwned
source§fn reflect_partial_eq(&self, value: &dyn Reflect) -> Option<bool>
fn reflect_partial_eq(&self, value: &dyn Reflect) -> Option<bool>
source§fn apply(&mut self, value: &(dyn Reflect + 'static))
fn apply(&mut self, value: &(dyn Reflect + 'static))
source§fn reflect_hash(&self) -> Option<u64>
fn reflect_hash(&self) -> Option<u64>
source§fn debug(&self, f: &mut Formatter<'_>) -> Result<(), Error>
fn debug(&self, f: &mut Formatter<'_>) -> Result<(), Error>
source§fn serializable(&self) -> Option<Serializable<'_>>
fn serializable(&self) -> Option<Serializable<'_>>
source§fn is_dynamic(&self) -> bool
fn is_dynamic(&self) -> bool
source§impl Serialize for DualAxisExclusion
impl Serialize for DualAxisExclusion
source§impl Struct for DualAxisExclusion
impl Struct for DualAxisExclusion
source§fn field(&self, name: &str) -> Option<&dyn Reflect>
fn field(&self, name: &str) -> Option<&dyn Reflect>
name
as a &dyn Reflect
.source§fn field_mut(&mut self, name: &str) -> Option<&mut dyn Reflect>
fn field_mut(&mut self, name: &str) -> Option<&mut dyn Reflect>
name
as a
&mut dyn Reflect
.source§fn field_at(&self, index: usize) -> Option<&dyn Reflect>
fn field_at(&self, index: usize) -> Option<&dyn Reflect>
index
as a
&dyn Reflect
.source§fn field_at_mut(&mut self, index: usize) -> Option<&mut dyn Reflect>
fn field_at_mut(&mut self, index: usize) -> Option<&mut dyn Reflect>
index
as a &mut dyn Reflect
.source§fn name_at(&self, index: usize) -> Option<&str>
fn name_at(&self, index: usize) -> Option<&str>
index
.source§fn iter_fields(&self) -> FieldIter<'_>
fn iter_fields(&self) -> FieldIter<'_>
source§fn clone_dynamic(&self) -> DynamicStruct
fn clone_dynamic(&self) -> DynamicStruct
DynamicStruct
.source§impl TypePath for DualAxisExclusion
impl TypePath for DualAxisExclusion
source§fn type_path() -> &'static str
fn type_path() -> &'static str
source§fn short_type_path() -> &'static str
fn short_type_path() -> &'static str
source§fn type_ident() -> Option<&'static str>
fn type_ident() -> Option<&'static str>
source§fn crate_name() -> Option<&'static str>
fn crate_name() -> Option<&'static str>
source§impl Typed for DualAxisExclusion
impl Typed for DualAxisExclusion
impl Copy for DualAxisExclusion
impl Eq for DualAxisExclusion
impl StructuralPartialEq for DualAxisExclusion
Auto Trait Implementations§
impl Freeze for DualAxisExclusion
impl RefUnwindSafe for DualAxisExclusion
impl Send for DualAxisExclusion
impl Sync for DualAxisExclusion
impl Unpin for DualAxisExclusion
impl UnwindSafe for DualAxisExclusion
Blanket Implementations§
source§impl<T, U> AsBindGroupShaderType<U> for T
impl<T, U> AsBindGroupShaderType<U> for T
source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
T
ShaderType
for self
. When used in AsBindGroup
derives, it is safe to assume that all images in self
exist.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§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)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>
. Box<dyn Any>
can
then be further downcast
into Box<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>
. Rc<Any>
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> DowncastSync for T
impl<T> DowncastSync for T
source§impl<T> DynamicTypePath for Twhere
T: TypePath,
impl<T> DynamicTypePath for Twhere
T: TypePath,
source§fn reflect_type_path(&self) -> &str
fn reflect_type_path(&self) -> &str
TypePath::type_path
.source§fn reflect_short_type_path(&self) -> &str
fn reflect_short_type_path(&self) -> &str
source§fn reflect_type_ident(&self) -> Option<&str>
fn reflect_type_ident(&self) -> Option<&str>
TypePath::type_ident
.source§fn reflect_crate_name(&self) -> Option<&str>
fn reflect_crate_name(&self) -> Option<&str>
TypePath::crate_name
.source§fn reflect_module_path(&self) -> Option<&str>
fn reflect_module_path(&self) -> Option<&str>
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.source§impl<T> FromWorld for Twhere
T: Default,
impl<T> FromWorld for Twhere
T: Default,
source§fn from_world(_world: &mut World) -> T
fn from_world(_world: &mut World) -> T
Self
using data from the given World
.source§impl<S> GetField for Swhere
S: Struct,
impl<S> GetField for Swhere
S: Struct,
source§impl<T> GetPath for T
impl<T> GetPath for T
source§fn reflect_path<'p>(
&self,
path: impl ReflectPath<'p>,
) -> Result<&(dyn Reflect + 'static), ReflectPathError<'p>>
fn reflect_path<'p>( &self, path: impl ReflectPath<'p>, ) -> Result<&(dyn Reflect + 'static), ReflectPathError<'p>>
path
. Read moresource§fn reflect_path_mut<'p>(
&mut self,
path: impl ReflectPath<'p>,
) -> Result<&mut (dyn Reflect + 'static), ReflectPathError<'p>>
fn reflect_path_mut<'p>( &mut self, path: impl ReflectPath<'p>, ) -> Result<&mut (dyn Reflect + 'static), ReflectPathError<'p>>
path
. Read moresource§fn path<'p, T>(
&self,
path: impl ReflectPath<'p>,
) -> Result<&T, ReflectPathError<'p>>where
T: Reflect,
fn path<'p, T>(
&self,
path: impl ReflectPath<'p>,
) -> Result<&T, ReflectPathError<'p>>where
T: Reflect,
path
. Read moresource§fn path_mut<'p, T>(
&mut self,
path: impl ReflectPath<'p>,
) -> Result<&mut T, ReflectPathError<'p>>where
T: Reflect,
fn path_mut<'p, T>(
&mut self,
path: impl ReflectPath<'p>,
) -> Result<&mut T, ReflectPathError<'p>>where
T: Reflect,
path
. Read moresource§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 more