mirror of
https://github.com/xlmnxp/blue-recorder.git
synced 2025-04-04 16:54:55 +03:00
start/stop recording gnome wayland
This commit is contained in:
parent
595f831a4e
commit
e59a2a95ec
@ -1,5 +1,4 @@
|
|||||||
extern crate subprocess;
|
extern crate subprocess;
|
||||||
// extern crate dbus;
|
|
||||||
use chrono::prelude::*;
|
use chrono::prelude::*;
|
||||||
use gtk::{
|
use gtk::{
|
||||||
CheckButton, ComboBoxExt, ComboBoxText, Entry, EntryExt, FileChooser, FileChooserExt,
|
CheckButton, ComboBoxExt, ComboBoxText, Entry, EntryExt, FileChooser, FileChooserExt,
|
||||||
@ -10,6 +9,8 @@ use std::path::PathBuf;
|
|||||||
use std::process::Command;
|
use std::process::Command;
|
||||||
use std::thread::sleep;
|
use std::thread::sleep;
|
||||||
use std::time::Duration;
|
use std::time::Duration;
|
||||||
|
use std::sync::mpsc;
|
||||||
|
use std::sync::mpsc::{Sender, Receiver};
|
||||||
use subprocess::Exec;
|
use subprocess::Exec;
|
||||||
use zbus::dbus_proxy;
|
use zbus::dbus_proxy;
|
||||||
use zvariant::Value;
|
use zvariant::Value;
|
||||||
@ -52,14 +53,48 @@ pub struct Ffmpeg {
|
|||||||
pub command: Entry,
|
pub command: Entry,
|
||||||
pub process_id: Option<u32>,
|
pub process_id: Option<u32>,
|
||||||
pub saved_filename: Option<String>,
|
pub saved_filename: Option<String>,
|
||||||
|
pub unbound: Option<Sender<bool>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Ffmpeg {
|
impl Ffmpeg {
|
||||||
pub fn start_record(&mut self, x: u16, y: u16, width: u16, height: u16) -> u32 {
|
pub fn start_record(&mut self, x: u16, y: u16, width: u16, height: u16) -> u32 {
|
||||||
if self.process_id.is_some() {
|
if self.process_id.is_some() {
|
||||||
self.clone().stop_record();
|
self.stop_record();
|
||||||
|
}
|
||||||
|
|
||||||
|
self.saved_filename = Some(
|
||||||
|
self.filename
|
||||||
|
.0
|
||||||
|
.get_filename()
|
||||||
|
.unwrap()
|
||||||
|
.join(PathBuf::from(format!(
|
||||||
|
"{}.{}",
|
||||||
|
if self.filename.1.get_text().to_string().trim().eq("") {
|
||||||
|
Utc::now().to_string().replace(" UTC", "")
|
||||||
|
} else {
|
||||||
|
self.filename.1.get_text().to_string().trim().to_string()
|
||||||
|
},
|
||||||
|
self.filename.2.get_active_id().unwrap().to_string()
|
||||||
|
)))
|
||||||
|
.as_path()
|
||||||
|
.display()
|
||||||
|
.to_string(),
|
||||||
|
);
|
||||||
|
|
||||||
|
if is_wayland() {
|
||||||
|
if self.unbound.is_some() {
|
||||||
|
self.clone().unbound.unwrap().send(false).unwrap_or_default();
|
||||||
|
}
|
||||||
|
|
||||||
|
self.record_wayland(
|
||||||
|
self.saved_filename.as_ref().unwrap().to_string(),
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
width,
|
||||||
|
height,
|
||||||
|
);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
// self.clone().record_wayland();
|
|
||||||
|
|
||||||
let mut ffmpeg_command: Command = Command::new("ffmpeg");
|
let mut ffmpeg_command: Command = Command::new("ffmpeg");
|
||||||
|
|
||||||
@ -108,25 +143,6 @@ impl Ffmpeg {
|
|||||||
ffmpeg_command.arg("-q");
|
ffmpeg_command.arg("-q");
|
||||||
ffmpeg_command.arg("1");
|
ffmpeg_command.arg("1");
|
||||||
|
|
||||||
self.saved_filename = Some(
|
|
||||||
self.filename
|
|
||||||
.0
|
|
||||||
.get_filename()
|
|
||||||
.unwrap()
|
|
||||||
.join(PathBuf::from(format!(
|
|
||||||
"{}.{}",
|
|
||||||
if self.filename.1.get_text().to_string().trim().eq("") {
|
|
||||||
Utc::now().to_string().replace(" UTC", "")
|
|
||||||
} else {
|
|
||||||
self.filename.1.get_text().to_string().trim().to_string()
|
|
||||||
},
|
|
||||||
self.filename.2.get_active_id().unwrap().to_string()
|
|
||||||
)))
|
|
||||||
.as_path()
|
|
||||||
.display()
|
|
||||||
.to_string(),
|
|
||||||
);
|
|
||||||
|
|
||||||
ffmpeg_command.arg(self.saved_filename.as_ref().unwrap());
|
ffmpeg_command.arg(self.saved_filename.as_ref().unwrap());
|
||||||
ffmpeg_command.arg("-y");
|
ffmpeg_command.arg("-y");
|
||||||
|
|
||||||
@ -138,7 +154,7 @@ impl Ffmpeg {
|
|||||||
self.process_id.unwrap()
|
self.process_id.unwrap()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn stop_record(self) {
|
pub fn stop_record(&self) {
|
||||||
// kill the process to stop recording
|
// kill the process to stop recording
|
||||||
if self.process_id.is_some() {
|
if self.process_id.is_some() {
|
||||||
Command::new("kill")
|
Command::new("kill")
|
||||||
@ -147,6 +163,17 @@ impl Ffmpeg {
|
|||||||
.unwrap();
|
.unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if is_wayland() {
|
||||||
|
// create new dbus session
|
||||||
|
let connection = zbus::Connection::new_session().unwrap();
|
||||||
|
// bind the connection to gnome screencast proxy
|
||||||
|
let gnome_screencast_proxy = GnomeScreencastProxy::new(&connection).unwrap();
|
||||||
|
gnome_screencast_proxy.stop_screencast().unwrap();
|
||||||
|
if self.unbound.is_some() {
|
||||||
|
self.unbound.as_ref().unwrap().send(true).unwrap_or_default();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// execute command after finish recording
|
// execute command after finish recording
|
||||||
if !(self.command.get_text().trim() == "") {
|
if !(self.command.get_text().trim() == "") {
|
||||||
Exec::shell(self.command.get_text().trim()).popen().unwrap();
|
Exec::shell(self.command.get_text().trim()).popen().unwrap();
|
||||||
@ -154,27 +181,36 @@ impl Ffmpeg {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Gnome screencast for record wayland
|
// Gnome screencast for record wayland
|
||||||
pub fn record_wayland(self) {
|
pub fn record_wayland(&mut self, filename: String, x: u16, y: u16, width: u16, height: u16) {
|
||||||
// create new dbus session
|
// create new dbus session
|
||||||
let connection = zbus::Connection::new_session().unwrap();
|
let connection = zbus::Connection::new_session().unwrap();
|
||||||
|
|
||||||
// bind the connection to gnome screencast proxy
|
// bind the connection to gnome screencast proxy
|
||||||
let gnome_screencast_proxy = GnomeScreencastProxy::new(&connection).unwrap();
|
let gnome_screencast_proxy = GnomeScreencastProxy::new(&connection).unwrap();
|
||||||
|
|
||||||
// options for gnome screencast
|
// options for gnome screencast
|
||||||
let mut screencast_options: HashMap<&str, Value> = HashMap::new();
|
let mut screencast_options: HashMap<&str, Value> = HashMap::new();
|
||||||
screencast_options.insert("framerate", Value::new(self.record_frames.get_value()));
|
screencast_options.insert("framerate", Value::new(self.record_frames.get_value()));
|
||||||
screencast_options.insert("draw-cursor", Value::new(self.record_mouse.get_active()));
|
screencast_options.insert("draw-cursor", Value::new(self.record_mouse.get_active()));
|
||||||
|
let (tx, tr): (Sender<bool>, Receiver<bool>) = mpsc::channel();
|
||||||
|
self.unbound = Some(tx);
|
||||||
|
let receiver: Receiver<bool> = tr;
|
||||||
|
std::thread::spawn(move || {
|
||||||
gnome_screencast_proxy
|
gnome_screencast_proxy
|
||||||
.screencast(
|
.screencast_area(
|
||||||
"/home/xlmnxp/Projects/blue-recorder/test/test.webm",
|
x.into(),
|
||||||
|
y.into(),
|
||||||
|
width.into(),
|
||||||
|
height.into(),
|
||||||
|
&filename,
|
||||||
screencast_options,
|
screencast_options,
|
||||||
)
|
)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
// for testing it will record 20 seconds then stop the recording
|
loop {
|
||||||
sleep(Duration::from_secs(20u64));
|
if receiver.recv().unwrap_or(false) {
|
||||||
gnome_screencast_proxy.stop_screencast().unwrap();
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn play_record(self) {
|
pub fn play_record(self) {
|
||||||
@ -186,3 +222,9 @@ impl Ffmpeg {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn is_wayland() -> bool {
|
||||||
|
std::env::var("XDG_SESSION_TYPE")
|
||||||
|
.unwrap()
|
||||||
|
.eq_ignore_ascii_case("wayland")
|
||||||
|
}
|
||||||
|
28
src/main.rs
28
src/main.rs
@ -147,15 +147,34 @@ fn main() {
|
|||||||
audio_switch.set_active(config_management::get_bool("default", "audiocheck"));
|
audio_switch.set_active(config_management::get_bool("default", "audiocheck"));
|
||||||
mouse_switch.set_active(config_management::get_bool("default", "mousecheck"));
|
mouse_switch.set_active(config_management::get_bool("default", "mousecheck"));
|
||||||
follow_mouse_switch.set_active(config_management::get_bool("default", "followmousecheck"));
|
follow_mouse_switch.set_active(config_management::get_bool("default", "followmousecheck"));
|
||||||
video_switch.connect_toggled(|switch: &CheckButton| {
|
|
||||||
|
let _mouse_switch = mouse_switch.clone();
|
||||||
|
let _follow_mouse_switch = follow_mouse_switch.clone();
|
||||||
|
video_switch.connect_toggled(move |switch: &CheckButton| {
|
||||||
config_management::set_bool("default", "videocheck", switch.get_active());
|
config_management::set_bool("default", "videocheck", switch.get_active());
|
||||||
|
if switch.get_active() {
|
||||||
|
_mouse_switch.set_sensitive(true);
|
||||||
|
_follow_mouse_switch.set_sensitive(true);
|
||||||
|
} else {
|
||||||
|
_mouse_switch.set_sensitive(false);
|
||||||
|
_follow_mouse_switch.set_sensitive(false);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let _follow_mouse_switch = follow_mouse_switch.clone();
|
||||||
|
mouse_switch.connect_toggled(move |switch: &CheckButton| {
|
||||||
|
config_management::set_bool("default", "mousecheck", switch.get_active());
|
||||||
|
if switch.get_active() {
|
||||||
|
_follow_mouse_switch.set_sensitive(true);
|
||||||
|
} else {
|
||||||
|
_follow_mouse_switch.set_sensitive(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
audio_switch.connect_toggled(|switch: &CheckButton| {
|
audio_switch.connect_toggled(|switch: &CheckButton| {
|
||||||
config_management::set_bool("default", "audiocheck", switch.get_active());
|
config_management::set_bool("default", "audiocheck", switch.get_active());
|
||||||
});
|
});
|
||||||
mouse_switch.connect_toggled(|switch: &CheckButton| {
|
|
||||||
config_management::set_bool("default", "mousecheck", switch.get_active());
|
|
||||||
});
|
|
||||||
follow_mouse_switch.connect_toggled(|switch: &CheckButton| {
|
follow_mouse_switch.connect_toggled(|switch: &CheckButton| {
|
||||||
config_management::set_bool("default", "followmousecheck", switch.get_active());
|
config_management::set_bool("default", "followmousecheck", switch.get_active());
|
||||||
});
|
});
|
||||||
@ -270,6 +289,7 @@ fn main() {
|
|||||||
command: command_entry,
|
command: command_entry,
|
||||||
process_id: None,
|
process_id: None,
|
||||||
saved_filename: None,
|
saved_filename: None,
|
||||||
|
unbound: None
|
||||||
}));
|
}));
|
||||||
|
|
||||||
// App Indicator
|
// App Indicator
|
||||||
|
BIN
test/test.webm
Normal file
BIN
test/test.webm
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user