Basic input and output managers

This commit is contained in:
buffet 2019-01-25 10:47:04 +01:00
parent 80204041fe
commit 05ef34fbe6
6 changed files with 175 additions and 10 deletions

View file

@ -1,17 +1,48 @@
use crate::input::Keyboard; use crate::{
input::{Keyboard, Pointer},
CompositorState,
};
use log::debug;
use wlroots::{ use wlroots::{
compositor, compositor,
input::{self, keyboard}, input::{self, keyboard, pointer},
with_handles,
}; };
pub fn manager() -> input::manager::Builder { 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( fn keyboard_added(
_compositor_handle: compositor::Handle, compositor_handle: compositor::Handle,
_keyboard_handle: keyboard::Handle, keyboard_handle: keyboard::Handle,
) -> Option<Box<keyboard::Handler>> { ) -> 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)) 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))
}

View file

@ -1,5 +1,8 @@
mod manager;
mod keyboard; mod keyboard;
mod manager;
mod pointer;
pub use self::manager::*; pub use self::manager::*;
pub use self::keyboard::*;
use self::keyboard::*;
use self::pointer::*;

41
src/input/pointer.rs Normal file
View 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();
}
}

View file

@ -1,9 +1,53 @@
mod input; mod input;
mod logger; 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() { fn main() {
logger::init(LevelFilter::Info); logger::init(LevelFilter::Info);
@ -16,5 +60,6 @@ fn build_compositor() -> compositor::Compositor {
.gles2(true) .gles2(true)
.data_device(true) .data_device(true)
.input_manager(input::manager()) .input_manager(input::manager())
.build_auto(()) .output_manager(output::manager())
.build_auto(CompositorState::new())
} }

42
src/output/manager.rs Normal file
View 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
View file

@ -0,0 +1,3 @@
mod manager;
pub use self::manager::*;