pub struct IrMapping<'a, B, const N: usize> { /* private fields */ }Available on
target_os=none only.Expand description
A generic device abstraction that maps IR remote button presses to user-defined button types.
§Examples
use device_envoy::ir::{IrMapping, IrMappingStatic};
#[derive(Debug, Clone, Copy)]
enum RemoteButton { Power, Play, Stop }
async fn example(
p: embassy_rp::Peripherals,
spawner: embassy_executor::Spawner,
) -> device_envoy::Result<()> {
let button_map = [
(0x0000, 0x45, RemoteButton::Power),
(0x0000, 0x0C, RemoteButton::Play),
(0x0000, 0x08, RemoteButton::Stop),
];
static IR_MAPPING_STATIC: IrMappingStatic = IrMapping::<RemoteButton, 3>::new_static();
let ir_mapping: IrMapping<RemoteButton, 3> = IrMapping::new(&IR_MAPPING_STATIC, p.PIN_15, p.PIO0, &button_map, spawner)?;
loop {
let button = ir_mapping.wait_for_press().await;
// Use button...
}
}Implementations§
Source§impl<'a, B, const N: usize> IrMapping<'a, B, N>where
B: Copy,
impl<'a, B, const N: usize> IrMapping<'a, B, N>where
B: Copy,
Sourcepub const fn new_static() -> IrMappingStatic
pub const fn new_static() -> IrMappingStatic
Create static channel resources for IR mapping events.
See IrMapping for usage examples.
Sourcepub fn new<P, PIO>(
ir_mapping_static: &'static IrMappingStatic,
pin: Peri<'static, P>,
pio: Peri<'static, PIO>,
button_map: &[(u16, u8, B)],
spawner: Spawner,
) -> Result<Self>
pub fn new<P, PIO>( ir_mapping_static: &'static IrMappingStatic, pin: Peri<'static, P>, pio: Peri<'static, PIO>, button_map: &[(u16, u8, B)], spawner: Spawner, ) -> Result<Self>
Create a new IR remote button mapper.
§Parameters
ir_mapping_static: Static reference to the channel resourcespin: GPIO pin connected to the IR receiverpio: PIO peripheral to use (PIO0, PIO1, or PIO2)button_map: Array mapping (address, command) pairs to button typesspawner: Embassy spawner for background task
See IrMapping for usage examples.
§Errors
Returns an error if the background task cannot be spawned.
Sourcepub async fn wait_for_press(&self) -> B
pub async fn wait_for_press(&self) -> B
Wait for the next recognized button press.
Ignores button presses that are not in the button map.
See IrMapping for usage examples.
Auto Trait Implementations§
impl<'a, B, const N: usize> Freeze for IrMapping<'a, B, N>where
B: Freeze,
impl<'a, B, const N: usize> !RefUnwindSafe for IrMapping<'a, B, N>
impl<'a, B, const N: usize> Send for IrMapping<'a, B, N>where
B: Send,
impl<'a, B, const N: usize> Sync for IrMapping<'a, B, N>where
B: Sync,
impl<'a, B, const N: usize> Unpin for IrMapping<'a, B, N>where
B: Unpin,
impl<'a, B, const N: usize> !UnwindSafe for IrMapping<'a, B, N>
Blanket Implementations§
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
Mutably borrows from an owned value. Read more
Source§impl<T> CheckedAs for T
impl<T> CheckedAs for T
Source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
Source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Casts the value.
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>
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 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>
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 moreSource§impl<Src, Dst> LosslessTryInto<Dst> for Srcwhere
Dst: LosslessTryFrom<Src>,
impl<Src, Dst> LosslessTryInto<Dst> for Srcwhere
Dst: LosslessTryFrom<Src>,
Source§fn lossless_try_into(self) -> Option<Dst>
fn lossless_try_into(self) -> Option<Dst>
Performs the conversion.
Source§impl<Src, Dst> LossyInto<Dst> for Srcwhere
Dst: LossyFrom<Src>,
impl<Src, Dst> LossyInto<Dst> for Srcwhere
Dst: LossyFrom<Src>,
Source§fn lossy_into(self) -> Dst
fn lossy_into(self) -> Dst
Performs the conversion.
Source§impl<T> OverflowingAs for T
impl<T> OverflowingAs for T
Source§fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
fn overflowing_as<Dst>(self) -> (Dst, bool)where
T: OverflowingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
impl<Src, Dst> OverflowingCastFrom<Src> for Dstwhere
Src: OverflowingCast<Dst>,
Source§fn overflowing_cast_from(src: Src) -> (Dst, bool)
fn overflowing_cast_from(src: Src) -> (Dst, bool)
Casts the value.
Source§impl<T> SaturatingAs for T
impl<T> SaturatingAs for T
Source§fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
fn saturating_as<Dst>(self) -> Dstwhere
T: SaturatingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
impl<Src, Dst> SaturatingCastFrom<Src> for Dstwhere
Src: SaturatingCast<Dst>,
Source§fn saturating_cast_from(src: Src) -> Dst
fn saturating_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> StrictAs for T
impl<T> StrictAs for T
Source§fn strict_as<Dst>(self) -> Dstwhere
T: StrictCast<Dst>,
fn strict_as<Dst>(self) -> Dstwhere
T: StrictCast<Dst>,
Casts the value.
Source§impl<Src, Dst> StrictCastFrom<Src> for Dstwhere
Src: StrictCast<Dst>,
impl<Src, Dst> StrictCastFrom<Src> for Dstwhere
Src: StrictCast<Dst>,
Source§fn strict_cast_from(src: Src) -> Dst
fn strict_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> UnwrappedAs for T
impl<T> UnwrappedAs for T
Source§fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
fn unwrapped_as<Dst>(self) -> Dstwhere
T: UnwrappedCast<Dst>,
Casts the value.
Source§impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
impl<Src, Dst> UnwrappedCastFrom<Src> for Dstwhere
Src: UnwrappedCast<Dst>,
Source§fn unwrapped_cast_from(src: Src) -> Dst
fn unwrapped_cast_from(src: Src) -> Dst
Casts the value.
Source§impl<T> WrappingAs for T
impl<T> WrappingAs for T
Source§fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
fn wrapping_as<Dst>(self) -> Dstwhere
T: WrappingCast<Dst>,
Casts the value.
Source§impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
impl<Src, Dst> WrappingCastFrom<Src> for Dstwhere
Src: WrappingCast<Dst>,
Source§fn wrapping_cast_from(src: Src) -> Dst
fn wrapping_cast_from(src: Src) -> Dst
Casts the value.