Struct wayland_server::protocol::wl_keyboard::WlKeyboard
source · pub struct WlKeyboard { /* private fields */ }
Expand description
keyboard input device
The wl_keyboard interface represents one or more keyboards associated with a seat.
See also the Request enum for this interface.
Implementations§
source§impl WlKeyboard
impl WlKeyboard
sourcepub fn keymap(&self, format: KeymapFormat, fd: RawFd, size: u32)
pub fn keymap(&self, format: KeymapFormat, fd: RawFd, size: u32)
keyboard mapping
This event provides a file descriptor to the client which can be memory-mapped in read-only mode to provide a keyboard mapping description.
From version 7 onwards, the fd must be mapped with MAP_PRIVATE by the recipient, as MAP_SHARED may fail.
sourcepub fn enter(&self, serial: u32, surface: &WlSurface, keys: Vec<u8>)
pub fn enter(&self, serial: u32, surface: &WlSurface, keys: Vec<u8>)
enter event
Notification that this seat’s keyboard focus is on a certain surface.
The compositor must send the wl_keyboard.modifiers event after this event.
sourcepub fn leave(&self, serial: u32, surface: &WlSurface)
pub fn leave(&self, serial: u32, surface: &WlSurface)
leave event
Notification that this seat’s keyboard focus is no longer on a certain surface.
The leave notification is sent before the enter notification for the new focus.
After this event client must assume that all keys, including modifiers, are lifted and also it must stop key repeating if there’s some going on.
sourcepub fn key(&self, serial: u32, time: u32, key: u32, state: KeyState)
pub fn key(&self, serial: u32, time: u32, key: u32, state: KeyState)
key event
A key was pressed or released. The time argument is a timestamp with millisecond granularity, with an undefined base.
The key is a platform-specific key code that can be interpreted by feeding it to the keyboard mapping (see the keymap event).
If this event produces a change in modifiers, then the resulting wl_keyboard.modifiers event must be sent after this event.
sourcepub fn modifiers(
&self,
serial: u32,
mods_depressed: u32,
mods_latched: u32,
mods_locked: u32,
group: u32
)
pub fn modifiers( &self, serial: u32, mods_depressed: u32, mods_latched: u32, mods_locked: u32, group: u32 )
modifier and group state
Notifies clients that the modifier and/or group state has changed, and it should update its local state.
sourcepub fn repeat_info(&self, rate: i32, delay: i32)
pub fn repeat_info(&self, rate: i32, delay: i32)
repeat rate and delay
Informs the client about the keyboard’s repeat rate and delay.
This event is sent as soon as the wl_keyboard object has been created, and is guaranteed to be received by the client before any key press event.
Negative values for either rate or delay are illegal. A rate of zero will disable any repeating (regardless of the value of delay).
This event can be sent later on as well with a new value if necessary, so clients should continue listening for the event past the creation of wl_keyboard.
Trait Implementations§
source§impl Clone for WlKeyboard
impl Clone for WlKeyboard
source§fn clone(&self) -> WlKeyboard
fn clone(&self) -> WlKeyboard
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for WlKeyboard
impl Debug for WlKeyboard
source§impl PartialEq<Weak<WlKeyboard>> for WlKeyboard
impl PartialEq<Weak<WlKeyboard>> for WlKeyboard
source§impl PartialEq<WlKeyboard> for WlKeyboard
impl PartialEq<WlKeyboard> for WlKeyboard
source§fn eq(&self, other: &WlKeyboard) -> bool
fn eq(&self, other: &WlKeyboard) -> bool
self
and other
values to be equal, and is used
by ==
.source§impl Resource for WlKeyboard
impl Resource for WlKeyboard
source§fn object_data(&self) -> Option<&Arc<dyn Any + Send + Sync>>
fn object_data(&self) -> Option<&Arc<dyn Any + Send + Sync>>
source§fn handle(&self) -> &WeakHandle
fn handle(&self) -> &WeakHandle
source§fn from_id(conn: &DisplayHandle, id: ObjectId) -> Result<Self, InvalidId>
fn from_id(conn: &DisplayHandle, id: ObjectId) -> Result<Self, InvalidId>
source§fn parse_request(
conn: &DisplayHandle,
msg: Message<ObjectId, OwnedFd>
) -> Result<(Self, Self::Request), DispatchError>
fn parse_request( conn: &DisplayHandle, msg: Message<ObjectId, OwnedFd> ) -> Result<(Self, Self::Request), DispatchError>
source§fn write_event(
&self,
conn: &DisplayHandle,
msg: Self::Event
) -> Result<Message<ObjectId, RawFd>, InvalidId>
fn write_event( &self, conn: &DisplayHandle, msg: Self::Event ) -> Result<Message<ObjectId, RawFd>, InvalidId>
source§fn is_alive(&self) -> bool
fn is_alive(&self) -> bool
impl Eq for WlKeyboard
Auto Trait Implementations§
impl !RefUnwindSafe for WlKeyboard
impl Send for WlKeyboard
impl Sync for WlKeyboard
impl Unpin for WlKeyboard
impl !UnwindSafe for WlKeyboard
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
source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere T: Any,
source§fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
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 + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
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.