diff options
Diffstat (limited to 'src/FbTk')
-rw-r--r-- | src/FbTk/Menu.cc | 113 | ||||
-rw-r--r-- | src/FbTk/Menu.hh | 14 |
2 files changed, 51 insertions, 76 deletions
diff --git a/src/FbTk/Menu.cc b/src/FbTk/Menu.cc index e2aa3c5..59cc310 100644 --- a/src/FbTk/Menu.cc +++ b/src/FbTk/Menu.cc | |||
@@ -22,7 +22,7 @@ | |||
22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
23 | // DEALINGS IN THE SOFTWARE. | 23 | // DEALINGS IN THE SOFTWARE. |
24 | 24 | ||
25 | // $Id: Menu.cc,v 1.43 2003/11/28 23:26:27 fluxgen Exp $ | 25 | // $Id: Menu.cc,v 1.44 2003/12/10 23:08:06 fluxgen Exp $ |
26 | 26 | ||
27 | //use GNU extensions | 27 | //use GNU extensions |
28 | #ifndef _GNU_SOURCE | 28 | #ifndef _GNU_SOURCE |
@@ -48,45 +48,18 @@ | |||
48 | 48 | ||
49 | using namespace std; | 49 | using namespace std; |
50 | 50 | ||
51 | namespace { | ||
52 | Pixmap getRootPixmap(int screen_num) { | ||
53 | Pixmap root_pm = 0; | ||
54 | // get root pixmap for transparency | ||
55 | Display *disp = FbTk::App::instance()->display(); | ||
56 | Atom real_type; | ||
57 | int real_format; | ||
58 | unsigned long items_read, items_left; | ||
59 | unsigned int *data; | ||
60 | if (XGetWindowProperty(disp, RootWindow(disp, screen_num), | ||
61 | XInternAtom(disp, "_XROOTPMAP_ID", false), | ||
62 | 0L, 1L, | ||
63 | false, XA_PIXMAP, &real_type, | ||
64 | &real_format, &items_read, &items_left, | ||
65 | (unsigned char **) &data) == Success && | ||
66 | items_read) { | ||
67 | root_pm = (Pixmap) (*data); | ||
68 | XFree(data); | ||
69 | } | ||
70 | |||
71 | return root_pm; | ||
72 | } | ||
73 | |||
74 | }; // end anonymous namespace | ||
75 | |||
76 | namespace FbTk { | 51 | namespace FbTk { |
77 | 52 | ||
78 | static Menu *shown = 0; | 53 | static Menu *shown = 0; |
79 | 54 | ||
80 | Menu *Menu::s_focused = 0; | 55 | Menu *Menu::s_focused = 0; |
81 | 56 | ||
82 | Menu::Menu(MenuTheme &tm, int screen_num, ImageControl &imgctrl): | 57 | Menu::Menu(MenuTheme &tm, ImageControl &imgctrl): |
83 | m_theme(tm), | 58 | m_theme(tm), |
84 | m_screen_num(screen_num), | ||
85 | m_image_ctrl(imgctrl), | 59 | m_image_ctrl(imgctrl), |
86 | m_display(FbTk::App::instance()->display()), | ||
87 | m_parent(0), | 60 | m_parent(0), |
88 | m_screen_width(DisplayWidth(m_display, screen_num)), | 61 | m_screen_width(DisplayWidth(FbTk::App::instance()->display(), tm.screenNum())), |
89 | m_screen_height(DisplayHeight(m_display, screen_num)), | 62 | m_screen_height(DisplayHeight(FbTk::App::instance()->display(), tm.screenNum())), |
90 | m_alignment(ALIGNDONTCARE), | 63 | m_alignment(ALIGNDONTCARE), |
91 | m_border_width(0), | 64 | m_border_width(0), |
92 | m_themeobserver(*this), | 65 | m_themeobserver(*this), |
@@ -123,7 +96,7 @@ Menu::Menu(MenuTheme &tm, int screen_num, ImageControl &imgctrl): | |||
123 | 96 | ||
124 | menu.bevel_w = 2; | 97 | menu.bevel_w = 2; |
125 | 98 | ||
126 | menu.width = menu.title_h = menu.item_w = menu.frame_h = | 99 | menu.title_h = menu.item_w = menu.frame_h = |
127 | m_theme.titleFont().height() + menu.bevel_w * 2; | 100 | m_theme.titleFont().height() + menu.bevel_w * 2; |
128 | 101 | ||
129 | menu.sublevels = | 102 | menu.sublevels = |
@@ -132,13 +105,11 @@ Menu::Menu(MenuTheme &tm, int screen_num, ImageControl &imgctrl): | |||
132 | 105 | ||
133 | menu.item_h = m_theme.frameFont().height() + menu.bevel_w; | 106 | menu.item_h = m_theme.frameFont().height() + menu.bevel_w; |
134 | 107 | ||
135 | menu.height = menu.title_h + 2 + menu.frame_h; | ||
136 | |||
137 | long event_mask = ButtonPressMask | ButtonReleaseMask | | 108 | long event_mask = ButtonPressMask | ButtonReleaseMask | |
138 | ButtonMotionMask | KeyPressMask | ExposureMask | FocusChangeMask; | 109 | ButtonMotionMask | KeyPressMask | ExposureMask | FocusChangeMask; |
139 | //create menu window | 110 | // create menu window |
140 | menu.window = FbTk::FbWindow(screen_num, | 111 | menu.window = FbTk::FbWindow(tm.screenNum(), |
141 | menu.x, menu.y, menu.width, menu.height, | 112 | 0, 0, 10, 10, |
142 | event_mask, | 113 | event_mask, |
143 | true); // override redirect | 114 | true); // override redirect |
144 | 115 | ||
@@ -152,7 +123,7 @@ Menu::Menu(MenuTheme &tm, int screen_num, ImageControl &imgctrl): | |||
152 | event_mask |= EnterWindowMask | LeaveWindowMask; | 123 | event_mask |= EnterWindowMask | LeaveWindowMask; |
153 | //create menu title | 124 | //create menu title |
154 | menu.title = FbTk::FbWindow(menu.window, | 125 | menu.title = FbTk::FbWindow(menu.window, |
155 | 0, 0, menu.width, menu.height, | 126 | 0, 0, width(), menu.title_h, |
156 | event_mask); | 127 | event_mask); |
157 | 128 | ||
158 | evm.add(*this, menu.title); | 129 | evm.add(*this, menu.title); |
@@ -160,7 +131,7 @@ Menu::Menu(MenuTheme &tm, int screen_num, ImageControl &imgctrl): | |||
160 | event_mask |= PointerMotionMask; | 131 | event_mask |= PointerMotionMask; |
161 | menu.frame = FbTk::FbWindow(menu.window, | 132 | menu.frame = FbTk::FbWindow(menu.window, |
162 | 0, menu.title_h, | 133 | 0, menu.title_h, |
163 | menu.width, menu.frame_h, | 134 | width(), menu.frame_h ? menu.frame_h : 1, |
164 | event_mask); | 135 | event_mask); |
165 | evm.add(*this, menu.frame); | 136 | evm.add(*this, menu.frame); |
166 | // update style | 137 | // update style |
@@ -421,30 +392,36 @@ void Menu::update(int active_index) { | |||
421 | menu.persub = 0; | 392 | menu.persub = 0; |
422 | } | 393 | } |
423 | 394 | ||
424 | menu.width = (menu.sublevels * (menu.item_w)); | ||
425 | if (! menu.width) menu.width = menu.item_w; | ||
426 | |||
427 | menu.frame_h = (menu.item_h * menu.persub); | 395 | menu.frame_h = (menu.item_h * menu.persub); |
428 | if (menu.frame_h < 0) | 396 | if (menu.frame_h < 0) |
429 | menu.frame_h = 0; | 397 | menu.frame_h = 0; |
430 | 398 | ||
431 | menu.height = menu.frame_h; | 399 | |
400 | int new_width = (menu.sublevels * menu.item_w); | ||
401 | int new_height = menu.frame_h; | ||
402 | |||
432 | if (title_vis) | 403 | if (title_vis) |
433 | menu.height += menu.title_h + ((menu.frame_h>0)?menu.title.borderWidth():0); | 404 | new_height += menu.title_h + ((menu.frame_h>0)?menu.title.borderWidth():0); |
405 | |||
406 | |||
407 | if (new_width < 1) | ||
408 | new_width = menu.item_w; | ||
409 | |||
410 | if (new_height < 1) | ||
411 | new_height = 1; | ||
434 | 412 | ||
435 | if (menu.height < 1) | 413 | menu.window.resize(new_width, new_height); |
436 | menu.height = 1; | ||
437 | 414 | ||
438 | Pixmap tmp; | 415 | Pixmap tmp; |
439 | if (title_vis) { | 416 | if (title_vis) { |
440 | tmp = menu.title_pixmap; | 417 | tmp = menu.title_pixmap; |
441 | const FbTk::Texture &tex = m_theme.titleTexture(); | 418 | const FbTk::Texture &tex = m_theme.titleTexture(); |
442 | if (tex.type() == (FbTk::Texture::FLAT | FbTk::Texture::SOLID)) { | 419 | if (!tex.usePixmap()) { |
443 | menu.title_pixmap = None; | 420 | menu.title_pixmap = None; |
444 | menu.title.setBackgroundColor(tex.color()); | 421 | menu.title.setBackgroundColor(tex.color()); |
445 | } else { | 422 | } else { |
446 | menu.title_pixmap = | 423 | menu.title_pixmap = |
447 | m_image_ctrl.renderImage(menu.width, menu.title_h, tex); | 424 | m_image_ctrl.renderImage(width(), menu.title_h, tex); |
448 | menu.title.setBackgroundPixmap(menu.title_pixmap); | 425 | menu.title.setBackgroundPixmap(menu.title_pixmap); |
449 | } | 426 | } |
450 | 427 | ||
@@ -455,11 +432,11 @@ void Menu::update(int active_index) { | |||
455 | 432 | ||
456 | tmp = menu.frame_pixmap; | 433 | tmp = menu.frame_pixmap; |
457 | const FbTk::Texture &frame_tex = m_theme.frameTexture(); | 434 | const FbTk::Texture &frame_tex = m_theme.frameTexture(); |
458 | if (frame_tex.type() == (FbTk::Texture::FLAT | FbTk::Texture::SOLID)) { | 435 | if (!frame_tex.usePixmap()) { |
459 | menu.frame_pixmap = None; | 436 | menu.frame_pixmap = None; |
460 | } else { | 437 | } else { |
461 | menu.frame_pixmap = | 438 | menu.frame_pixmap = |
462 | m_image_ctrl.renderImage(menu.width, menu.frame_h, frame_tex); | 439 | m_image_ctrl.renderImage(width(), menu.frame_h, frame_tex); |
463 | } | 440 | } |
464 | 441 | ||
465 | if (tmp) | 442 | if (tmp) |
@@ -467,18 +444,18 @@ void Menu::update(int active_index) { | |||
467 | 444 | ||
468 | tmp = menu.hilite_pixmap; | 445 | tmp = menu.hilite_pixmap; |
469 | const FbTk::Texture &hilite_tex = m_theme.hiliteTexture(); | 446 | const FbTk::Texture &hilite_tex = m_theme.hiliteTexture(); |
470 | if (hilite_tex.type() == (FbTk::Texture::FLAT | FbTk::Texture::SOLID)) | 447 | if (!hilite_tex.usePixmap()) { |
471 | menu.hilite_pixmap = None; | 448 | menu.hilite_pixmap = None; |
472 | else | 449 | } else |
473 | menu.hilite_pixmap = | 450 | menu.hilite_pixmap = |
474 | m_image_ctrl.renderImage(menu.item_w, menu.item_h, hilite_tex); | 451 | m_image_ctrl.renderImage(menu.item_w, menu.item_h, hilite_tex); |
475 | if (tmp) | 452 | if (tmp) |
476 | m_image_ctrl.removeImage(tmp); | 453 | m_image_ctrl.removeImage(tmp); |
477 | 454 | ||
478 | tmp = menu.sel_pixmap; | 455 | tmp = menu.sel_pixmap; |
479 | if (hilite_tex.type() == (FbTk::Texture::FLAT | FbTk::Texture::SOLID)) | 456 | if (!hilite_tex.usePixmap()) { |
480 | menu.sel_pixmap = None; | 457 | menu.sel_pixmap = None; |
481 | else { | 458 | } else { |
482 | int hw = menu.item_h / 2; | 459 | int hw = menu.item_h / 2; |
483 | menu.sel_pixmap = | 460 | menu.sel_pixmap = |
484 | m_image_ctrl.renderImage(hw, hw, hilite_tex); | 461 | m_image_ctrl.renderImage(hw, hw, hilite_tex); |
@@ -486,11 +463,11 @@ void Menu::update(int active_index) { | |||
486 | if (tmp) | 463 | if (tmp) |
487 | m_image_ctrl.removeImage(tmp); | 464 | m_image_ctrl.removeImage(tmp); |
488 | 465 | ||
489 | menu.window.resize(menu.width, menu.height); | 466 | |
490 | 467 | ||
491 | if (title_vis) { | 468 | if (title_vis) { |
492 | menu.title.moveResize(-menu.title.borderWidth(), -menu.title.borderWidth(), | 469 | menu.title.moveResize(-menu.title.borderWidth(), -menu.title.borderWidth(), |
493 | menu.width + menu.title.borderWidth(), menu.title_h); | 470 | width() + menu.title.borderWidth(), menu.title_h); |
494 | } | 471 | } |
495 | 472 | ||
496 | menu.frame.moveResize(0, ((title_vis) ? menu.title.y() + menu.title.height() + | 473 | menu.frame.moveResize(0, ((title_vis) ? menu.title.y() + menu.title.height() + |
@@ -637,11 +614,11 @@ void Menu::redrawTitle() { | |||
637 | 614 | ||
638 | switch (m_theme.titleFontJustify()) { | 615 | switch (m_theme.titleFontJustify()) { |
639 | case FbTk::RIGHT: | 616 | case FbTk::RIGHT: |
640 | dx += menu.width - l; | 617 | dx += width() - l; |
641 | break; | 618 | break; |
642 | 619 | ||
643 | case FbTk::CENTER: | 620 | case FbTk::CENTER: |
644 | dx += (menu.width - l) / 2; | 621 | dx += (width() - l) / 2; |
645 | break; | 622 | break; |
646 | default: | 623 | default: |
647 | break; | 624 | break; |
@@ -695,10 +672,10 @@ void Menu::drawSubmenu(unsigned int index) { | |||
695 | } | 672 | } |
696 | 673 | ||
697 | if (m_alignment == ALIGNBOTTOM && | 674 | if (m_alignment == ALIGNBOTTOM && |
698 | (y + item->submenu()->menu.height) > ((shifted) ? menu.y_shift : | 675 | (y + item->submenu()->height()) > ((shifted) ? menu.y_shift : |
699 | menu.y) + menu.height) { | 676 | menu.y) + height()) { |
700 | y = (((shifted) ? menu.y_shift : menu.y) + | 677 | y = (((shifted) ? menu.y_shift : menu.y) + |
701 | menu.height - item->submenu()->menu.height); | 678 | height() - item->submenu()->height()); |
702 | } | 679 | } |
703 | 680 | ||
704 | if ((x + item->submenu()->width()) > m_screen_width) { | 681 | if ((x + item->submenu()->width()) > m_screen_width) { |
@@ -1090,13 +1067,13 @@ void Menu::buttonReleaseEvent(XButtonEvent &re) { | |||
1090 | update(); | 1067 | update(); |
1091 | } | 1068 | } |
1092 | 1069 | ||
1093 | if (re.x >= 0 && re.x <= (signed) menu.width && | 1070 | if (re.x >= 0 && re.x <= (signed) width() && |
1094 | re.y >= 0 && re.y <= (signed) menu.title_h && | 1071 | re.y >= 0 && re.y <= (signed) menu.title_h && |
1095 | re.button == 3) | 1072 | re.button == 3) |
1096 | hide(); | 1073 | hide(); |
1097 | 1074 | ||
1098 | } else if (re.window == menu.frame && | 1075 | } else if (re.window == menu.frame && |
1099 | re.x >= 0 && re.x < (signed) menu.width && | 1076 | re.x >= 0 && re.x < (signed) width() && |
1100 | re.y >= 0 && re.y < (signed) menu.frame_h) { | 1077 | re.y >= 0 && re.y < (signed) menu.frame_h) { |
1101 | 1078 | ||
1102 | int sbl = (re.x / menu.item_w), i = (re.y / menu.item_h), | 1079 | int sbl = (re.x / menu.item_w), i = (re.y / menu.item_h), |
@@ -1147,7 +1124,7 @@ void Menu::motionNotifyEvent(XMotionEvent &me) { | |||
1147 | } | 1124 | } |
1148 | } | 1125 | } |
1149 | } else if ((! (me.state & Button1Mask)) && me.window == menu.frame && | 1126 | } else if ((! (me.state & Button1Mask)) && me.window == menu.frame && |
1150 | me.x >= 0 && me.x < (signed) menu.width && | 1127 | me.x >= 0 && me.x < (signed) width() && |
1151 | me.y >= 0 && me.y < (signed) menu.frame_h) { | 1128 | me.y >= 0 && me.y < (signed) menu.frame_h) { |
1152 | int sbl = (me.x / menu.item_w), i = (me.y / menu.item_h), | 1129 | int sbl = (me.x / menu.item_w), i = (me.y / menu.item_h), |
1153 | w = (sbl * menu.persub) + i; | 1130 | w = (sbl * menu.persub) + i; |
@@ -1230,16 +1207,16 @@ void Menu::enterNotifyEvent(XCrossingEvent &ce) { | |||
1230 | return; | 1207 | return; |
1231 | 1208 | ||
1232 | menu.x_shift = menu.x, menu.y_shift = menu.y; | 1209 | menu.x_shift = menu.x, menu.y_shift = menu.y; |
1233 | if (menu.x + menu.width > m_screen_width) { | 1210 | if (menu.x + width() > m_screen_width) { |
1234 | menu.x_shift = m_screen_width - menu.width - 2*m_border_width; | 1211 | menu.x_shift = m_screen_width - width() - 2*m_border_width; |
1235 | shifted = true; | 1212 | shifted = true; |
1236 | } else if (menu.x < 0) { | 1213 | } else if (menu.x < 0) { |
1237 | menu.x_shift = 0; //-m_border_width; | 1214 | menu.x_shift = 0; //-m_border_width; |
1238 | shifted = true; | 1215 | shifted = true; |
1239 | } | 1216 | } |
1240 | 1217 | ||
1241 | if (menu.y + menu.height + 2*m_border_width > m_screen_height) { | 1218 | if (menu.y + height() + 2*m_border_width > m_screen_height) { |
1242 | menu.y_shift = m_screen_height - menu.height - 2*m_border_width; | 1219 | menu.y_shift = m_screen_height - height() - 2*m_border_width; |
1243 | shifted = true; | 1220 | shifted = true; |
1244 | } else if (menu.y + (signed) menu.title_h < 0) { | 1221 | } else if (menu.y + (signed) menu.title_h < 0) { |
1245 | menu.y_shift = 0; // -m_border_width;; | 1222 | menu.y_shift = 0; // -m_border_width;; |
diff --git a/src/FbTk/Menu.hh b/src/FbTk/Menu.hh index 333f6d8..9a3f425 100644 --- a/src/FbTk/Menu.hh +++ b/src/FbTk/Menu.hh | |||
@@ -22,7 +22,7 @@ | |||
22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 22 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
23 | // DEALINGS IN THE SOFTWARE. | 23 | // DEALINGS IN THE SOFTWARE. |
24 | 24 | ||
25 | // $Id: Menu.hh,v 1.24 2003/12/08 16:39:44 fluxgen Exp $ | 25 | // $Id: Menu.hh,v 1.25 2003/12/10 23:08:06 fluxgen Exp $ |
26 | 26 | ||
27 | #ifndef FBTK_MENU_HH | 27 | #ifndef FBTK_MENU_HH |
28 | #define FBTK_MENU_HH | 28 | #define FBTK_MENU_HH |
@@ -57,7 +57,7 @@ public: | |||
57 | */ | 57 | */ |
58 | enum { EMPTY = 0, SQUARE, TRIANGLE, DIAMOND }; | 58 | enum { EMPTY = 0, SQUARE, TRIANGLE, DIAMOND }; |
59 | 59 | ||
60 | Menu(MenuTheme &tm, int screen_num, ImageControl &imgctrl); | 60 | Menu(MenuTheme &tm, ImageControl &imgctrl); |
61 | virtual ~Menu(); | 61 | virtual ~Menu(); |
62 | 62 | ||
63 | /** | 63 | /** |
@@ -132,7 +132,7 @@ public: | |||
132 | //@{ | 132 | //@{ |
133 | inline bool isTorn() const { return torn; } | 133 | inline bool isTorn() const { return torn; } |
134 | inline bool isVisible() const { return visible; } | 134 | inline bool isVisible() const { return visible; } |
135 | inline int screenNumber() const { return m_screen_num; } | 135 | inline int screenNumber() const { return menu.window.screenNumber(); } |
136 | inline Window window() const { return menu.window.window(); } | 136 | inline Window window() const { return menu.window.window(); } |
137 | inline FbWindow &fbwindow() { return menu.window; } | 137 | inline FbWindow &fbwindow() { return menu.window; } |
138 | inline const FbWindow &fbwindow() const { return menu.window; } | 138 | inline const FbWindow &fbwindow() const { return menu.window; } |
@@ -141,8 +141,8 @@ public: | |||
141 | inline const std::string &label() const { return menu.label; } | 141 | inline const std::string &label() const { return menu.label; } |
142 | inline int x() const { return menu.x; } | 142 | inline int x() const { return menu.x; } |
143 | inline int y() const { return menu.y; } | 143 | inline int y() const { return menu.y; } |
144 | inline unsigned int width() const { return menu.width; } | 144 | inline unsigned int width() const { return menu.window.width(); } |
145 | inline unsigned int height() const { return menu.height; } | 145 | inline unsigned int height() const { return menu.window.height(); } |
146 | inline unsigned int numberOfItems() const { return menuitems.size(); } | 146 | inline unsigned int numberOfItems() const { return menuitems.size(); } |
147 | inline int currentSubmenu() const { return which_sub; } | 147 | inline int currentSubmenu() const { return which_sub; } |
148 | inline unsigned int titleHeight() const { return menu.title_h; } | 148 | inline unsigned int titleHeight() const { return menu.title_h; } |
@@ -178,8 +178,6 @@ private: | |||
178 | 178 | ||
179 | typedef std::vector<MenuItem *> Menuitems; | 179 | typedef std::vector<MenuItem *> Menuitems; |
180 | const MenuTheme &m_theme; | 180 | const MenuTheme &m_theme; |
181 | Display *m_display; | ||
182 | const int m_screen_num; | ||
183 | Menu *m_parent; | 181 | Menu *m_parent; |
184 | ImageControl &m_image_ctrl; | 182 | ImageControl &m_image_ctrl; |
185 | Menuitems menuitems; | 183 | Menuitems menuitems; |
@@ -198,7 +196,7 @@ private: | |||
198 | std::string label; | 196 | std::string label; |
199 | int x, y, x_move, y_move, x_shift, y_shift, sublevels, persub, minsub, | 197 | int x, y, x_move, y_move, x_shift, y_shift, sublevels, persub, minsub, |
200 | grab_x, grab_y; | 198 | grab_x, grab_y; |
201 | unsigned int width, height, title_h, frame_h, item_w, item_h, bevel_w, | 199 | unsigned int title_h, frame_h, item_w, item_h, bevel_w, |
202 | bevel_h; | 200 | bevel_h; |
203 | } menu; | 201 | } menu; |
204 | 202 | ||