X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mainwindow.h;h=7f8c57ac805a79928573a01e76e17e5916ab8d39;hb=c68428cb7aa931d20250a309890c21d95537dcdc;hp=76124ae63fbb1e6518986dd1e7bc54fff00b3c30;hpb=83f00b3618fa1cb4527b59f6e2d2f8d3f52cc25a;p=nageru diff --git a/mainwindow.h b/mainwindow.h index 76124ae..7f8c57a 100644 --- a/mainwindow.h +++ b/mainwindow.h @@ -1,11 +1,17 @@ #ifndef MAINWINDOW_H #define MAINWINDOW_H +#include "clip_list.h" +#include "db.h" +#include "state.pb.h" + +#include +#include +#include #include #include -#include - -#include "clip_list.h" +#include +#include namespace Ui { class MainWindow; @@ -13,18 +19,22 @@ class MainWindow; class Player; -class MainWindow : public QMainWindow -{ +class MainWindow : public QMainWindow { Q_OBJECT public: MainWindow(); + // HTTP callback. TODO: Does perhaps not belong to MainWindow? + std::pair get_queue_status() const; + //private: Ui::MainWindow *ui; private: + QLabel *disk_free_label; Player *preview_player, *live_player; + DB db; // State when doing a scrub operation on a timestamp with the mouse. bool scrubbing = false; @@ -36,6 +46,29 @@ private: int scrub_row; int scrub_column; + // Used to keep track of small mouse wheel motions on the camera index in the playlist. + int last_mousewheel_camera_row = -1; + int leftover_angle_degrees = 0; + + // Some operations, notably scrubbing and scrolling, happen in so large increments + // that we want to group them instead of saving to disk every single time. + // If they happen (ie., we get a callback from the model that it's changed) while + // currently_deferring_model_changes, we fire off this timer. If it manages to elapse + // before some other event happens, we count the event. (If the other event is of the + // same kind, we just fire off the timer anew instead of taking any action.) + QTimer *defer_timeout; + std::string deferred_change_id; + StateProto deferred_state; + + // 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. + bool currently_deferring_model_changes = false; + std::string current_change_id; + + mutable std::mutex queue_status_mu; + std::string queue_status; // Under queue_status_mu. + void cue_in_clicked(); void cue_out_clicked(); void queue_clicked(); @@ -43,13 +76,33 @@ private: void preview_angle_clicked(unsigned stream_idx); void play_clicked(); void live_player_clip_done(); + std::pair live_player_get_next_clip(); + void live_player_clip_progress(const std::map &progress); + void set_output_status(const std::string &status); + void playlist_duplicate(); + void playlist_remove(); + void playlist_move(int delta); + + void defer_timer_expired(); + void content_changed(); // In clip_list or play_list. + void state_changed(const StateProto &state); // Called post-filtering. enum Rounding { FIRST_AT_OR_AFTER, LAST_BEFORE }; void preview_single_frame(int64_t pts, unsigned stream_idx, Rounding rounding); + // Also covers when the playlist itself changes. + void playlist_selection_changed(); + + void clip_list_selection_changed(const QModelIndex ¤t, const QModelIndex &previous); + void resizeEvent(QResizeEvent *event) override; bool eventFilter(QObject *watched, QEvent *event) override; + void report_disk_space(off_t free_bytes, double estimated_seconds_left); + void exit_triggered(); + + void highlight_camera_input(int stream_idx); + private slots: void relayout(); }; @@ -57,4 +110,3 @@ private slots: extern MainWindow *global_mainwindow; #endif -