Split wayland buffer code into a file
This commit is contained in:
parent
c46ab4f1e6
commit
8c690e9648
2 changed files with 63 additions and 49 deletions
58
src/wayland/buffer.rs
Normal file
58
src/wayland/buffer.rs
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
use cctk::{
|
||||||
|
screencopy::BufferInfo,
|
||||||
|
sctk::{globals::ProvidesBoundGlobal, shm::raw::RawPool},
|
||||||
|
wayland_client::{
|
||||||
|
protocol::{wl_buffer, wl_shm},
|
||||||
|
QueueHandle,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
use cosmic::iced::widget::image;
|
||||||
|
|
||||||
|
pub struct Buffer {
|
||||||
|
pub pool: RawPool,
|
||||||
|
pub buffer: wl_buffer::WlBuffer,
|
||||||
|
pub buffer_info: BufferInfo,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Buffer {
|
||||||
|
pub fn new(
|
||||||
|
buffer_info: BufferInfo,
|
||||||
|
shm: &impl ProvidesBoundGlobal<wl_shm::WlShm, 1>,
|
||||||
|
qh: &QueueHandle<super::AppData>,
|
||||||
|
) -> Self {
|
||||||
|
// Assume format is already known to be valid
|
||||||
|
let mut pool =
|
||||||
|
RawPool::new((buffer_info.stride * buffer_info.height) as usize, shm).unwrap();
|
||||||
|
let format = wl_shm::Format::try_from(buffer_info.format).unwrap();
|
||||||
|
let buffer = pool.create_buffer(
|
||||||
|
0,
|
||||||
|
buffer_info.width as i32,
|
||||||
|
buffer_info.height as i32,
|
||||||
|
buffer_info.stride as i32,
|
||||||
|
format,
|
||||||
|
(),
|
||||||
|
qh,
|
||||||
|
);
|
||||||
|
Self {
|
||||||
|
pool,
|
||||||
|
buffer,
|
||||||
|
buffer_info,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Buffer must be released by server for safety
|
||||||
|
pub unsafe fn to_image(&mut self) -> image::Handle {
|
||||||
|
// XXX is this at all a performance issue?
|
||||||
|
image::Handle::from_pixels(
|
||||||
|
self.buffer_info.width,
|
||||||
|
self.buffer_info.height,
|
||||||
|
self.pool.mmap().to_vec(),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Drop for Buffer {
|
||||||
|
fn drop(&mut self) {
|
||||||
|
self.buffer.destroy();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -20,11 +20,10 @@ use cctk::{
|
||||||
sctk::{
|
sctk::{
|
||||||
self,
|
self,
|
||||||
event_loop::WaylandSource,
|
event_loop::WaylandSource,
|
||||||
globals::ProvidesBoundGlobal,
|
|
||||||
output::{OutputHandler, OutputState},
|
output::{OutputHandler, OutputState},
|
||||||
registry::{ProvidesRegistryState, RegistryState},
|
registry::{ProvidesRegistryState, RegistryState},
|
||||||
seat::{SeatHandler, SeatState},
|
seat::{SeatHandler, SeatState},
|
||||||
shm::{raw::RawPool, ShmHandler, ShmState},
|
shm::{ShmHandler, ShmState},
|
||||||
},
|
},
|
||||||
toplevel_info::{ToplevelInfo, ToplevelInfoHandler, ToplevelInfoState},
|
toplevel_info::{ToplevelInfo, ToplevelInfoHandler, ToplevelInfoState},
|
||||||
toplevel_management::{ToplevelManagerHandler, ToplevelManagerState},
|
toplevel_management::{ToplevelManagerHandler, ToplevelManagerState},
|
||||||
|
|
@ -52,6 +51,9 @@ use std::{
|
||||||
thread,
|
thread,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
mod buffer;
|
||||||
|
use buffer::Buffer;
|
||||||
|
|
||||||
// TODO define subscription for a particular output/workspace/toplevel (but we want to rate limit?)
|
// TODO define subscription for a particular output/workspace/toplevel (but we want to rate limit?)
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
|
|
@ -115,45 +117,6 @@ pub enum Cmd {
|
||||||
CaptureFilter(CaptureFilter),
|
CaptureFilter(CaptureFilter),
|
||||||
}
|
}
|
||||||
|
|
||||||
struct Buffer {
|
|
||||||
pool: RawPool,
|
|
||||||
buffer: wl_buffer::WlBuffer,
|
|
||||||
buffer_info: BufferInfo,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Buffer {
|
|
||||||
fn new(
|
|
||||||
buffer_info: BufferInfo,
|
|
||||||
shm: &impl ProvidesBoundGlobal<wl_shm::WlShm, 1>,
|
|
||||||
qh: &QueueHandle<AppData>,
|
|
||||||
) -> Self {
|
|
||||||
// Assume format is already known to be valid
|
|
||||||
let mut pool =
|
|
||||||
RawPool::new((buffer_info.stride * buffer_info.height) as usize, shm).unwrap();
|
|
||||||
let format = wl_shm::Format::try_from(buffer_info.format).unwrap();
|
|
||||||
let buffer = pool.create_buffer(
|
|
||||||
0,
|
|
||||||
buffer_info.width as i32,
|
|
||||||
buffer_info.height as i32,
|
|
||||||
buffer_info.stride as i32,
|
|
||||||
format,
|
|
||||||
(),
|
|
||||||
qh,
|
|
||||||
);
|
|
||||||
Self {
|
|
||||||
pool,
|
|
||||||
buffer,
|
|
||||||
buffer_info,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Drop for Buffer {
|
|
||||||
fn drop(&mut self) {
|
|
||||||
self.buffer.destroy();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct Capture {
|
struct Capture {
|
||||||
buffer: Mutex<Option<Buffer>>,
|
buffer: Mutex<Option<Buffer>>,
|
||||||
source: CaptureSource,
|
source: CaptureSource,
|
||||||
|
|
@ -432,7 +395,6 @@ impl ScreencopyHandler for AppData {
|
||||||
&& x.format == wl_shm::Format::Abgr8888.into()
|
&& x.format == wl_shm::Format::Abgr8888.into()
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
let buf_len = buffer_info.stride * buffer_info.height;
|
|
||||||
|
|
||||||
// XXX fix in compositor
|
// XXX fix in compositor
|
||||||
if buffer_info.width == 0 || buffer_info.height == 0 || buffer_info.stride == 0 {
|
if buffer_info.width == 0 || buffer_info.height == 0 || buffer_info.stride == 0 {
|
||||||
|
|
@ -472,13 +434,7 @@ impl ScreencopyHandler for AppData {
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut buffer = capture.buffer.lock().unwrap();
|
let mut buffer = capture.buffer.lock().unwrap();
|
||||||
let mut buffer = buffer.as_mut().unwrap();
|
let image = unsafe { buffer.as_mut().unwrap().to_image() };
|
||||||
// XXX is this at all a performance issue?
|
|
||||||
let image = image::Handle::from_pixels(
|
|
||||||
buffer.buffer_info.width,
|
|
||||||
buffer.buffer_info.height,
|
|
||||||
buffer.pool.mmap().to_vec(),
|
|
||||||
);
|
|
||||||
let event = match &capture.source {
|
let event = match &capture.source {
|
||||||
CaptureSource::Toplevel(toplevel) => Event::ToplevelCapture(toplevel.clone(), image),
|
CaptureSource::Toplevel(toplevel) => Event::ToplevelCapture(toplevel.clone(), image),
|
||||||
CaptureSource::Workspace(workspace, _) => {
|
CaptureSource::Workspace(workspace, _) => {
|
||||||
Loading…
Add table
Add a link
Reference in a new issue