summaryrefslogtreecommitdiff
path: root/libs
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2014-05-27 16:27:20 +0200
committerRobin Gareus <robin@gareus.org>2014-05-27 16:37:01 +0200
commit99c953514bd13a025066f73e179c160cc5145e1b (patch)
tree79a4f98c39edc126d1ad11fb5178ccae7acecbaf /libs
parentcadf07e362684fc74e5541181d451600767e928d (diff)
implement Curve in/outside fill
Diffstat (limited to 'libs')
-rw-r--r--libs/canvas/canvas/curve.h8
-rw-r--r--libs/canvas/curve.cc59
2 files changed, 62 insertions, 5 deletions
diff --git a/libs/canvas/canvas/curve.h b/libs/canvas/canvas/curve.h
index 1fe21c3307..e6decf8455 100644
--- a/libs/canvas/canvas/curve.h
+++ b/libs/canvas/canvas/curve.h
@@ -35,6 +35,12 @@ public:
CatmullRomUniform,
CatmullRomCentripetal,
};
+
+ enum CurveFill {
+ None,
+ Inside,
+ Outside,
+ };
void compute_bounding_box () const;
void render (Rect const & area, Cairo::RefPtr<Cairo::Context>) const;
@@ -43,12 +49,14 @@ public:
void set_points_per_segment (uint32_t n);
bool covers (Duple const &) const;
+ void set_fill_mode (CurveFill cf) { curve_fill = cf; }
private:
Points samples;
Points::size_type n_samples;
uint32_t points_per_segment;
SplineType curve_type;
+ CurveFill curve_fill;
void interpolate ();
diff --git a/libs/canvas/curve.cc b/libs/canvas/curve.cc
index 66fcd2bfe3..7a45ca90bf 100644
--- a/libs/canvas/curve.cc
+++ b/libs/canvas/curve.cc
@@ -34,6 +34,7 @@ Curve::Curve (Group* parent)
, n_samples (0)
, points_per_segment (16)
, curve_type (CatmullRomCentripetal)
+ , curve_fill (None)
{
}
@@ -305,7 +306,32 @@ Curve::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) const
window_space = item_to_window (_points.back());
context->line_to (window_space.x, window_space.y);
- context->stroke ();
+
+ switch (curve_fill) {
+ case None:
+ context->stroke();
+ break;
+ case Inside:
+ context->stroke_preserve ();
+ window_space = item_to_window (Duple(_points.back().x, draw.height()));
+ context->line_to (window_space.x, window_space.y);
+ window_space = item_to_window (Duple(_points.front().x, draw.height()));
+ context->line_to (window_space.x, window_space.y);
+ context->close_path();
+ setup_fill_context(context);
+ context->fill ();
+ break;
+ case Outside:
+ context->stroke_preserve ();
+ window_space = item_to_window (Duple(_points.back().x, 0.0));
+ context->line_to (window_space.x, window_space.y);
+ window_space = item_to_window (Duple(_points.front().x, 0.0));
+ context->line_to (window_space.x, window_space.y);
+ context->close_path();
+ setup_fill_context(context);
+ context->fill ();
+ break;
+ }
} else {
@@ -362,14 +388,37 @@ Curve::render (Rect const & area, Cairo::RefPtr<Cairo::Context> context) const
context->line_to (window_space.x, window_space.y);
}
- context->stroke ();
+ switch (curve_fill) {
+ case None:
+ context->stroke();
+ break;
+ case Inside:
+ context->stroke_preserve ();
+ window_space = item_to_window (Duple (samples[right-1].x, draw.height()));
+ context->line_to (window_space.x, window_space.y);
+ window_space = item_to_window (Duple (samples[left].x, draw.height()));
+ context->line_to (window_space.x, window_space.y);
+ context->close_path();
+ setup_fill_context(context);
+ context->fill ();
+ break;
+ case Outside:
+ context->stroke_preserve ();
+ window_space = item_to_window (Duple (samples[right-1].x, 0.0));
+ context->line_to (window_space.x, window_space.y);
+ window_space = item_to_window (Duple (samples[left].x, 0.0));
+ context->line_to (window_space.x, window_space.y);
+ context->close_path();
+ setup_fill_context(context);
+ context->fill ();
+ break;
+ }
context->restore ();
}
-#if 1
+#if 0
/* add points */
-
- setup_fill_context (context);
+ setup_outline_context (context);
for (Points::const_iterator p = _points.begin(); p != _points.end(); ++p) {
Duple window_space (item_to_window (*p));
context->arc (window_space.x, window_space.y, 5.0, 0.0, 2 * M_PI);