diff options
-rw-r--r-- | src/FbMenu.cc | 25 | ||||
-rw-r--r-- | src/FbMenu.hh | 7 | ||||
-rw-r--r-- | src/FbTk/Menu.cc | 4 | ||||
-rw-r--r-- | src/FbTk/Menu.hh | 7 |
4 files changed, 10 insertions, 33 deletions
diff --git a/src/FbMenu.cc b/src/FbMenu.cc index 65fbecd..941ca0e 100644 --- a/src/FbMenu.cc +++ b/src/FbMenu.cc | |||
@@ -25,36 +25,13 @@ | |||
25 | #include "FbMenu.hh" | 25 | #include "FbMenu.hh" |
26 | 26 | ||
27 | #include "fluxbox.hh" | 27 | #include "fluxbox.hh" |
28 | #include "FbTk/MenuTheme.hh" | ||
29 | #include "Screen.hh" | 28 | #include "Screen.hh" |
30 | 29 | ||
31 | #include "FbTk/Shape.hh" | ||
32 | |||
33 | FbMenu::FbMenu(FbTk::MenuTheme &tm, FbTk::ImageControl &imgctrl, | 30 | FbMenu::FbMenu(FbTk::MenuTheme &tm, FbTk::ImageControl &imgctrl, |
34 | FbTk::XLayer &layer): | 31 | FbTk::XLayer &layer): |
35 | FbTk::Menu(tm, imgctrl), | 32 | FbTk::Menu(tm, imgctrl), |
36 | m_layeritem(fbwindow(), layer), | 33 | m_layeritem(fbwindow(), layer) { |
37 | m_shape(new FbTk::Shape(fbwindow(), tm.shapePlaces())) { | ||
38 | |||
39 | } | ||
40 | |||
41 | FbMenu::~FbMenu() { | ||
42 | |||
43 | } | ||
44 | |||
45 | void FbMenu::updateMenu(int index) { | ||
46 | FbTk::Menu::updateMenu(index); | ||
47 | m_shape->update(); | ||
48 | } | ||
49 | |||
50 | void FbMenu::clearWindow() { | ||
51 | FbTk::Menu::clearWindow(); | ||
52 | m_shape->update(); | ||
53 | } | ||
54 | 34 | ||
55 | void FbMenu::reconfigure() { | ||
56 | m_shape->setPlaces(theme().shapePlaces()); | ||
57 | FbTk::Menu::reconfigure(); | ||
58 | } | 35 | } |
59 | 36 | ||
60 | void FbMenu::buttonReleaseEvent(XButtonEvent &be) { | 37 | void FbMenu::buttonReleaseEvent(XButtonEvent &be) { |
diff --git a/src/FbMenu.hh b/src/FbMenu.hh index ef8670d..9469311 100644 --- a/src/FbMenu.hh +++ b/src/FbMenu.hh | |||
@@ -30,7 +30,6 @@ | |||
30 | 30 | ||
31 | namespace FbTk { | 31 | namespace FbTk { |
32 | class MenuTheme; | 32 | class MenuTheme; |
33 | class Shape; | ||
34 | } | 33 | } |
35 | 34 | ||
36 | /// a layered and shaped menu | 35 | /// a layered and shaped menu |
@@ -38,16 +37,12 @@ class FbMenu:public FbTk::Menu { | |||
38 | public: | 37 | public: |
39 | FbMenu(FbTk::MenuTheme &tm, FbTk::ImageControl &imgctrl, | 38 | FbMenu(FbTk::MenuTheme &tm, FbTk::ImageControl &imgctrl, |
40 | FbTk::XLayer &layer); | 39 | FbTk::XLayer &layer); |
41 | virtual ~FbMenu(); | 40 | virtual ~FbMenu() { } |
42 | void updateMenu(int index = -1); | ||
43 | void clearWindow(); | ||
44 | void raise() { m_layeritem.raise(); } | 41 | void raise() { m_layeritem.raise(); } |
45 | void lower() { m_layeritem.lower(); } | 42 | void lower() { m_layeritem.lower(); } |
46 | void reconfigure(); | ||
47 | void buttonReleaseEvent(XButtonEvent &be); | 43 | void buttonReleaseEvent(XButtonEvent &be); |
48 | private: | 44 | private: |
49 | FbTk::XLayerItem m_layeritem; | 45 | FbTk::XLayerItem m_layeritem; |
50 | std::auto_ptr<FbTk::Shape> m_shape; | ||
51 | }; | 46 | }; |
52 | 47 | ||
53 | #endif // FBMENU_HH | 48 | #endif // FBMENU_HH |
diff --git a/src/FbTk/Menu.cc b/src/FbTk/Menu.cc index 485b56c..00dcc54 100644 --- a/src/FbTk/Menu.cc +++ b/src/FbTk/Menu.cc | |||
@@ -92,6 +92,7 @@ Menu::Menu(MenuTheme &tm, ImageControl &imgctrl): | |||
92 | m_screen_height(DisplayHeight(FbTk::App::instance()->display(), tm.screenNum())), | 92 | m_screen_height(DisplayHeight(FbTk::App::instance()->display(), tm.screenNum())), |
93 | m_alignment(ALIGNDONTCARE), | 93 | m_alignment(ALIGNDONTCARE), |
94 | m_active_index(-1), | 94 | m_active_index(-1), |
95 | m_shape(new Shape(fbwindow(), tm.shapePlaces())), | ||
95 | m_need_update(true) { | 96 | m_need_update(true) { |
96 | // setup timers | 97 | // setup timers |
97 | 98 | ||
@@ -496,6 +497,7 @@ void Menu::updateMenu(int active_index) { | |||
496 | 497 | ||
497 | clearWindow(); | 498 | clearWindow(); |
498 | m_need_update = false; | 499 | m_need_update = false; |
500 | m_shape->update(); | ||
499 | } | 501 | } |
500 | 502 | ||
501 | 503 | ||
@@ -563,6 +565,7 @@ void Menu::clearWindow() { | |||
563 | for (size_t i = 0; i < menuitems.size(); i++) { | 565 | for (size_t i = 0; i < menuitems.size(); i++) { |
564 | clearItem(i, false); // no clear | 566 | clearItem(i, false); // no clear |
565 | } | 567 | } |
568 | m_shape->update(); | ||
566 | } | 569 | } |
567 | 570 | ||
568 | void Menu::redrawFrame(FbDrawable &drawable) { | 571 | void Menu::redrawFrame(FbDrawable &drawable) { |
@@ -1091,6 +1094,7 @@ void Menu::keyPressEvent(XKeyEvent &event) { | |||
1091 | 1094 | ||
1092 | 1095 | ||
1093 | void Menu::reconfigure() { | 1096 | void Menu::reconfigure() { |
1097 | m_shape->setPlaces(theme().shapePlaces()); | ||
1094 | 1098 | ||
1095 | if (FbTk::Transparent::haveComposite()) { | 1099 | if (FbTk::Transparent::haveComposite()) { |
1096 | menu.window.setOpaque(alpha()); | 1100 | menu.window.setOpaque(alpha()); |
diff --git a/src/FbTk/Menu.hh b/src/FbTk/Menu.hh index f16c443..54c6d62 100644 --- a/src/FbTk/Menu.hh +++ b/src/FbTk/Menu.hh | |||
@@ -203,13 +203,12 @@ private: | |||
203 | void startHide(); | 203 | void startHide(); |
204 | void stopHide(); | 204 | void stopHide(); |
205 | 205 | ||
206 | |||
207 | typedef std::vector<MenuItem *> Menuitems; | ||
208 | MenuTheme &m_theme; | 206 | MenuTheme &m_theme; |
209 | Menu *m_parent; | 207 | Menu *m_parent; |
210 | ImageControl &m_image_ctrl; | 208 | ImageControl &m_image_ctrl; |
211 | Menuitems menuitems; | ||
212 | 209 | ||
210 | typedef std::vector<MenuItem *> Menuitems; | ||
211 | Menuitems menuitems; | ||
213 | TypeAhead<Menuitems, MenuItem *> m_type_ahead; | 212 | TypeAhead<Menuitems, MenuItem *> m_type_ahead; |
214 | Menuitems m_matches; | 213 | Menuitems m_matches; |
215 | 214 | ||
@@ -242,6 +241,8 @@ private: | |||
242 | 241 | ||
243 | int m_active_index; ///< current highlighted index | 242 | int m_active_index; ///< current highlighted index |
244 | 243 | ||
244 | std::auto_ptr<FbTk::Shape> m_shape; | ||
245 | |||
245 | Drawable m_root_pm; | 246 | Drawable m_root_pm; |
246 | static Menu *shown; ///< used for determining if there's a menu open at all | 247 | static Menu *shown; ///< used for determining if there's a menu open at all |
247 | static Menu *s_focused; ///< holds current input focused menu, so one can determine if a menu is focused | 248 | static Menu *s_focused; ///< holds current input focused menu, so one can determine if a menu is focused |