summaryrefslogtreecommitdiff
path: root/libs/canvas/lookup_table.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2013-11-04 11:56:10 -0500
committerPaul Davis <paul@linuxaudiosystems.com>2013-11-04 11:56:10 -0500
commit6473cc7cb431abe71721341c550130e61cf64aa1 (patch)
tree1f0a2c5783e883d817d4667269abd73d0fdb5afb /libs/canvas/lookup_table.cc
parent08b485db75082a21c3814b0a4517f2b2fc994b77 (diff)
drop use of bounding box to determine whether an item covers a point; add Item::covers(Duple const&)
Default implementation for Item still uses bounding box, but specializations for Arc (Circle), Polygon, Line and PolyLine have been added
Diffstat (limited to 'libs/canvas/lookup_table.cc')
-rw-r--r--libs/canvas/lookup_table.cc10
1 files changed, 3 insertions, 7 deletions
diff --git a/libs/canvas/lookup_table.cc b/libs/canvas/lookup_table.cc
index 38b8be4afb..0cae7c9c4f 100644
--- a/libs/canvas/lookup_table.cc
+++ b/libs/canvas/lookup_table.cc
@@ -62,13 +62,9 @@ DumbLookupTable::items_at_point (Duple point) const
if (!(*i)->visible()) {
continue;
}
-
- boost::optional<Rect> item_bbox = (*i)->bounding_box ();
-
- if (item_bbox) {
- if ((*i)->item_to_canvas (item_bbox.get ()).contains (point)) {
- vitems.push_back (*i);
- }
+
+ if ((*i)->covers (point)) {
+ vitems.push_back (*i);
}
}