167d767e0f
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3@6614 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
306 lines
10 KiB
C++
306 lines
10 KiB
C++
//
|
|
// "$Id$"
|
|
//
|
|
// Common browser header file for the Fast Light Tool Kit (FLTK).
|
|
//
|
|
// Copyright 1998-2009 by Bill Spitzak and others.
|
|
//
|
|
// This library is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Library General Public
|
|
// License as published by the Free Software Foundation; either
|
|
// version 2 of the License, or (at your option) any later version.
|
|
//
|
|
// This library 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
|
|
// Library General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Library General Public
|
|
// License along with this library; if not, write to the Free Software
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
// USA.
|
|
//
|
|
// Please report all bugs and problems on the following page:
|
|
//
|
|
// http://www.fltk.org/str.php
|
|
//
|
|
|
|
/* \file
|
|
Fl_Browser_ widget . */
|
|
|
|
// This is the base class for browsers. To be useful it must
|
|
// be subclassed and several virtual functions defined. The
|
|
// Forms-compatable browser and the file chooser's browser are
|
|
// subclassed off of this.
|
|
|
|
// Yes, I know this should be a template...
|
|
|
|
#ifndef Fl_Browser__H
|
|
#define Fl_Browser__H
|
|
|
|
#ifndef Fl_Group_H
|
|
#include "Fl_Group.H"
|
|
#endif
|
|
#include "Fl_Scrollbar.H"
|
|
|
|
#define FL_NORMAL_BROWSER 0 /**< type() of Fl_Browser */
|
|
#define FL_SELECT_BROWSER 1 /**< type() of FL_Select_Browser */
|
|
#define FL_HOLD_BROWSER 2 /**< type() of Fl_Hold_Browser */
|
|
#define FL_MULTI_BROWSER 3 /**< type() of Fl_Multi_Browser */
|
|
|
|
#define FL_SORT_ASC 0 /**< sort browser items in ascending alphabetic order. */
|
|
#define FL_SORT_DESC 1 /**< sort in descending order */
|
|
|
|
/**
|
|
This is the base for browsers. To be useful it must be
|
|
subclassed and several virtual functions defined. The Forms-compatible
|
|
browser and the file chooser's browser are subclassed off of this.
|
|
|
|
This has been designed so that the subclass has complete control
|
|
over the storage of the data, although because next() and
|
|
prev() functions are used to index, it works best as a linked list
|
|
or as a large block of characters in which the line breaks must be
|
|
searched for.
|
|
|
|
A great deal of work has been done so that the "height" of a data
|
|
object does not need to be determined until it is drawn. This is
|
|
useful if actually figuring out the size of an object requires
|
|
accessing image data or doing stat() on a file or doing some
|
|
other slow operation.
|
|
*/
|
|
class FL_EXPORT Fl_Browser_ : public Fl_Group {
|
|
int position_; // where user wants it scrolled to
|
|
int real_position_; // the current vertical scrolling position
|
|
int hposition_; // where user wants it panned to
|
|
int real_hposition_; // the current horizontal scrolling position
|
|
int offset_; // how far down top_ item the real_position is
|
|
int max_width; // widest object seen so far
|
|
uchar has_scrollbar_; // which scrollbars are enabled
|
|
Fl_Font textfont_;
|
|
Fl_Fontsize textsize_;
|
|
unsigned textcolor_;
|
|
void* top_; // which item scrolling position is in
|
|
void* selection_; // which is selected (except for FL_MULTI_BROWSER)
|
|
void *redraw1,*redraw2; // minimal update pointers
|
|
void* max_width_item; // which item has max_width_
|
|
|
|
static int scrollbar_width_;
|
|
|
|
void update_top();
|
|
|
|
protected:
|
|
|
|
// All of the following must be supplied by the subclass:
|
|
/** This method must be provided by the subclass to return the first item in the list. */
|
|
virtual void *item_first() const = 0;
|
|
/** This method must be provided by the subclass to return the item in the list after p. */
|
|
virtual void *item_next(void *) const = 0;
|
|
/** This method must be provided by the subclass to return the item in the list before p. */
|
|
virtual void *item_prev(void *) const = 0;
|
|
/** This method can be provided by the subclass to return the ilast item in the list. */
|
|
virtual void *item_last() const { return 0L; }
|
|
/**
|
|
This method must be provided by the subclass to return the height of the
|
|
item p in pixels. Allow for two additional pixels for the list
|
|
selection box.
|
|
*/
|
|
virtual int item_height(void *) const = 0;
|
|
/**
|
|
This method must be provided by the subclass to return the width of the
|
|
item p in pixels. Allow for two additional pixels for the list
|
|
selection box.
|
|
*/
|
|
virtual int item_width(void *) const = 0;
|
|
virtual int item_quick_height(void *) const ;
|
|
/**
|
|
This method must be provided by the subclass to draw the item
|
|
p in the area indicated by x, y, w,
|
|
and h.
|
|
*/
|
|
virtual void item_draw(void *,int,int,int,int) const = 0;
|
|
/**
|
|
This optional function returns a string that may be used for sorting.
|
|
*/
|
|
virtual const char *item_text(void *item) const { return 0L; }
|
|
/**
|
|
This optional function is required for sorting browser items.
|
|
*/
|
|
virtual void item_swap(void*, void*) { }
|
|
/**
|
|
Return the item a specified index.
|
|
*/
|
|
virtual void *item_at(int) const { return 0L; }
|
|
// you don't have to provide these but it may help speed it up:
|
|
virtual int full_width() const ; // current width of all items
|
|
virtual int full_height() const ; // current height of all items
|
|
virtual int incr_height() const ; // average height of an item
|
|
// These only need to be done by subclass if you want a multi-browser:
|
|
virtual void item_select(void *,int=1);
|
|
virtual int item_selected(void *) const ;
|
|
|
|
// things the subclass may want to call:
|
|
/** Returns the item the appears at the top of the list. */
|
|
void *top() const {return top_;}
|
|
/**
|
|
Returns the item currently selected, or NULL if there is no selection.
|
|
|
|
<P>For multiple selection browsers this call returns the currently focused item,
|
|
even if it is not selected. To find all selected items, call
|
|
|
|
Fl_Multi_Browser::selected() for every item in question.
|
|
*/
|
|
void *selection() const {return selection_;}
|
|
void new_list(); // completely clobber all data, as though list replaced
|
|
void deleting(void *a); // get rid of any pointers to a
|
|
void replacing(void *a,void *b); // change a pointers to b
|
|
void swapping(void *a,void *b); // exchange pointers a and b
|
|
void inserting(void *a,void *b); // insert b near a
|
|
int displayed(void *) const ; // true if this line is visible
|
|
void redraw_line(void *); // minimal update, no change in size
|
|
/** This method will cause the entire list to be redrawn. */
|
|
void redraw_lines() {damage(FL_DAMAGE_SCROLL);} // redraw all of them
|
|
void bbox(int&,int&,int&,int&) const;
|
|
int leftedge() const; // x position after scrollbar & border
|
|
void *find_item(int my); // item under mouse
|
|
|
|
/**
|
|
Draws the contents of the browser within the specified bounding box.
|
|
\todo Find the implementation, if any, and document it there!
|
|
*/
|
|
void draw(int,int,int,int);
|
|
/*
|
|
Handles the specified event, plus 4 extra parameters!
|
|
\todo Find the implementation, if any, and document it there!
|
|
fabien: I guess the answer is there is no implementation (yet?),
|
|
so let's comment out this method that does not exist.
|
|
int handle(int,int,int,int,int);
|
|
*/
|
|
|
|
void draw();
|
|
Fl_Browser_(int,int,int,int,const char * = 0);
|
|
|
|
public:
|
|
|
|
/** Vertical scrollbar. */
|
|
Fl_Scrollbar scrollbar;
|
|
/** Horizontal scrollbar */
|
|
Fl_Scrollbar hscrollbar;
|
|
|
|
int handle(int);
|
|
void resize(int,int,int,int);
|
|
|
|
int select(void *,int=1,int docallbacks=0);
|
|
int select_only(void *,int docallbacks=0);
|
|
int deselect(int docallbacks=0);
|
|
/**
|
|
Gets or sets the vertical scrolling position of the list,
|
|
which is the pixel offset of the list items within the list
|
|
area.
|
|
*/
|
|
int position() const {return position_;}
|
|
/**
|
|
Gets or sets the horizontal scrolling position of the list,
|
|
which is the pixel offset of the list items within the list
|
|
area.
|
|
*/
|
|
int hposition() const {return hposition_;}
|
|
void position(int); // scroll to here
|
|
void hposition(int); // pan to here
|
|
void display(void*); // scroll so this item is shown
|
|
/** See Fl_Browser_::has_scrollbar(uchar) */
|
|
uchar has_scrollbar() const {return has_scrollbar_;}
|
|
/**
|
|
By default you can scroll in both directions, and the scrollbars
|
|
disappear if the data will fit in the widget. has_scrollbar() changes
|
|
this based on the value of h:
|
|
|
|
\li 0 - No scrollbars.
|
|
|
|
\li Fl_Browser_::HORIZONTAL - Only a horizontal scrollbar.
|
|
|
|
\li Fl_Browser_::VERTICAL - Only a vertical scrollbar.
|
|
|
|
\li Fl_Browser_::BOTH - The default is both scrollbars.
|
|
|
|
\li Fl_Browser_::HORIZONTAL_ALWAYS - Horizontal scrollbar always on,
|
|
vertical always off.
|
|
|
|
\li Fl_Browser_::VERTICAL_ALWAYS - Vertical scrollbar always on,
|
|
horizontal always off.
|
|
|
|
\li Fl_Browser_::BOTH_ALWAYS - Both always on.
|
|
*/
|
|
void has_scrollbar(uchar i) {has_scrollbar_ = i;}
|
|
enum { // values for has_scrollbar()
|
|
HORIZONTAL = 1,
|
|
VERTICAL = 2,
|
|
BOTH = 3,
|
|
ALWAYS_ON = 4,
|
|
HORIZONTAL_ALWAYS = 5,
|
|
VERTICAL_ALWAYS = 6,
|
|
BOTH_ALWAYS = 7
|
|
};
|
|
|
|
/**
|
|
Gets the default text font for the lines in the browser.
|
|
*/
|
|
Fl_Font textfont() const {return textfont_;}
|
|
/**
|
|
Sets the default text font to font \p s
|
|
*/
|
|
void textfont(Fl_Font s) {textfont_ = s;}
|
|
|
|
/**
|
|
Gets the default text size for the lines in the browser.
|
|
*/
|
|
Fl_Fontsize textsize() const {return textsize_;}
|
|
/**
|
|
Sets the default text size to size \p s.
|
|
*/
|
|
void textsize(Fl_Fontsize s) {textsize_ = s;}
|
|
|
|
/**
|
|
Gets the default text color for the lines in the browser.
|
|
*/
|
|
Fl_Color textcolor() const {return (Fl_Color)textcolor_;}
|
|
/**
|
|
Sets the default text color to color \p n.
|
|
*/
|
|
void textcolor(unsigned n) {textcolor_ = n;}
|
|
|
|
/**
|
|
Gets the width of any scrollbars that are used.
|
|
*/
|
|
static int scrollbar_width() {return scrollbar_width_;}
|
|
/**
|
|
Sets the width of any scrollbars that are used to \p b.
|
|
*/
|
|
static void scrollbar_width(int b) {scrollbar_width_ = b;}
|
|
|
|
/**
|
|
Moves the vertical scrollbar to the righthand side of the list.
|
|
For back compatibility.
|
|
*/
|
|
void scrollbar_right() {scrollbar.align(FL_ALIGN_RIGHT);}
|
|
/**
|
|
Moves the vertical scrollbar to the lefthand side of the list.
|
|
For back compatibility.
|
|
*/
|
|
void scrollbar_left() {scrollbar.align(FL_ALIGN_LEFT);}
|
|
|
|
/**
|
|
Sort the items in the browser.
|
|
item_swap(void*, void*) and item_text(void*) must be implemented for this call.
|
|
\param[in] flags no flags were defined yet. Sorting in descending order and
|
|
sorting while ignoring case come to mind.
|
|
*/
|
|
void sort(int flags=0);
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
//
|
|
// End of "$Id$".
|
|
//
|