X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=events.h;h=df5fcb6a9b8c8b08871f2d76ef7804a5501652f7;hb=7a960fbf75a145f30e34f5f803062d91afb81165;hp=9804836aaabde417e07ac69fb4d4c52924276e04;hpb=d9795989980dddf5213e1e1293002e5192ad9c54;p=pkanalytics diff --git a/events.h b/events.h index 9804836..df5fcb6 100644 --- a/events.h +++ b/events.h @@ -12,7 +12,7 @@ class EventsModel : public QAbstractTableModel { public: - EventsModel(sqlite3 *db); + EventsModel(sqlite3 *db, int match_id); int rowCount(const QModelIndex &parent) const override { @@ -25,9 +25,11 @@ public: QVariant headerData(int section, Qt::Orientation orientation, int role) const override; QVariant data(const QModelIndex &index, int role) const override; - unsigned insert_event(uint64_t t, std::optional player_id, const std::string &type = "unknown"); // Returns the row. + unsigned insert_event(uint64_t t, std::optional player_id, std::optional formation_id, const std::string &type = "unknown"); // Returns the row. void delete_event(unsigned row); + std::string get_event_type(unsigned row) { return events[row].type; } void set_event_type(unsigned row, const std::string &type); + void set_event_formation(unsigned row, int formation_id); uint64_t get_time(unsigned row) { return events[row].t; } unsigned get_last_event_pos(uint64_t t) const; // Last event that happened at or before t. QModelIndex get_last_event_qt(uint64_t t) const { @@ -38,6 +40,7 @@ public: struct Status { unsigned our_score, their_score; enum { NOT_STARTED, OFFENSE, DEFENSE } attack_state; + unsigned offensive_formation, defensive_formation; bool stoppage; enum { NOT_PULLING, SHOULD_PULL, PULL_IN_AIR } pull_state; unsigned num_passes; @@ -47,6 +50,13 @@ public: Status get_status_at(uint64_t t); std::set get_team_at(uint64_t t); void set_team_at(uint64_t, const std::set &new_team); + std::vector sort_team(const std::set &team) const; // Ordered first by gender, then by number. + void set_formation_at(uint64_t t, bool offense, unsigned formation); + + // Used to notify when we've inserted a new one into the database. + void inserted_new_formation(int formation_id, const std::string &name) { + formations[formation_id] = Formation{ formation_id, name }; + } private: struct Player { @@ -55,16 +65,25 @@ private: std::string name; }; std::map players; + std::map player_ordering; // From id to position. + + struct Formation { + int formation_id; + std::string name; + }; + std::map formations; struct Event { int event_id; uint64_t t; std::optional player_id; + std::optional formation_id; std::string type; }; std::vector events; sqlite3 *db; + int match_id; void load_data(); };