use a centripetal catmull-rom curve to smooth ArdourCanvas::Curve
[ardour.git] / libs / canvas / canvas / curve.h
1 /*
2     Copyright (C) 2013 Paul Davis
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17 */
18
19 #ifndef __CANVAS_CURVE_H__
20 #define __CANVAS_CURVE_H__
21
22 #include "canvas/visibility.h"
23
24 #include "canvas/poly_item.h"
25 #include "canvas/fill.h"
26
27 namespace ArdourCanvas {
28
29 class LIBCANVAS_API Curve : public PolyItem, public Fill
30 {
31 public:
32     Curve (Group *);
33
34     enum SplineType {
35             CatmullRomUniform,
36             CatmullRomCentripetal,
37     };
38     
39     void compute_bounding_box () const;
40     void render (Rect const & area, Cairo::RefPtr<Cairo::Context>) const;
41     void set (Points const &);
42
43     void set_points_per_segment (uint32_t n);
44
45     bool covers (Duple const &) const;
46
47   private:
48     Points samples;
49     Points::size_type n_samples;
50     uint32_t points_per_segment;
51     SplineType curve_type;
52
53     double map_value (double) const;
54     void interpolate ();
55
56     static void interpolate (const Points& coordinates, uint32_t points_per_segment, SplineType, bool closed, Points& results);
57 };
58         
59 }
60
61 #endif