d751db12ff
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3@9668 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
116 lines
3.2 KiB
C++
116 lines
3.2 KiB
C++
//
|
|
// "$Id$"
|
|
//
|
|
// Menu button widget for the Fast Light Tool Kit (FLTK).
|
|
//
|
|
// Copyright 1998-2010 by Bill Spitzak and others.
|
|
//
|
|
// This library is free software. Distribution and use rights are outlined in
|
|
// the file "COPYING" which should have been included with this file. If this
|
|
// file is missing or damaged, see the license at:
|
|
//
|
|
// http://www.fltk.org/COPYING.php
|
|
//
|
|
// Please report all bugs and problems on the following page:
|
|
//
|
|
// http://www.fltk.org/str.php
|
|
//
|
|
|
|
#include <FL/Fl.H>
|
|
#include <FL/Fl_Menu_Button.H>
|
|
#include <FL/fl_draw.H>
|
|
|
|
|
|
static Fl_Menu_Button *pressed_menu_button_ = 0;
|
|
|
|
|
|
void Fl_Menu_Button::draw() {
|
|
if (!box() || type()) return;
|
|
int H = (labelsize()-3)&-2;
|
|
int X = x()+w()-H-Fl::box_dx(box())-Fl::box_dw(box())-1;
|
|
int Y = y()+(h()-H)/2;
|
|
draw_box(pressed_menu_button_ == this ? fl_down(box()) : box(), color());
|
|
draw_label(x()+Fl::box_dx(box()), y(), X-x()+2, h());
|
|
if (Fl::focus() == this) draw_focus();
|
|
// ** if (box() == FL_FLAT_BOX) return; // for XForms compatibility
|
|
fl_color(active_r() ? FL_DARK3 : fl_inactive(FL_DARK3));
|
|
fl_line(X+H/2, Y+H, X, Y, X+H, Y);
|
|
fl_color(active_r() ? FL_LIGHT3 : fl_inactive(FL_LIGHT3));
|
|
fl_line(X+H, Y, X+H/2, Y+H);
|
|
}
|
|
|
|
|
|
/**
|
|
Act exactly as though the user clicked the button or typed the
|
|
shortcut key. The menu appears, it waits for the user to pick an item,
|
|
and if they pick one it sets value() and does the callback or
|
|
sets changed() as described above. The menu item is returned
|
|
or NULL if the user dismisses the menu.
|
|
*/
|
|
const Fl_Menu_Item* Fl_Menu_Button::popup() {
|
|
const Fl_Menu_Item* m;
|
|
pressed_menu_button_ = this;
|
|
redraw();
|
|
Fl_Widget_Tracker mb(this);
|
|
if (!box() || type()) {
|
|
m = menu()->popup(Fl::event_x(), Fl::event_y(), label(), mvalue(), this);
|
|
} else {
|
|
m = menu()->pulldown(x(), y(), w(), h(), 0, this);
|
|
}
|
|
picked(m);
|
|
pressed_menu_button_ = 0;
|
|
if (mb.exists()) redraw();
|
|
return m;
|
|
}
|
|
|
|
int Fl_Menu_Button::handle(int e) {
|
|
if (!menu() || !menu()->text) return 0;
|
|
switch (e) {
|
|
case FL_ENTER: /* FALLTHROUGH */
|
|
case FL_LEAVE:
|
|
return (box() && !type()) ? 1 : 0;
|
|
case FL_PUSH:
|
|
if (!box()) {
|
|
if (Fl::event_button() != 3) return 0;
|
|
} else if (type()) {
|
|
if (!(type() & (1 << (Fl::event_button()-1)))) return 0;
|
|
}
|
|
if (Fl::visible_focus()) Fl::focus(this);
|
|
popup();
|
|
return 1;
|
|
case FL_KEYBOARD:
|
|
if (!box()) return 0;
|
|
if (Fl::event_key() == ' ' &&
|
|
!(Fl::event_state() & (FL_SHIFT | FL_CTRL | FL_ALT | FL_META))) {
|
|
popup();
|
|
return 1;
|
|
} else return 0;
|
|
case FL_SHORTCUT:
|
|
if (Fl_Widget::test_shortcut()) {popup(); return 1;}
|
|
return test_shortcut() != 0;
|
|
case FL_FOCUS: /* FALLTHROUGH */
|
|
case FL_UNFOCUS:
|
|
if (box() && Fl::visible_focus()) {
|
|
redraw();
|
|
return 1;
|
|
}
|
|
default:
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
/**
|
|
Creates a new Fl_Menu_Button widget using the given position,
|
|
size, and label string. The default boxtype is FL_UP_BOX.
|
|
<P>The constructor sets menu() to NULL. See
|
|
Fl_Menu_ for the methods to set or change the menu.
|
|
*/
|
|
Fl_Menu_Button::Fl_Menu_Button(int X,int Y,int W,int H,const char *l)
|
|
: Fl_Menu_(X,Y,W,H,l) {
|
|
down_box(FL_NO_BOX);
|
|
}
|
|
|
|
//
|
|
// End of "$Id$".
|
|
//
|