X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=futatabi%2Fmainwindow.h;h=2eeacc3c0ff31e4a521a68e4e4382b00ea60c88c;hb=3974e42a86665521c477ab0c1dfc0af1a28bede1;hp=43c9e78232f1d3edcff3375b450b24017e4bc835;hpb=a6f3a2275ad116e6ab338e583ab8ef1b1141b468;p=nageru diff --git a/futatabi/mainwindow.h b/futatabi/mainwindow.h index 43c9e78..2eeacc3 100644 --- a/futatabi/mainwindow.h +++ b/futatabi/mainwindow.h @@ -43,8 +43,10 @@ public: void preview() override; void queue() override; void play() override; + void toggle_lock() override; void jog(int delta) override; void switch_camera(unsigned camera_idx) override; + void set_master_speed(float speed) override; void cue_in() override; void cue_out() override; @@ -57,6 +59,7 @@ private: QLabel *disk_free_label; std::unique_ptr preview_player, live_player; + bool preview_playing = false; DB db; unsigned num_cameras; @@ -98,6 +101,10 @@ private: // NOTE: The undo stack always has the current state on top. std::deque undo_stack, redo_stack; + // If we need to blink the lock light, we do so for only a second. + // This timer signals that we should end it. + QTimer *lock_blink_timeout; + // Before a change that should be deferred (see above), currently_deferring_model_changes // must be set to true, and current_change_id must be given contents describing what's // changed to avoid accidental grouping. @@ -128,6 +135,9 @@ private: void preview_angle_clicked(unsigned stream_idx); void play_clicked(); void stop_clicked(); + void speed_slider_changed(int percent); + void speed_lock_clicked(); + void preview_player_done(); void live_player_done(); void live_player_clip_progress(const std::map &progress, double time_remaining); void set_output_status(const std::string &status); @@ -143,6 +153,8 @@ private: void state_changed(const StateProto &state); // Called post-filtering. void save_settings(); + void lock_blink_timer_expired(); + enum Rounding { FIRST_AT_OR_AFTER, LAST_BEFORE }; void preview_single_frame(int64_t pts, unsigned stream_idx, Rounding rounding); @@ -156,6 +168,7 @@ private: bool eventFilter(QObject *watched, QEvent *event) override; void report_disk_space(off_t free_bytes, double estimated_seconds_left); + void midi_mapping_triggered(); void exit_triggered(); void export_cliplist_clip_multitrack_triggered(); void export_playlist_clip_interpolated_triggered(); @@ -164,7 +177,8 @@ private: void undo_triggered(); void redo_triggered(); void quality_toggled(int quality, bool checked); - void padding_toggled(double seconds, bool checked); + void in_padding_toggled(double seconds, bool checked); + void out_padding_toggled(double seconds, bool checked); void highlight_camera_input(int stream_idx); void enable_or_disable_preview_button();