X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=libs%2Fcanvas%2Fpolygon.cc;h=fdc1061d743dd3c201367f50a740f720ff468251;hb=065c6d813e6aac7fa216121be1b15ab6f1ca2892;hp=2e818236160d77335aec155aae1245d3de4a2a6c;hpb=f4b5f4c72ee60b6f509e307c5bfd164108d1f30b;p=ardour.git diff --git a/libs/canvas/polygon.cc b/libs/canvas/polygon.cc index 2e81823616..fdc1061d74 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,17 +46,24 @@ 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 ()) { /* close path */ Duple p = item_to_window (Duple (_points.front().x, _points.front().y)); - context->move_to (p.x, p.y); + context->line_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();