X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fcanvas%2Fpolygon.cc;h=aa16a6017844c2cc6f3ba816eabac5b8ecd5f08d;hb=542d1ce01c6629362edd8b14eee9523941a3c128;hp=2e818236160d77335aec155aae1245d3de4a2a6c;hpb=25a6296f865620d5013cd634e693f7179e7edc84;p=ardour.git diff --git a/libs/canvas/polygon.cc b/libs/canvas/polygon.cc index 2e81823616..aa16a60178 100644 --- a/libs/canvas/polygon.cc +++ b/libs/canvas/polygon.cc @@ -21,15 +21,20 @@ using namespace ArdourCanvas; -Polygon::Polygon (Group* parent) - : Item (parent) - , PolyItem (parent) - , Fill (parent) +Polygon::Polygon (Canvas* c) + : PolyItem (c) , multiple (0) , constant (0) , cached_size (0) { +} +Polygon::Polygon (Item* parent) + : PolyItem (parent) + , multiple (0) + , constant (0) + , cached_size (0) +{ } Polygon::~Polygon () @@ -41,8 +46,7 @@ Polygon::~Polygon () void Polygon::render (Rect const & area, Cairo::RefPtr context) const { - if (_outline) { - setup_outline_context (context); + if (_outline || _fill) { render_path (area, context); if (!_points.empty ()) { @@ -51,7 +55,15 @@ Polygon::render (Rect const & area, Cairo::RefPtr context) const context->move_to (p.x, p.y); } - context->stroke_preserve (); + } + + if (_outline) { + setup_outline_context (context); + if (_fill) { + context->stroke_preserve (); + } else { + context->stroke (); + } } if (_fill) { @@ -96,7 +108,7 @@ Polygon::cache_shape_computation () const bool Polygon::covers (Duple const & point) const { - Duple p = canvas_to_item (point); + Duple p = window_to_item (point); Points::size_type npoints = _points.size();