lesavka/client/src/input/mouse.rs

67 lines
1.9 KiB
Rust
Raw Normal View History

2025-06-08 22:24:14 -05:00
// client/src/input/mouse.rs
2025-06-11 00:37:01 -05:00
use evdev::{Device, InputEvent, EventType, RelativeAxisCode};
use tracing::error;
2025-06-08 22:24:14 -05:00
/// Aggregator for a single mouse device
pub struct MouseAggregator {
dev: Device,
tx: Sender<HidReport>,
buttons: u8,
dx: i8,
dy: i8,
wheel: i8,
2025-06-08 22:24:14 -05:00
}
impl MouseAggregator {
pub fn new(dev: Device) -> Self {
Self {
dev,
dx: 0,
dy: 0,
}
}
pub fn process_events(&mut self) {
2025-06-11 00:37:01 -05:00
let events_vec: Vec<InputEvent> = match self.dev.fetch_events() {
Ok(it) => it.collect(),
Err(e) if e.kind() == std::io::ErrorKind::WouldBlock => {
return;
2025-06-08 22:24:14 -05:00
}
Err(e) => {
2025-06-11 00:37:01 -05:00
error!("Mouse device read error: {e}");
return;
2025-06-08 22:24:14 -05:00
}
2025-06-11 00:37:01 -05:00
};
for ev in events_vec {
self.handle_event(ev);
2025-06-08 22:24:14 -05:00
}
}
fn handle_event(&mut self, ev: InputEvent) {
match ev.event_type() {
EventType::RELATIVE => { /* fill dx/dy/wheel as i8 */ }
EventType::KEY => { // buttons are REPORTED as KEYS (BTN_LEFT…)
let pressed = ev.value() != 0;
match ev.code() {
c if c == KeyCode::BTN_LEFT.0 => self.set_btn(0, pressed),
c if c == KeyCode::BTN_RIGHT.0 => self.set_btn(1, pressed),
c if c == KeyCode::BTN_MIDDLE.0=> self.set_btn(2, pressed),
_ => {}
2025-06-08 22:24:14 -05:00
}
}
_ => {}
2025-06-08 22:24:14 -05:00
}
// whenever we changed something, emit:
let rep = [self.buttons, self.dx as u8, self.dy as u8, self.wheel as u8];
let _ = self.tx.try_send(HidReport {
kind: Some(navka_common::navka::hid_report::Kind::MouseReport(rep.to_vec())),
});
// reset deltas so we send *relative* movement
self.dx = 0; self.dy = 0; self.wheel = 0;
2025-06-08 22:24:14 -05:00
}
2025-06-08 22:24:14 -05:00
}