|
- //
- // "$Id: Fl_Menu_.H 7903 2010-11-28 21:06:39Z matt $"
- //
- // Menu base class header file for the Fast Light Tool Kit (FLTK).
- //
- // Copyright 1998-2010 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_Menu_ widget . */
-
- #ifndef Fl_Menu__H
- #define Fl_Menu__H
-
- #ifndef Fl_Widget_H
- #include "Fl_Widget.H"
- #endif
- #include "Fl_Menu_Item.H"
-
- /**
- Base class of all widgets that have a menu in FLTK.
- Currently FLTK provides you with
- Fl_Menu_Button, Fl_Menu_Bar, and Fl_Choice.
-
- <P>The class contains a pointer to an array of structures of type Fl_Menu_Item. The
- array may either be supplied directly by the user program, or it may
- be "private": a dynamically allocated array managed by the Fl_Menu_.
- */
- class FL_EXPORT Fl_Menu_ : public Fl_Widget {
-
- Fl_Menu_Item *menu_;
- const Fl_Menu_Item *value_;
-
- protected:
-
- uchar alloc; // flag indicates if menu_ is a dynamic copy (=1) or not (=0)
- uchar down_box_;
- Fl_Font textfont_;
- Fl_Fontsize textsize_;
- Fl_Color textcolor_;
-
- public:
- Fl_Menu_(int,int,int,int,const char * =0);
- ~Fl_Menu_();
-
- int item_pathname(char *name, int namelen, const Fl_Menu_Item *finditem=0) const;
- const Fl_Menu_Item* picked(const Fl_Menu_Item*);
- const Fl_Menu_Item* find_item(const char *name);
- const Fl_Menu_Item* find_item(Fl_Callback*);
- int find_index(const char *name) const;
- int find_index(const Fl_Menu_Item *item) const;
- int find_index(Fl_Callback *cb) const;
-
- /**
- Returns the menu item with the entered shortcut (key value).
-
- This searches the complete menu() for a shortcut that matches the
- entered key value. It must be called for a FL_KEYBOARD or FL_SHORTCUT
- event.
-
- If a match is found, the menu's callback will be called.
-
- \return matched Fl_Menu_Item or NULL.
- */
- const Fl_Menu_Item* test_shortcut() {return picked(menu()->test_shortcut());}
- void global();
-
- /**
- Returns a pointer to the array of Fl_Menu_Items. This will either be
- the value passed to menu(value) or the private copy.
- */
- const Fl_Menu_Item *menu() const {return menu_;}
- void menu(const Fl_Menu_Item *m);
- void copy(const Fl_Menu_Item *m, void* user_data = 0);
- int insert(int index, const char*, int shortcut, Fl_Callback*, void* = 0, int = 0);
- int add(const char*, int shortcut, Fl_Callback*, void* = 0, int = 0);
- /** See int Fl_Menu_::add(const char* label, int shortcut, Fl_Callback*, void *user_data=0, int flags=0) */
- int add(const char* a, const char* b, Fl_Callback* c, void* d = 0, int e = 0) {
- return add(a,fl_old_shortcut(b),c,d,e);
- }
- /** See int Fl_Menu_::insert(const char* label, int shortcut, Fl_Callback*, void *user_data=0, int flags=0) */
- int insert(int index, const char* a, const char* b, Fl_Callback* c, void* d = 0, int e = 0) {
- return insert(index,a,fl_old_shortcut(b),c,d,e);
- }
- int add(const char *);
- int size() const ;
- void size(int W, int H) { Fl_Widget::size(W, H); }
- void clear();
- int clear_submenu(int index);
- void replace(int,const char *);
- void remove(int);
- /** Changes the shortcut of item i to n. */
- void shortcut(int i, int s) {menu_[i].shortcut(s);}
- /** Sets the flags of item i. For a list of the flags, see Fl_Menu_Item. */
- void mode(int i,int fl) {menu_[i].flags = fl;}
- /** Gets the flags of item i. For a list of the flags, see Fl_Menu_Item. */
- int mode(int i) const {return menu_[i].flags;}
-
- /** Returns a pointer to the last menu item that was picked. */
- const Fl_Menu_Item *mvalue() const {return value_;}
- /** Returns the index into menu() of the last item chosen by the user. It is zero initially. */
- int value() const {return value_ ? (int)(value_-menu_) : -1;}
- int value(const Fl_Menu_Item*);
- /**
- The value is the index into menu() of the last item chosen by
- the user. It is zero initially. You can set it as an integer, or set
- it with a pointer to a menu item. The set routines return non-zero if
- the new value is different than the old one.
- */
- int value(int i) {return value(menu_+i);}
- /** Returns the title of the last item chosen. */
- const char *text() const {return value_ ? value_->text : 0;}
- /** Returns the title of item i. */
- const char *text(int i) const {return menu_[i].text;}
-
- /** Gets the current font of menu item labels. */
- Fl_Font textfont() const {return textfont_;}
- /** Sets the current font of menu item labels. */
- void textfont(Fl_Font c) {textfont_=c;}
- /** Gets the font size of menu item labels. */
- Fl_Fontsize textsize() const {return textsize_;}
- /** Sets the font size of menu item labels. */
- void textsize(Fl_Fontsize c) {textsize_=c;}
- /** Get the current color of menu item labels. */
- Fl_Color textcolor() const {return textcolor_;}
- /** Sets the current color of menu item labels. */
- void textcolor(Fl_Color c) {textcolor_=c;}
-
- /**
- This box type is used to surround the currently-selected items in the
- menus. If this is FL_NO_BOX then it acts like
- FL_THIN_UP_BOX and selection_color() acts like
- FL_WHITE, for back compatibility.
- */
- Fl_Boxtype down_box() const {return (Fl_Boxtype)down_box_;}
- /** See Fl_Boxtype Fl_Menu_::down_box() const */
- void down_box(Fl_Boxtype b) {down_box_ = b;}
-
- /** For back compatibility, same as selection_color() */
- Fl_Color down_color() const {return selection_color();}
- /** For back compatibility, same as selection_color() */
- void down_color(unsigned c) {selection_color(c);}
- };
-
- #endif
-
- //
- // End of "$Id: Fl_Menu_.H 7903 2010-11-28 21:06:39Z matt $".
- //
|