summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMichael R Sweet <michael.r.sweet@gmail.com>2004-04-10 00:37:03 +0000
committerMichael R Sweet <michael.r.sweet@gmail.com>2004-04-10 00:37:03 +0000
commit616c919d3724b5ae142299de49e9706246ab0db7 (patch)
treef6c80a2e9b7650bcee4c59995e1799f4c47ca4c9 /src
parent1a71339155a6c74808e4dc6e6ef9d8b59d1d85dc (diff)
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
Diffstat (limited to 'src')
-rw-r--r--src/Fl_Scroll.cxx60
1 files changed, 30 insertions, 30 deletions
diff --git a/src/Fl_Scroll.cxx b/src/Fl_Scroll.cxx
index 7508a980a..d60160674 100644
--- a/src/Fl_Scroll.cxx
+++ b/src/Fl_Scroll.cxx
@@ -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).
//
@@ -24,6 +24,7 @@
//
#include <FL/Fl.H>
+#include <FL/Fl_Image.H>
#include <FL/Fl_Scroll.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) {
fl_clip(X,Y,W,H);
Fl_Scroll* s = (Fl_Scroll*)v;
- // erase background if there is a boxtype:
- if (s->box()) {
- fl_color(s->color());
- fl_rectf(X,Y,W,H);
+ // erase background as needed...
+ switch (s->box()) {
+ case FL_NO_BOX :
+ 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();
- int R = X; int B = Y; // track bottom & right edge of all children
for (int i=s->children()-2; i--;) {
Fl_Widget& o = **a++;
- int NR, NB;
s->draw_child(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();
}
@@ -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 $".
//