2 // "$Id: curve.cxx 7978 2010-12-08 14:00:35Z AlbrechtS $"
4 // Curve test program for the Fast Light Tool Kit (FLTK).
6 // Copyright 1998-2010 by Bill Spitzak and others.
8 // This library is free software; you can redistribute it and/or
9 // modify it under the terms of the GNU Library General Public
10 // License as published by the Free Software Foundation; either
11 // version 2 of the License, or (at your option) any later version.
13 // This library is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 // Library General Public License for more details.
18 // You should have received a copy of the GNU Library General Public
19 // License along with this library; if not, write to the Free Software
20 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
23 // Please report all bugs and problems on the following page:
25 // http://www.fltk.org/str.php
29 #include <FL/Fl_Double_Window.H>
30 #include <FL/Fl_Hor_Value_Slider.H>
31 #include <FL/fl_draw.H>
32 #include <FL/Fl_Toggle_Button.H>
35 20,20, 50,200, 100,20, 200,200, 0};
36 const char* name
[9] = {
37 "X0", "Y0", "X1", "Y1", "X2", "Y2", "X3", "Y3", "rotate"};
41 class Drawing
: public Fl_Widget
{
43 fl_push_clip(x(),y(),w(),h());
45 fl_rectf(x(),y(),w(),h());
48 fl_translate(x()+w()/2.0, y()+h()/2.0);
50 fl_translate(-(x()+w()/2.0), -(y()+h()/2.0));
52 fl_translate(x(),y());
55 fl_begin_complex_polygon();
56 fl_curve(args
[0],args
[1],args
[2],args
[3],args
[4],args
[5],args
[6],args
[7]);
57 fl_end_complex_polygon();
61 fl_vertex(args
[0],args
[1]);
62 fl_vertex(args
[2],args
[3]);
63 fl_vertex(args
[4],args
[5]);
64 fl_vertex(args
[6],args
[7]);
66 fl_color(points
? FL_WHITE
: FL_RED
);
67 points
? fl_begin_points() : fl_begin_line();
68 fl_curve(args
[0],args
[1],args
[2],args
[3],args
[4],args
[5],args
[6],args
[7]);
69 points
? fl_end_points() : fl_end_line();
74 Drawing(int X
,int Y
,int W
,int H
) : Fl_Widget(X
,Y
,W
,H
) {}
79 void points_cb(Fl_Widget
* o
, void*) {
80 points
= ((Fl_Toggle_Button
*)o
)->value();
84 void slider_cb(Fl_Widget
* o
, void* v
) {
85 Fl_Slider
* s
= (Fl_Slider
*)o
;
86 args
[fl_intptr_t(v
)] = s
->value();
90 int main(int argc
, char** argv
) {
91 Fl_Double_Window
window(300,555);
92 Drawing
drawing(10,10,280,280);
96 for (int n
= 0; n
<9; n
++) {
97 Fl_Slider
* s
= new Fl_Hor_Value_Slider(50,y
,240,25,name
[n
]); y
+= 25;
98 s
->minimum(0); s
->maximum(280);
99 if (n
== 8) s
->maximum(360);
102 s
->align(FL_ALIGN_LEFT
);
103 s
->callback(slider_cb
, (void*)n
);
105 Fl_Toggle_Button
but(50,y
,50,25,"points");
106 but
.callback(points_cb
);
109 window
.show(argc
,argv
);
114 // End of "$Id: curve.cxx 7978 2010-12-08 14:00:35Z AlbrechtS $".