Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Initial gtk4 migration #39

Merged
merged 50 commits into from
Nov 22, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
6f48df3
Initial gtk4 migration
ochibani Sep 24, 2022
3c0ea6e
fix window size by changing main.ui
ochibani Sep 28, 2022
78d3fb6
display home icons in folder chooser
ochibani Sep 29, 2022
84cc6b3
area chooser window redesigned
ochibani Sep 30, 2022
8092950
spell check
ochibani Oct 1, 2022
835e466
remove wayland from ffmpeg-interface
ochibani Oct 14, 2022
3428d6d
Remove buggy video formats
ochibani Oct 14, 2022
56f5598
fix is_file_already_exists & play button
ochibani Oct 16, 2022
d9e7458
use system theme colors
xlmnxp Oct 18, 2022
a6ca6d3
look like fixed the video and audio merge
xlmnxp Oct 18, 2022
828074a
fix Progress dialog
xlmnxp Oct 18, 2022
336e8e4
hide window selection in wayland
ochibani Oct 18, 2022
71edab6
folder chooser parent
ochibani Oct 19, 2022
cec2d85
folder chooser hide
ochibani Oct 19, 2022
d1c4706
fix FileChooserButton
ochibani Oct 20, 2022
257c5b4
remove progress button
ochibani Oct 20, 2022
ad01c74
remove audio only record code
ochibani Oct 24, 2022
a3dbd29
add delay timer
ochibani Nov 1, 2022
f7c72ff
add recording timer
ochibani Nov 2, 2022
cbcb44d
add hours to timer
ochibani Nov 2, 2022
3e37cc9
minor change
ochibani Nov 4, 2022
258cda8
Edit indicator.rs
ochibani Nov 26, 2022
78ec81d
Working X11 version
ochibani Nov 26, 2022
fb32ebe
use 60fps as default
xlmnxp Feb 22, 2023
86303da
Merge branch 'blue-recorder-gtk4' of https://github.com/ochibani/blue…
xlmnxp Feb 22, 2023
c5189de
bug fixes, force select audio or video to record
xlmnxp Feb 22, 2023
a8f025e
use of Childs instead of kill command (Work cross multiple operating …
xlmnxp Feb 22, 2023
d82d71b
Simplify the implementation of Ffmpeg
xlmnxp Feb 23, 2023
b5b10cf
fix video and audio merges and fix audio recording issue
xlmnxp Feb 28, 2023
2ed389d
include tr.po with migration to GTK4
xlmnxp Mar 1, 2023
af982be
auto detect dark mode and change icons
xlmnxp Mar 1, 2023
3695530
improve style of select buttons
xlmnxp Oct 14, 2023
f857ba5
remove overwrite switch and fix message dialog
xlmnxp Oct 14, 2023
329c4a7
add wayland recorder
xlmnxp Oct 14, 2023
29b0a61
little improvements
xlmnxp Oct 15, 2023
aa9213a
little improvements
xlmnxp Oct 15, 2023
5d8f19f
update ui
ochibani Oct 16, 2023
7688528
update ui
ochibani Oct 17, 2023
8b7343c
add auto hide
ochibani Oct 19, 2023
b959262
add wayland record and mouse toggle
xlmnxp Oct 19, 2023
0e95762
refactor of code
xlmnxp Oct 21, 2023
5f847a0
remove progress dialog
xlmnxp Oct 21, 2023
5f079b8
fix borrow_mut
xlmnxp Oct 21, 2023
75df858
enable recording of window or screen
xlmnxp Oct 21, 2023
6c049e4
remove temporary video file when recording video only
xlmnxp Oct 21, 2023
510a1e5
enable recording of window or screen
xlmnxp Oct 21, 2023
5af98f9
remember last decision to record window or screen
xlmnxp Oct 22, 2023
4e4756e
update ui
ochibani Oct 23, 2023
591a671
remove appid from gtk part
xlmnxp Oct 27, 2023
d10fdf7
upgrade snap packaging
xlmnxp Oct 28, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add delay timer
  • Loading branch information
ochibani committed Nov 1, 2022
commit a3dbd2989b9d2dfc56e258db1db2ff432e6ef974
43 changes: 25 additions & 18 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ gtk-sys = "0.15"
glib = "0.10.3"
rust-ini = "0.16"
regex = "1.4.3"
secfmt = "0.1.1"
subprocess = "0.2.6"

[dependencies.gio]
Expand Down
42 changes: 42 additions & 0 deletions interfaces/main.ui
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,48 @@
</object>
</child>
</object>
<object class="GtkWindow" id="delay_window">
<property name="can-focus">True</property>
<property name="transient-for">main_window</property>
<property name="resizable">False</property>
<property name="modal">True</property>
<property name="default-height">200</property>
<property name="default-width">200</property>
<property name="decorated">False</property>
<property name="deletable">False</property>
<child>
<object class="GtkBox">
<property name="orientation">vertical</property>
<child type="top">
<object class="GtkLabel" id="delay_window_title">
<property name="name">delay_window_title</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Start Recording in…</property>
<property name="margin-top">10</property>
</object>
</child>
<child type="center">
<object class="GtkLabel" id="delay_window_label">
<property name="name">delay_window_label</property>
<property name="vexpand">True</property>
<property name="hexpand">True</property>
<property name="visible">True</property>
</object>
</child>
<child type="bottom">
<object class="GtkButton" id="delay_window_stopbutton">
<property name="visible">True</property>
<property name="can-focus">True</property>
<property name="receives-default">True</property>
<property name="margin-start">10</property>
<property name="margin-end">10</property>
<property name="margin-bottom">10</property>
<property name="label" translatable="yes">Stop</property>
</object>
</child>
</object>
</child>
</object>
<object class="GtkImage" id="image3">
<property name="visible">True</property>
<property name="can-focus">True</property>
Expand Down
4 changes: 1 addition & 3 deletions src/ffmpeg_interface.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
extern crate subprocess;

use chrono::prelude::*;
use gettextrs::gettext;
use gtk::prelude::*;
Expand Down Expand Up @@ -53,7 +54,6 @@ pub struct Ffmpeg {
pub record_mouse: CheckButton,
pub follow_mouse: CheckButton,
pub record_frames: SpinButton,
pub record_delay: SpinButton,
pub command: Entry,
pub video_process_id: Option<u32>,
pub audio_process_id: Option<u32>,
Expand Down Expand Up @@ -169,8 +169,6 @@ impl Ffmpeg {
ffmpeg_command.arg("1");
ffmpeg_command.arg(self.saved_filename.as_ref().unwrap());
ffmpeg_command.arg("-y");
// Sleep for delay
sleep(Duration::from_secs(self.record_delay.value() as u64));
// Start recording and return the process id
self.video_process_id = Some(ffmpeg_command.spawn().unwrap().id());
return (self.video_process_id, self.audio_process_id);
Expand Down
66 changes: 46 additions & 20 deletions src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,22 @@ extern crate gtk;
mod area_capture;
mod config_management;
mod ffmpeg_interface;
mod timer;

use ffmpeg_interface::{Ffmpeg, ProgressWidget};
use gettextrs::{bindtextdomain, gettext, LocaleCategory, setlocale, textdomain};
use gtk::{prelude::*, Application};
use gtk::{AboutDialog, Builder, Button, CheckButton, ComboBoxText, CssProvider, Entry, FileChooserNative, FileChooserAction, Image, Label, MessageDialog, ProgressBar, SpinButton, ToggleButton, Window};
use gtk::{AboutDialog, Application, Builder, Button, CheckButton, ComboBoxText, CssProvider, Entry, FileChooserNative, FileChooserAction, Image, Label, MessageDialog, ProgressBar, SpinButton, ToggleButton, Window};
use gtk::prelude::*;
use gtk::glib;
use std::cell::RefCell;
use std::ops::Add;
use std::path::Path;
use std::process::{Command, Stdio};
use std::rc::Rc;
use timer::{recording_delay};

fn main() {
//Create new application
// Create new application
let application = Application::new(Some("sa.sy.blue-recorder"), Default::default(),);
application.connect_activate(build_ui);
application.run();
Expand Down Expand Up @@ -70,6 +73,9 @@ pub fn build_ui(application: &Application) {
let command_label: Label = builder.object("command_label").unwrap();
let delay_label: Label = builder.object("delay_label").unwrap();
let delay_spin: SpinButton = builder.object("delay").unwrap();
let delay_window: Window = builder.object("delay_window").unwrap();
let delay_window_label: Label = builder.object("delay_window_label").unwrap();
let delay_window_button: Button = builder.object("delay_window_stopbutton").unwrap();
let filename_entry: Entry = builder.object("filename").unwrap();
let folder_chooser_button: Button = builder.object("folder_chooser").unwrap();
let folder_chooser_image: Image = builder.object("folder_chooser_image").unwrap();
Expand All @@ -96,13 +102,13 @@ pub fn build_ui(application: &Application) {
// Windows
main_window.set_title(Some(&gettext("Blue Recorder")));
main_window.set_application(Some(application));
area_chooser_window.set_title(Some(&gettext("Area Chooser"))); //title is hidden
area_chooser_window.set_title(Some(&gettext("Area Chooser"))); // Title is hidden

//Hide stop & play buttons
// Hide stop & play buttons
stop_button.hide();
play_button.hide();

//Hide window grab button in Wayland
// Hide window grab button in Wayland
if is_wayland() {
window_grab_button.hide();
}
Expand Down Expand Up @@ -276,6 +282,18 @@ pub fn build_ui(application: &Application) {
audio_source_label.set_label(&gettext("Audio Input Source:"));

// Spin
frames_spin.set_value(
config_management::get("default", "frame")
.parse::<f64>()
.unwrap(),
);

delay_spin.set_value(
config_management::get("default", "delay")
.parse::<f64>()
.unwrap(),
);

let _frames_spin = frames_spin.to_owned();
frames_spin.connect_value_changed(move |_| {
config_management::set(
Expand Down Expand Up @@ -375,7 +393,6 @@ pub fn build_ui(application: &Application) {
record_mouse: mouse_switch,
follow_mouse: follow_mouse_switch,
record_frames: frames_spin,
record_delay: delay_spin,
command: command_entry,
video_process_id: None,
audio_process_id: None,
Expand All @@ -386,30 +403,39 @@ pub fn build_ui(application: &Application) {
overwrite: overwrite_switch,
}));

let _delay_window = delay_window.clone();
let mut _ffmpeg_record_interface = ffmpeg_record_interface.clone();
let _stop_button = stop_button.clone();
let _record_button = record_button.clone();
let _stop_button = stop_button.clone();
record_button.connect_clicked(move |_| {
let _area_capture = area_capture.borrow_mut();
match _ffmpeg_record_interface.borrow_mut().start_record(
_area_capture.x,
_area_capture.y,
_area_capture.width,
_area_capture.height,
) {
(None, None) => {
if delay_spin.value()as u64 > 0 {
recording_delay(delay_spin.clone(), delay_spin.value()as u64, delay_window.clone(), delay_window_label.clone(), _record_button.clone());
}
if delay_spin.value()as u64 == 0 {
let _area_capture = area_capture.borrow_mut();
match _ffmpeg_record_interface.borrow_mut().start_record(
_area_capture.x,
_area_capture.y,
_area_capture.width,
_area_capture.height,
) {
(None, None) => {
// Do nothing if the start_record function return nothing
}
_ => {
_record_button.hide();
_stop_button.show();
_ => {
_record_button.hide();
_stop_button.show();
}
}
}
});

delay_window_button.connect_clicked(move |_| {
});

let mut _ffmpeg_record_interface = ffmpeg_record_interface.clone();
let _stop_button = stop_button.clone();
let _play_button = play_button.clone();
let _stop_button = stop_button.clone();
stop_button.connect_clicked(move |_| {
_ffmpeg_record_interface.borrow_mut().clone().stop_record();
record_button.show();
Expand Down
10 changes: 10 additions & 0 deletions src/styles/global.css
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,13 @@
color: @theme_selected_fg_color;
background: @theme_selected_bg_color;
}

#delay_window_label{
font-size: 350%;
font-weight: 250;
}

#delay_window_title{
font-size: 120%;
font-weight: 50;
}
Loading