Fl_Scroll now shows the background image when a framed box type
is used and the Fl_Scroll is a direct decendent of a window (STR #205) git-svn-id: file:///fltk/svn/fltk/branches/branch-1.1@3380 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
parent
1a71339155
commit
616c919d37
3
CHANGES
3
CHANGES
@ -2,6 +2,9 @@ CHANGES IN FLTK 1.1.5rc1
|
|||||||
|
|
||||||
- Documentation updates (STR #245, STR #250, STR #277,
|
- Documentation updates (STR #245, STR #250, STR #277,
|
||||||
STR #281, STR #328, STR #338)
|
STR #281, STR #328, STR #338)
|
||||||
|
- Fl_Scroll now shows the background image when a framed
|
||||||
|
box type is used and the Fl_Scroll is a direct
|
||||||
|
decendent of a window (STR #205)
|
||||||
- Added a new_directory_tooltip string pointer to allow
|
- Added a new_directory_tooltip string pointer to allow
|
||||||
localization of the file chooser's new directory
|
localization of the file chooser's new directory
|
||||||
button (STR #340)
|
button (STR #340)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
//
|
//
|
||||||
// "$Id: Fl_Scroll.cxx,v 1.7.2.6.2.7 2004/04/06 02:47:26 easysw Exp $"
|
// "$Id: Fl_Scroll.cxx,v 1.7.2.6.2.8 2004/04/10 00:37:03 easysw Exp $"
|
||||||
//
|
//
|
||||||
// Scroll widget for the Fast Light Tool Kit (FLTK).
|
// Scroll widget for the Fast Light Tool Kit (FLTK).
|
||||||
//
|
//
|
||||||
@ -24,6 +24,7 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#include <FL/Fl.H>
|
#include <FL/Fl.H>
|
||||||
|
#include <FL/Fl_Image.H>
|
||||||
#include <FL/Fl_Scroll.H>
|
#include <FL/Fl_Scroll.H>
|
||||||
#include <FL/fl_draw.H>
|
#include <FL/fl_draw.H>
|
||||||
|
|
||||||
@ -52,40 +53,39 @@ void Fl_Scroll::fix_scrollbar_order() {
|
|||||||
void Fl_Scroll::draw_clip(void* v,int X, int Y, int W, int H) {
|
void Fl_Scroll::draw_clip(void* v,int X, int Y, int W, int H) {
|
||||||
fl_clip(X,Y,W,H);
|
fl_clip(X,Y,W,H);
|
||||||
Fl_Scroll* s = (Fl_Scroll*)v;
|
Fl_Scroll* s = (Fl_Scroll*)v;
|
||||||
// erase background if there is a boxtype:
|
// erase background as needed...
|
||||||
if (s->box()) {
|
switch (s->box()) {
|
||||||
fl_color(s->color());
|
case FL_NO_BOX :
|
||||||
fl_rectf(X,Y,W,H);
|
case FL_UP_FRAME :
|
||||||
|
case FL_DOWN_FRAME :
|
||||||
|
case FL_THIN_UP_FRAME :
|
||||||
|
case FL_THIN_DOWN_FRAME :
|
||||||
|
case FL_ENGRAVED_FRAME :
|
||||||
|
case FL_EMBOSSED_FRAME :
|
||||||
|
case FL_BORDER_FRAME :
|
||||||
|
case _FL_SHADOW_FRAME :
|
||||||
|
case _FL_ROUNDED_FRAME :
|
||||||
|
case _FL_OVAL_FRAME :
|
||||||
|
case _FL_PLASTIC_UP_FRAME :
|
||||||
|
case _FL_PLASTIC_DOWN_FRAME :
|
||||||
|
if (s->parent() == (Fl_Group *)s->window() && Fl::scheme_bg_) {
|
||||||
|
Fl::scheme_bg_->draw(X-(X%Fl::scheme_bg_->w()),
|
||||||
|
Y-(Y%Fl::scheme_bg_->h()),
|
||||||
|
W+Fl::scheme_bg_->w(),
|
||||||
|
H+Fl::scheme_bg_->h());
|
||||||
|
break;
|
||||||
|
} else if (s->box() == FL_NO_BOX) break;
|
||||||
|
|
||||||
|
default :
|
||||||
|
fl_color(s->color());
|
||||||
|
fl_rectf(X,Y,W,H);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
Fl_Widget*const* a = s->array();
|
Fl_Widget*const* a = s->array();
|
||||||
int R = X; int B = Y; // track bottom & right edge of all children
|
|
||||||
for (int i=s->children()-2; i--;) {
|
for (int i=s->children()-2; i--;) {
|
||||||
Fl_Widget& o = **a++;
|
Fl_Widget& o = **a++;
|
||||||
int NR, NB;
|
|
||||||
s->draw_child(o);
|
s->draw_child(o);
|
||||||
s->draw_outside_label(o);
|
s->draw_outside_label(o);
|
||||||
NR = o.x()+o.w();
|
|
||||||
NB = o.y()+o.h();
|
|
||||||
if ((o.align() & (FL_ALIGN_BOTTOM | FL_ALIGN_RIGHT)) &&
|
|
||||||
!(o.align() & FL_ALIGN_INSIDE)) {
|
|
||||||
int LW = 0, LH = 0;
|
|
||||||
o.measure_label(LW, LH);
|
|
||||||
if (o.align() & FL_ALIGN_BOTTOM) NB += LH;
|
|
||||||
else NR += LW;
|
|
||||||
}
|
|
||||||
if (NR > R) R = NR;
|
|
||||||
if (NB > B) B = NB;
|
|
||||||
}
|
|
||||||
// fill any area to right & bottom of widgets:
|
|
||||||
if (s->box()) {
|
|
||||||
if (R < X+W && B > Y) {
|
|
||||||
fl_color(s->color());
|
|
||||||
fl_rectf(R,Y,X+W-R,B-Y);
|
|
||||||
}
|
|
||||||
if (B < Y+H) {
|
|
||||||
fl_color(s->color());
|
|
||||||
fl_rectf(X,B,W,Y+H-B);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
fl_pop_clip();
|
fl_pop_clip();
|
||||||
}
|
}
|
||||||
@ -271,5 +271,5 @@ int Fl_Scroll::handle(int event) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// End of "$Id: Fl_Scroll.cxx,v 1.7.2.6.2.7 2004/04/06 02:47:26 easysw Exp $".
|
// End of "$Id: Fl_Scroll.cxx,v 1.7.2.6.2.8 2004/04/10 00:37:03 easysw Exp $".
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user