mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 23:20:05 +00:00
Move MarkerManager to using an ID system for markers, instead of index
This commit is contained in:
parent
236d7c1e35
commit
7a070b3e7f
8 changed files with 233 additions and 74 deletions
|
|
@ -12,6 +12,7 @@ namespace qt
|
|||
namespace manager
|
||||
{
|
||||
|
||||
typedef void MarkerForEachFunc(const types::MarkerInfo&);
|
||||
class MarkerManager : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
|
|
@ -21,12 +22,15 @@ public:
|
|||
~MarkerManager();
|
||||
|
||||
size_t marker_count();
|
||||
std::optional<types::MarkerInfo> get_marker(size_t index);
|
||||
void set_marker(size_t index, const types::MarkerInfo& marker);
|
||||
std::optional<types::MarkerInfo> get_marker(types::MarkerId id);
|
||||
std::optional<size_t> get_index(types::MarkerId id);
|
||||
void set_marker(types::MarkerId id, const types::MarkerInfo& marker);
|
||||
void add_marker(const types::MarkerInfo& marker);
|
||||
void remove_marker(size_t index);
|
||||
void remove_marker(types::MarkerId id);
|
||||
void move_marker(size_t from, size_t to);
|
||||
|
||||
void for_each(std::function<MarkerForEachFunc> func);
|
||||
|
||||
// Only use for testing
|
||||
void set_marker_settings_path(const std::string& path);
|
||||
|
||||
|
|
@ -35,9 +39,9 @@ public:
|
|||
signals:
|
||||
void MarkersInitialized(size_t count);
|
||||
void MarkersUpdated();
|
||||
void MarkerChanged(size_t index);
|
||||
void MarkerAdded();
|
||||
void MarkerRemoved(size_t index);
|
||||
void MarkerChanged(types::MarkerId id);
|
||||
void MarkerAdded(types::MarkerId id);
|
||||
void MarkerRemoved(types::MarkerId id);
|
||||
|
||||
private:
|
||||
class Impl;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue