X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=libs%2Fcanvas%2Fcanvas%2Flookup_table.h;h=2877f7a727b194121231a5d075a5bb55bf74bc35;hb=fcad5a337fd4a7119fdd213ddb1df8eeb6a42bf4;hp=4ab69b6167f212e60c391861048023625d656939;hpb=580520b12f90251e38d94a1a5d6a199b76142b0b;p=ardour.git diff --git a/libs/canvas/canvas/lookup_table.h b/libs/canvas/canvas/lookup_table.h index 4ab69b6167..2877f7a727 100644 --- a/libs/canvas/canvas/lookup_table.h +++ b/libs/canvas/canvas/lookup_table.h @@ -22,6 +22,8 @@ #include #include + +#include "canvas/visibility.h" #include "canvas/types.h" class OptimizingLookupTableTest; @@ -29,55 +31,57 @@ class OptimizingLookupTableTest; namespace ArdourCanvas { class Item; -class Group; -class LookupTable +class LIBCANVAS_API LookupTable { public: - LookupTable (Group const &); - virtual ~LookupTable (); + LookupTable (Item const &); + virtual ~LookupTable (); - virtual std::vector get (Rect const &) = 0; - virtual std::vector items_at_point (Duple) const = 0; + virtual std::vector get (Rect const &) = 0; + virtual std::vector items_at_point (Duple const &) const = 0; + virtual bool has_item_at_point (Duple const & point) const = 0; protected: - - Group const & _group; + + Item const & _item; }; -class DumbLookupTable : public LookupTable +class LIBCANVAS_API DumbLookupTable : public LookupTable { public: - DumbLookupTable (Group const &); + DumbLookupTable (Item const &); - std::vector get (Rect const &); - std::vector items_at_point (Duple) const; + std::vector get (Rect const &); + std::vector items_at_point (Duple const &) const; + bool has_item_at_point (Duple const & point) const; }; -class OptimizingLookupTable : public LookupTable +class LIBCANVAS_API OptimizingLookupTable : public LookupTable { public: - OptimizingLookupTable (Group const &, int); - ~OptimizingLookupTable (); - std::vector get (Rect const &); - std::vector items_at_point (Duple) const; + OptimizingLookupTable (Item const &, int); + ~OptimizingLookupTable (); + std::vector get (Rect const &); + std::vector items_at_point (Duple const &) const; + bool has_item_at_point (Duple const & point) const; - static int default_items_per_cell; + static int default_items_per_cell; -private: + private: - void area_to_indices (Rect const &, int &, int &, int &, int &) const; - void point_to_indices (Duple, int &, int &) const; + void area_to_indices (Rect const &, int &, int &, int &, int &) const; + void point_to_indices (Duple, int &, int &) const; - friend class ::OptimizingLookupTableTest; + friend class ::OptimizingLookupTableTest; - typedef std::vector Cell; - int _items_per_cell; - int _dimension; - Duple _cell_size; - Duple _offset; - Cell** _cells; - bool _added; + typedef std::vector Cell; + int _items_per_cell; + int _dimension; + Duple _cell_size; + Duple _offset; + Cell** _cells; + bool _added; }; }