Basic input and output managers
This commit is contained in:
parent
80204041fe
commit
05ef34fbe6
6 changed files with 175 additions and 10 deletions
|
@ -1,17 +1,48 @@
|
|||
use crate::input::Keyboard;
|
||||
use crate::{
|
||||
input::{Keyboard, Pointer},
|
||||
CompositorState,
|
||||
};
|
||||
|
||||
use log::debug;
|
||||
|
||||
use wlroots::{
|
||||
compositor,
|
||||
input::{self, keyboard},
|
||||
input::{self, keyboard, pointer},
|
||||
with_handles,
|
||||
};
|
||||
|
||||
pub fn manager() -> input::manager::Builder {
|
||||
input::manager::Builder::default().keyboard_added(keyboard_added)
|
||||
input::manager::Builder::default()
|
||||
.keyboard_added(keyboard_added)
|
||||
.pointer_added(pointer_added)
|
||||
}
|
||||
|
||||
fn keyboard_added(
|
||||
_compositor_handle: compositor::Handle,
|
||||
_keyboard_handle: keyboard::Handle,
|
||||
compositor_handle: compositor::Handle,
|
||||
keyboard_handle: keyboard::Handle,
|
||||
) -> Option<Box<keyboard::Handler>> {
|
||||
debug!("Keyboard added");
|
||||
|
||||
with_handles!([(compositor: {compositor_handle})] => {
|
||||
let compositor_state: &mut CompositorState = compositor.data.downcast_mut().unwrap();
|
||||
compositor_state.keyboards.push(keyboard_handle);
|
||||
})
|
||||
.unwrap();
|
||||
Some(Box::new(Keyboard))
|
||||
}
|
||||
|
||||
fn pointer_added(
|
||||
compositor_handle: compositor::Handle,
|
||||
pointer_handle: pointer::Handle,
|
||||
) -> Option<Box<pointer::Handler>> {
|
||||
debug!("Pointer added");
|
||||
|
||||
with_handles!([(compositor: {compositor_handle}), (pointer: {pointer_handle})] => {
|
||||
let compositor_state: &mut CompositorState = compositor.downcast();
|
||||
compositor_state.cursor_handle
|
||||
.run(|cursor| cursor.attach_input_device(pointer.input_device()))
|
||||
.unwrap();
|
||||
})
|
||||
.unwrap();
|
||||
Some(Box::new(Pointer))
|
||||
}
|
||||
|
|
|
@ -1,5 +1,8 @@
|
|||
mod manager;
|
||||
mod keyboard;
|
||||
mod manager;
|
||||
mod pointer;
|
||||
|
||||
pub use self::manager::*;
|
||||
pub use self::keyboard::*;
|
||||
|
||||
use self::keyboard::*;
|
||||
use self::pointer::*;
|
||||
|
|
41
src/input/pointer.rs
Normal file
41
src/input/pointer.rs
Normal file
|
@ -0,0 +1,41 @@
|
|||
use crate::CompositorState;
|
||||
|
||||
use wlroots::{compositor, input::pointer, with_handles};
|
||||
|
||||
pub struct Pointer;
|
||||
|
||||
impl pointer::Handler for Pointer {
|
||||
fn on_motion_absolute(
|
||||
&mut self,
|
||||
compositor_handle: compositor::Handle,
|
||||
_pointer_handle: pointer::Handle,
|
||||
absolute_motion_event: &pointer::event::AbsoluteMotion,
|
||||
) {
|
||||
with_handles!([(compositor: {compositor_handle})] => {
|
||||
let compositor_state: &mut CompositorState = compositor.downcast();
|
||||
let (x, y) = absolute_motion_event.pos();
|
||||
|
||||
compositor_state.cursor_handle
|
||||
.run(|cursor| cursor.warp_absolute(absolute_motion_event.device(), x, y))
|
||||
.unwrap();
|
||||
})
|
||||
.unwrap();
|
||||
}
|
||||
|
||||
fn on_motion(
|
||||
&mut self,
|
||||
compositor_handle: compositor::Handle,
|
||||
_pointer_handle: pointer::Handle,
|
||||
motion_event: &pointer::event::Motion,
|
||||
) {
|
||||
with_handles!([(compositor: {compositor_handle})] => {
|
||||
let compositor_state: &mut CompositorState = compositor.downcast();
|
||||
let (dx, dy) = motion_event.delta();
|
||||
|
||||
compositor_state.cursor_handle
|
||||
.run(|cursor| cursor.move_to(None, dx, dy))
|
||||
.unwrap();
|
||||
})
|
||||
.unwrap();
|
||||
}
|
||||
}
|
51
src/main.rs
51
src/main.rs
|
@ -1,9 +1,53 @@
|
|||
mod input;
|
||||
mod logger;
|
||||
mod output;
|
||||
|
||||
use log::LevelFilter;
|
||||
use log::{warn, LevelFilter};
|
||||
|
||||
use wlroots::compositor;
|
||||
use wlroots::{
|
||||
compositor,
|
||||
cursor::{self, xcursor, Cursor},
|
||||
input::keyboard,
|
||||
output::layout,
|
||||
};
|
||||
|
||||
struct ExCursor;
|
||||
impl cursor::Handler for ExCursor {}
|
||||
|
||||
struct ExOutputLayout;
|
||||
impl layout::Handler for ExOutputLayout {}
|
||||
|
||||
struct CompositorState {
|
||||
pub xcursor_manager: xcursor::Manager,
|
||||
pub cursor_handle: cursor::Handle,
|
||||
pub layout_handle: layout::Handle,
|
||||
pub keyboards: Vec<keyboard::Handle>,
|
||||
}
|
||||
|
||||
impl CompositorState {
|
||||
pub fn new() -> Self {
|
||||
let mut xcursor_manager = xcursor::Manager::create(String::from("default"), 24)
|
||||
.expect("Could not create xcursor manager");
|
||||
|
||||
if xcursor_manager.load(1.0) {
|
||||
warn!("Cursor did not load");
|
||||
}
|
||||
|
||||
let cursor_handle = Cursor::create(Box::new(ExCursor));
|
||||
cursor_handle
|
||||
.run(|c| xcursor_manager.set_cursor_image(String::from("left_ptr"), c))
|
||||
.unwrap();
|
||||
|
||||
let layout_handle = layout::Layout::create(Box::new(ExOutputLayout));
|
||||
|
||||
CompositorState {
|
||||
xcursor_manager: xcursor_manager,
|
||||
cursor_handle: cursor_handle,
|
||||
layout_handle: layout_handle,
|
||||
keyboards: Vec::new(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
logger::init(LevelFilter::Info);
|
||||
|
@ -16,5 +60,6 @@ fn build_compositor() -> compositor::Compositor {
|
|||
.gles2(true)
|
||||
.data_device(true)
|
||||
.input_manager(input::manager())
|
||||
.build_auto(())
|
||||
.output_manager(output::manager())
|
||||
.build_auto(CompositorState::new())
|
||||
}
|
||||
|
|
42
src/output/manager.rs
Normal file
42
src/output/manager.rs
Normal file
|
@ -0,0 +1,42 @@
|
|||
use crate::CompositorState;
|
||||
|
||||
use log::debug;
|
||||
use wlroots::{compositor, output, with_handles};
|
||||
|
||||
pub fn manager() -> output::manager::Builder {
|
||||
output::manager::Builder::default().output_added(output_added)
|
||||
}
|
||||
|
||||
struct Output;
|
||||
|
||||
impl output::Handler for Output {}
|
||||
|
||||
fn output_added<'output>(
|
||||
compositor_handle: compositor::Handle,
|
||||
output_builder: output::Builder<'output>,
|
||||
) -> Option<output::BuilderResult<'output>> {
|
||||
debug!("Output added");
|
||||
|
||||
let mut result = output_builder.build_best_mode(Output);
|
||||
with_handles!([(compositor: {compositor_handle})] => {
|
||||
let compositor_state: &mut CompositorState = compositor.data.downcast_mut().unwrap();
|
||||
let layout_handle = &mut compositor_state.layout_handle;
|
||||
let cursor_handle = &mut compositor_state.cursor_handle;
|
||||
let xcursor_manager = &mut compositor_state.xcursor_manager;
|
||||
// TODO use output config if present instead of auto
|
||||
with_handles!([
|
||||
(layout: {layout_handle}),
|
||||
(cursor: {cursor_handle}),
|
||||
(output: {&mut result.output})
|
||||
] => {
|
||||
layout.add_auto(output);
|
||||
cursor.attach_output_layout(layout);
|
||||
xcursor_manager.load(output.scale());
|
||||
xcursor_manager.set_cursor_image("left_ptr".to_string(), cursor);
|
||||
let (x, y) = cursor.coords();
|
||||
cursor.warp(None, x, y);
|
||||
}).unwrap();
|
||||
Some(result)
|
||||
})
|
||||
.unwrap()
|
||||
}
|
3
src/output/mod.rs
Normal file
3
src/output/mod.rs
Normal file
|
@ -0,0 +1,3 @@
|
|||
mod manager;
|
||||
|
||||
pub use self::manager::*;
|
Loading…
Reference in a new issue