]> git.sesse.net Git - pkanalytics/blobdiff - mainwindow.h
Fix a threading issue, where we would call into the Qt thread from the video thread.
[pkanalytics] / mainwindow.h
index 9f27068b0dc5089cd710c55f0c795c2c256ae05b..95dfae78e3ae060eaf7745c041275d8a5a97a11b 100644 (file)
@@ -7,28 +7,43 @@
 
 class EventsModel;
 class PlayersModel;
+class FormationsModel;
 
 class MainWindow : public QMainWindow
 {
        Q_OBJECT
 
 public:
-       MainWindow(EventsModel *events, PlayersModel *players);
+       MainWindow(EventsModel *events, PlayersModel *players,
+                  FormationsModel *offensive_formations, FormationsModel *defensive_formations);
+       ~MainWindow() {
+               if (ui && ui->video) {
+                       ui->video->stop();
+               }
+       }
 
 private:
        void position_changed(uint64_t pos);
        void seek(int64_t delta_ms);
-       void insert_event(int button_id);
+       void insert_player_event(int button_id);
+       void insert_noplayer_event(const std::string &type);
        void set_current_event_type(const std::string &type);
+       void insert_or_change_formation(bool offense);
        void delete_current_event();
        void make_substitution();
-       void update_status();
+       void formation_double_clicked(bool offense, unsigned row);
+
+       void update_ui_from_time(uint64_t t);
+       void update_status(uint64_t t);
+       void update_player_buttons(uint64_t t);
+       void update_action_buttons(uint64_t t);
 
        Ui::MainWindow *ui;
        EventsModel *events;
        PlayersModel *players;
+       FormationsModel *offensive_formations;
+       FormationsModel *defensive_formations;
        bool seeking = false;
-       bool playing = true;
+       std::atomic<bool> playing{true};
        std::optional<uint64_t> buffered_seek;
-       QMediaPlayer *player;
 };