| @@ -0,0 +1,104 @@ | |||||
| /*******************************************************************************/ | |||||
| /* Copyright (C) 2008 Jonathan Moore Liles */ | |||||
| /* */ | |||||
| /* This program is free software; you can redistribute it and/or modify it */ | |||||
| /* under the terms of the GNU General Public License as published by the */ | |||||
| /* Free Software Foundation; either version 2 of the License, or (at your */ | |||||
| /* option) any later version. */ | |||||
| /* */ | |||||
| /* This program is distributed in the hope that it will be useful, but WITHOUT */ | |||||
| /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */ | |||||
| /* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for */ | |||||
| /* more details. */ | |||||
| /* */ | |||||
| /* You should have received a copy of the GNU General Public License along */ | |||||
| /* with This program; see the file COPYING. If not,write to the Free Software */ | |||||
| /* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ | |||||
| /*******************************************************************************/ | |||||
| #include "Fl_Arc_Dial.H" | |||||
| #include <Fl/fl_draw.H> | |||||
| #include <Fl/Fl.H> | |||||
| int | |||||
| Fl_Arc_Dial::handle ( int m ) | |||||
| { | |||||
| /* Fl_Dial and friends should really handle mousewheel, but they don't in FTLK1 */ | |||||
| switch ( m ) | |||||
| { | |||||
| case FL_MOUSEWHEEL: | |||||
| { | |||||
| if ( this != Fl::belowmouse() ) | |||||
| return 0; | |||||
| int d = Fl::event_dy(); | |||||
| double v = increment( value(), d ); | |||||
| if ( v < minimum() ) | |||||
| v = minimum(); | |||||
| else if ( v > maximum() ) | |||||
| v = maximum(); | |||||
| value( v ); | |||||
| return 1; | |||||
| } | |||||
| } | |||||
| return Fl_Dial::handle( m ); | |||||
| } | |||||
| void | |||||
| Fl_Arc_Dial::draw ( void ) | |||||
| { | |||||
| int X = x(); | |||||
| int Y = y(); | |||||
| int W = w(); | |||||
| int H = h(); | |||||
| draw_box(); | |||||
| draw_label(); | |||||
| X += Fl::box_dx(box()); | |||||
| Y += Fl::box_dy(box()); | |||||
| W -= Fl::box_dw(box()); | |||||
| H -= Fl::box_dh(box()); | |||||
| double angle = ( angle2() - angle1() ) * ( value() - minimum()) / ( maximum() - minimum() ) + angle1(); | |||||
| fl_line_style( FL_SOLID, W / 6 ); | |||||
| X += W / 8; | |||||
| Y += H / 8; | |||||
| W -= W / 4; | |||||
| H -= H / 4; | |||||
| if ( box() == FL_NO_BOX ) | |||||
| { | |||||
| /* draw backgrond arc */ | |||||
| fl_color( fl_color_average( FL_BLACK, selection_color(), 0.80f ) ); | |||||
| fl_arc( X, Y, W, H, 270 - angle1(), 270 - angle2() ); | |||||
| } | |||||
| fl_color( selection_color() ); | |||||
| if ( type() == FL_FILL_DIAL ) | |||||
| fl_arc( X, Y, W, H, 270 - angle1(), 270 - angle ); | |||||
| else | |||||
| { | |||||
| const int d = 6; | |||||
| /* account for edge conditions */ | |||||
| angle = angle < angle1() + d ? angle1() + d : angle; | |||||
| angle = angle > angle2() - d ? angle2() - d : angle; | |||||
| fl_arc( X, Y, W, H, 270 - (angle - d), 270 - (angle + d) ); | |||||
| fl_line_style( FL_SOLID, 0 ); | |||||
| } | |||||
| } | |||||