]> git.scottworley.com Git - srec/blobdiff - srec.py
Put output in a subdirectory
[srec] / srec.py
diff --git a/srec.py b/srec.py
index b9ab34448ce0351d2a6acd9ec7a0802ef8d94d58..4abe5817ac2be6826201dbfbddf0aab77c2c8ba4 100644 (file)
--- a/srec.py
+++ b/srec.py
@@ -27,22 +27,24 @@ recording: Recording | None = None
 def make_filename() -> str:
     directory = os.environ.get(
         'XDG_VIDEOS_DIR',
-        os.path.expanduser('~/Videos'))
+        os.path.expanduser('~/Videos/SRec'))
     os.makedirs(directory, exist_ok=True)
     timestamp = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
     return os.path.join(directory, f'srec {timestamp}.mkv')
 
 
+def video_source(stack: Gtk.Stack) -> list[str]:
+    if stack.get_child_by_name('not_recording').get_first_child().get_active():
+        return ['-f', 'v4l2', '-i', '/dev/video0']
+    return ['-f', 'x11grab', '-i', ':0.0+0,0']
+
+
 def on_start_recording(_: Gtk.Button, stack: Gtk.Stack) -> None:
     global recording  # pylint: disable=global-statement
     assert recording is None
     filename = make_filename()
-    command = [
-            'ffmpeg',
-            '-framerate', '25',
-            '-f', 'x11grab', '-i', ':0.0+0,0',
-            '-f', 'pulse', '-ac', '2', '-i', 'default',
-            filename]  # nopep8
+    command = (['ffmpeg', '-framerate', '25'] + video_source(stack) +
+               ['-f', 'pulse', '-ac', '2', '-i', 'default', filename])
     # pylint: disable=consider-using-with
     recording = Recording(
         filename=filename,
@@ -78,13 +80,17 @@ def on_activate(app: Gtk.Application) -> None:
     win.set_title('SRec')
     stack = Gtk.Stack()
 
-    start_recording = make_button("Start Recording", on_start_recording, stack)
-    stack.add_named(start_recording, "not_recording")
+    nr_box = Gtk.Box()
+    nr_box.set_orientation(Gtk.Orientation.VERTICAL)
+    webcam = Gtk.CheckButton(label='Webcam', active=True)
+    nr_box.append(webcam)
+    nr_box.append(Gtk.CheckButton(label='Screen', group=webcam))
+    nr_box.append(make_button("Start Recording", on_start_recording, stack))
+    stack.add_named(nr_box, "not_recording")
 
     r_box = Gtk.Box()
     r_box.set_orientation(Gtk.Orientation.VERTICAL)
-    stop_recording = make_button("Stop Recording", on_stop_recording, stack)
-    r_box.append(stop_recording)
+    r_box.append(make_button("Stop Recording", on_stop_recording, stack))
     stack.add_named(r_box, "recording")
 
     win.set_child(stack)