This container widget lets you maneuver around a set of widgets much larger than your window. If the child widgets are larger than the size of this object then scrollbars will appear so that you can scroll over to them:
If all the child widgets are packed together into a solid rectangle then you want to set box() to FL_NO_BOX or one of the _FRAME types. This will result in the best output. However, if the child widgets are a sparse arrangment you must set box() to a real _BOX type. This can result in some blinking during redrawing, but that can be solved by using an Fl_Double_Window.
This widget can also be used to pan around a single child widget "canvas". This child widget should be of your own class, with a draw() method that draws the contents. The scrolling is done by changing the x() and y() of the widget, so this child must use the x() and y() to position it's drawing. To speed up drawing it should test fl_clip().
Another very useful child is a single Fl_Pack, which is itself a group that packs it's children together and changes size to surround them. Filling the Fl_Pack with Fl_Tab groups (and then putting normal widgets inside those) gives you a very powerful scrolling list of individually-openable panels.
Fluid lets you create these, but you can only lay out objects that fit inside the Fl_Scroll without scrolling. Be sure to leave space for the scrollbars, as Fluid won't show these either.
You cannot use Fl_Window as a child of this, the clipping is not conveyed to them when they draw, and they will draw over the scrollbars and neighboring objects.
Fl_Scroll::Fl_Scroll(int x,int y,int w,int h, const char * = 0);
void Fl_Widget::type(int);
0
- No scrollbars
Fl_Scroll::HORIZONTAL
- Only a horizontal scrollbar.
Fl_Scroll::VERTICAL
- Only a vertical scrollbar.
Fl_Scroll::BOTH
- The default is both scrollbars.
Fl_Scroll::HORIZONTAL_ALWAYS
- Horizontal scrollbar
always on, vertical always off.
Fl_Scroll::VERTICAL_ALWAYS
- Vertical scrollbar always on,
horizontal always off.
Fl_Scroll::BOTH_ALWAYS
- Both always on.
void Fl_Scroll::scrollbar.align(int);
Fl_Scrollbar& Fl_Scroll::scrollbar;
Fl_Scrollbar& Fl_Scroll::hscrollbar;
int Fl_Scroll::xposition() const;
int Fl_Scroll::yposition() const;
void Fl_Scroll::position(int w, int h);