source: src/UIElements/Menu/Qt4/QtMenu.hpp@ ef8667

ForceAnnealing_oldresults IndependentFragmentGrids_IntegrationTest
Last change on this file since ef8667 was 86c013, checked in by Frederik Heber <heber@…>, 11 years ago

QMenu extended for tooltips, but not working yet.

  • somehow no QHelpEvents are triggered that would cause display of tooltips for QActions as menuitems.
  • Property mode set to 100644
File size: 3.3 KB
RevLine 
[b47bfc]1/*
[4cf323d]2 * QtMenu.hpp
[b47bfc]3 *
[b59da6]4 * Created on: Nov 5, 2010
5 * Author: heber
[b47bfc]6 */
7
[b59da6]8#ifndef MENUINTERFACEQT_HPP_
9#define MENUINTERFACEQT_HPP_
[b47bfc]10
[56f73b]11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16
[b59da6]17#include <Qt/qaction.h>
[b47bfc]18
[86c013]19#include "Menu/Qt4/QMenu_tooltip.hpp"
20
[b59da6]21#include <iostream>
22#include <list>
23#include <map>
24#include <string>
[b47bfc]25
26#include "Menu/Menu.hpp"
[b59da6]27#include "Menu/MenuInterface.hpp"
28#include "Menu/Qt4/QtMenuPipe.hpp"
[b47bfc]29
[b59da6]30/** QtMenu is a specialization of MenuInterface to Qt-like menus.
31 * I.e. with this interface we can access QMenu and QMenuBar.
32 * (The latter is the reason why we have to add this additional wrapping layer).
33 */
34template <class T>
35class QtMenu : virtual public MenuInterface, public Menu
[b47bfc]36{
37public:
[b59da6]38 explicit QtMenu(const std::string &_token) :
39 MenuInterface(_token),
40 Menu(_token),
41 MenuInstance(new T(QString(getNameWithAccelerator(_token).c_str()))),
42 deleteMenu(true)
43 {}
[b47bfc]44
[b59da6]45 QtMenu(T *_Menu, const std::string &_token) :
46 MenuInterface(_token),
47 Menu(_token),
48 MenuInstance(_Menu),
49 deleteMenu(false)
50 {}
51
52 virtual ~QtMenu()
53 {
54 for(std::list<QtMenuPipe*>::iterator it=plumbing.begin(); it != plumbing.end(); it++)
55 delete (*it);
56
57 if (deleteMenu)
58 delete MenuInstance;
59 }
60
61 T * const getMenuInstance()
62 {
63 return MenuInstance;
64 }
65
66protected:
67 // We need to have a reference of the Menu, as Qt returns reference to added menu as well
68 T *MenuInstance;
69
70 /** Puts Qt's token, the ampersand, in front of the accelerator char in the menu name.
71 * \param ActionName Action of menu
72 * \return name with ampersand added at the right place
73 */
74 std::string getNameWithAccelerator(const std::string &ActionName)
75 {
76 std::string newname;
77 bool Inserted = false;
78 std::pair < MenuShortcutMap::iterator, bool > Inserter;
79 for (std::string::const_iterator CharRunner = ActionName.begin();
80 CharRunner != ActionName.end();
81 ++CharRunner) {
[ad7270]82// std::cout << "Current char is " << *CharRunner << std::endl;
[b59da6]83 if (!Inserted) {
84 Inserter = ShortcutMap.insert(
85 std::pair<char, std::string > (*CharRunner, ActionName)
86 );
87 if (Inserter.second) {
[ad7270]88// std::cout << "Accelerator is " << *CharRunner << std::endl;
[b59da6]89 newname += '&';
90 Inserted = true;
91 }
92 }
93 newname += *CharRunner;
94 }
95 return newname;
96 }
[b47bfc]97
98private:
[b59da6]99 bool deleteMenu;
100 std::list<QtMenuPipe*> plumbing;
101
102 typedef std::map <char, std::string> MenuShortcutMap;
103 MenuShortcutMap ShortcutMap;
104
105 virtual void addActionItem(const std::string &token, const std::string &description)
106 {
[163110]107 QAction *action = MenuInstance->addAction(QString(getNameWithAccelerator(token).c_str()));
[86c013]108 action->setToolTip(QString(description.c_str()));
109 action->setWhatsThis(QString(description.c_str()));
[b59da6]110 QtMenuPipe *pipe = new QtMenuPipe(token,action);
111 QObject::connect(action, SIGNAL(triggered()),pipe,SLOT(called()));
112 plumbing.push_back(pipe);
113 }
114
115 virtual void addSeparatorItem()
116 {
117 MenuInstance->addSeparator();
118 }
119
120 virtual void addSubmenuItem(const std::string &token, const std::string &description)
121 {
[86c013]122 QMenu_tooltip *Menu = new QMenu_tooltip(QString(token.c_str()));
123 MenuInstance->addMenu(Menu);
124 QtMenu<QMenu_tooltip> *NewMenu = new QtMenu<QMenu_tooltip>(Menu, token);
[b59da6]125 NewMenu->init();
126 }
127
[b47bfc]128};
129
[b59da6]130#endif /* MENUINTERFACEQT_HPP_ */
Note: See TracBrowser for help on using the repository browser.