Fix light/radio/check button drawing to use a consistent size and
offset. git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@1960 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
parent
b31ff32ee9
commit
ca09c66686
2
CHANGES
2
CHANGES
@ -1,5 +1,7 @@
|
|||||||
CHANGES IN FLTK 1.1.0b11
|
CHANGES IN FLTK 1.1.0b11
|
||||||
|
|
||||||
|
- Fixed some drawing problems with Fl_Light_Button and
|
||||||
|
its subclasses.
|
||||||
- Fixed a minor event propagation bug in Fl_Group that
|
- Fixed a minor event propagation bug in Fl_Group that
|
||||||
caused mousewheel events to be passed to scrollbars
|
caused mousewheel events to be passed to scrollbars
|
||||||
that were not visible.
|
that were not visible.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
//
|
//
|
||||||
// "$Id: Fl_Light_Button.cxx,v 1.4.2.3.2.10 2002/01/01 15:11:30 easysw Exp $"
|
// "$Id: Fl_Light_Button.cxx,v 1.4.2.3.2.11 2002/02/15 17:30:29 easysw Exp $"
|
||||||
//
|
//
|
||||||
// Lighted button widget for the Fast Light Tool Kit (FLTK).
|
// Lighted button widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
@ -39,15 +39,11 @@ void Fl_Light_Button::draw() {
|
|||||||
Fl_Color col = value() ? (active_r() ? selection_color() :
|
Fl_Color col = value() ? (active_r() ? selection_color() :
|
||||||
fl_inactive(selection_color())) : color();
|
fl_inactive(selection_color())) : color();
|
||||||
int W;
|
int W;
|
||||||
int d;
|
int dx, dy;
|
||||||
|
|
||||||
if (w() < h()) {
|
W = labelsize();
|
||||||
d = (w() - labelsize() + 1) / 2;
|
dx = Fl::box_dx(box()) + 2;
|
||||||
W = w() - 2 * d;
|
dy = (h() - W) / 2;
|
||||||
} else {
|
|
||||||
d = (h() - labelsize() + 1) / 2;
|
|
||||||
W = h() - 2 * d;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (down_box()) {
|
if (down_box()) {
|
||||||
// draw other down_box() styles:
|
// draw other down_box() styles:
|
||||||
@ -57,47 +53,49 @@ void Fl_Light_Button::draw() {
|
|||||||
case _FL_PLASTIC_DOWN_BOX :
|
case _FL_PLASTIC_DOWN_BOX :
|
||||||
case _FL_PLASTIC_UP_BOX :
|
case _FL_PLASTIC_UP_BOX :
|
||||||
// Check box...
|
// Check box...
|
||||||
draw_box(down_box(), x()+d, y()+d, W, W, FL_WHITE);
|
draw_box(down_box(), x()+dx, y()+dy, W, W, FL_WHITE);
|
||||||
if (value()) {
|
if (value()) {
|
||||||
fl_color(col);
|
fl_color(col);
|
||||||
fl_line_style(FL_SOLID, 2);
|
fl_line_style(FL_SOLID, 2);
|
||||||
fl_line(x() + d + W - 3, y() + d + 3,
|
fl_line(x() + dx + W - 3, y() + dy + 3,
|
||||||
x() + d + W / 2 - 1, y() + d + W - 4,
|
x() + dx + W / 2 - 1, y() + dy + W - 4,
|
||||||
x() + d + 3, y() + d + W / 2);
|
x() + dx + 3, y() + dy + W / 2);
|
||||||
fl_line_style(FL_SOLID);
|
fl_line_style(FL_SOLID);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case _FL_ROUND_DOWN_BOX :
|
case _FL_ROUND_DOWN_BOX :
|
||||||
case _FL_ROUND_UP_BOX :
|
case _FL_ROUND_UP_BOX :
|
||||||
// Radio button...
|
// Radio button...
|
||||||
draw_box(down_box(), x()+d, y()+d+1, W, W, FL_WHITE);
|
draw_box(down_box(), x()+dx, y()+dy+1, W, W, FL_WHITE);
|
||||||
if (value()) {
|
if (value()) {
|
||||||
fl_color(col);
|
fl_color(col);
|
||||||
int tW = W - Fl::box_dw(down_box()) - 3;
|
int tW = W - Fl::box_dw(down_box()) - 3;
|
||||||
int td = d + Fl::box_dx(down_box()) + 1;
|
int tdx = dx + Fl::box_dx(down_box()) + 1;
|
||||||
|
int tdy = dy + Fl::box_dy(down_box()) + 1;
|
||||||
|
|
||||||
if (tW > 4) {
|
if (tW > 4) {
|
||||||
fl_pie(x() + td, y() + td, tW, tW + 1, 0.0, 360.0);
|
fl_pie(x() + tdx, y() + tdy, tW, tW + 1, 0.0, 360.0);
|
||||||
} else {
|
} else {
|
||||||
// Small circles don't draw well with some X servers...
|
// Small circles don't draw well with some X servers...
|
||||||
fl_rectf(x() + td + 1, y() + td, 2, 4);
|
fl_rectf(x() + tdx + 1, y() + tdy, 2, 4);
|
||||||
fl_rectf(x() + td, y() + td + 1, 4, 2);
|
fl_rectf(x() + tdx, y() + tdy + 1, 4, 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default :
|
default :
|
||||||
draw_box(down_box(), x()+d, y()+d, W, W, col);
|
draw_box(down_box(), x()+dx, y()+dy, W, W, col);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// if down_box() is zero, draw light button style:
|
// if down_box() is zero, draw light button style:
|
||||||
int hh = h()-2*d - 2;
|
int hh = h()-2*dy - 2;
|
||||||
int ww = hh/2+1;
|
int ww = W/2+1;
|
||||||
int xx = d;
|
int xx = dx;
|
||||||
if (w()<ww+2*xx) xx = (w()-ww)/2;
|
if (w()<ww+2*xx) xx = (w()-ww)/2;
|
||||||
draw_box(FL_THIN_DOWN_BOX, x()+xx, y()+d+1, ww, hh, col);
|
draw_box(FL_THIN_DOWN_BOX, x()+xx, y()+dy+1, ww, hh, col);
|
||||||
d = (ww + 2 * d - W) / 2;
|
dx = (ww + 2 * dx - W) / 2;
|
||||||
}
|
}
|
||||||
draw_label(x()+W+2*d, y(), w()-W-2*d, h());
|
draw_label(x()+W+2*dx, y(), w()-W-2*dx, h());
|
||||||
if (Fl::focus() == this) draw_focus();
|
if (Fl::focus() == this) draw_focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -118,5 +116,5 @@ Fl_Light_Button::Fl_Light_Button(int x, int y, int w, int h, const char* l)
|
|||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// End of "$Id: Fl_Light_Button.cxx,v 1.4.2.3.2.10 2002/01/01 15:11:30 easysw Exp $".
|
// End of "$Id: Fl_Light_Button.cxx,v 1.4.2.3.2.11 2002/02/15 17:30:29 easysw Exp $".
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user