summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--vcl/inc/qt5/Qt5Menu.hxx5
-rw-r--r--vcl/qt5/Qt5Menu.cxx124
2 files changed, 72 insertions, 57 deletions
diff --git a/vcl/inc/qt5/Qt5Menu.hxx b/vcl/inc/qt5/Qt5Menu.hxx
index e31c44fa8b55..92d2e18b9c5c 100644
--- a/vcl/inc/qt5/Qt5Menu.hxx
+++ b/vcl/inc/qt5/Qt5Menu.hxx
@@ -12,6 +12,7 @@
#include <salmenu.hxx>
class MenuItemList;
+class QActionGroup;
class QMenu;
class QMenuBar;
class Qt5MenuItem;
@@ -27,10 +28,14 @@ private:
Qt5Frame* mpFrame;
bool mbMenuBar;
QMenuBar* mpQMenuBar;
+ QMenu* mpQMenu;
+ QActionGroup* mpQActionGroup;
void DoFullMenuUpdate(Menu* pMenuBar, QMenu* pParentMenu = nullptr);
static void NativeItemText(OUString& rItemText);
+ QMenu* InsertMenuItem(Qt5MenuItem* pSalMenuItem);
+
public:
Qt5Menu(bool bMenuBar);
virtual ~Qt5Menu() override;
diff --git a/vcl/qt5/Qt5Menu.cxx b/vcl/qt5/Qt5Menu.cxx
index c3228bdd90c0..ed26f31f2761 100644
--- a/vcl/qt5/Qt5Menu.cxx
+++ b/vcl/qt5/Qt5Menu.cxx
@@ -23,6 +23,9 @@ Qt5Menu::Qt5Menu(bool bMenuBar)
, mpParentSalMenu(nullptr)
, mpFrame(nullptr)
, mbMenuBar(bMenuBar)
+ , mpQMenuBar(nullptr)
+ , mpQMenu(nullptr)
+ , mpQActionGroup(nullptr)
{
connect(this, &Qt5Menu::setFrameSignal, this, &Qt5Menu::SetFrame, Qt::BlockingQueuedConnection);
}
@@ -31,6 +34,67 @@ Qt5Menu::~Qt5Menu() { maItems.clear(); }
bool Qt5Menu::VisibleMenuBar() { return true; }
+QMenu* Qt5Menu::InsertMenuItem(Qt5MenuItem* pSalMenuItem)
+{
+ QMenu* pQMenu = mpQMenu;
+ sal_uInt16 nId = pSalMenuItem->mnId;
+ OUString aText = mpVCLMenu->GetItemText(nId);
+ NativeItemText(aText);
+ vcl::KeyCode nAccelKey = mpVCLMenu->GetAccelKey(nId);
+ bool bChecked = mpVCLMenu->IsItemChecked(nId);
+ MenuItemBits itemBits = mpVCLMenu->GetItemBits(nId);
+
+ if (mbMenuBar && mpQMenuBar)
+ // top-level menu
+ pQMenu = mpQMenuBar->addMenu(toQString(aText));
+ else
+ {
+ if (pSalMenuItem->mpSubMenu)
+ {
+ // submenu
+ pQMenu = pQMenu->addMenu(toQString(aText));
+ mpQActionGroup = new QActionGroup(pQMenu);
+ }
+ else
+ {
+ if (pSalMenuItem->mnType == MenuItemType::SEPARATOR)
+ pQMenu->addSeparator();
+ else
+ {
+ // leaf menu
+ QAction* pAction = pQMenu->addAction(toQString(aText));
+ pSalMenuItem->mpAction = pAction;
+ pAction->setShortcut(toQString(nAccelKey.GetName(GetFrame()->GetWindow())));
+
+ if (itemBits & MenuItemBits::CHECKABLE)
+ {
+ pAction->setCheckable(true);
+ pAction->setChecked(bChecked);
+ }
+ else if (itemBits & MenuItemBits::RADIOCHECK)
+ {
+ pAction->setCheckable(true);
+ if (!mpQActionGroup)
+ {
+ mpQActionGroup = new QActionGroup(pQMenu);
+ mpQActionGroup->setExclusive(true);
+ }
+ mpQActionGroup->addAction(pAction);
+ pAction->setChecked(bChecked);
+ }
+
+ pAction->setEnabled(pSalMenuItem->mbEnabled);
+ pAction->setVisible(pSalMenuItem->mbVisible);
+
+ connect(pAction, &QAction::triggered, this,
+ [pSalMenuItem] { slotMenuTriggered(pSalMenuItem); });
+ }
+ }
+ }
+
+ return pQMenu;
+}
+
void Qt5Menu::InsertItem(SalMenuItem* pSalMenuItem, unsigned nPos)
{
SolarMutexGuard aGuard;
@@ -88,70 +152,16 @@ void Qt5Menu::SetFrame(const SalFrame* pFrame)
void Qt5Menu::DoFullMenuUpdate(Menu* pMenuBar, QMenu* pParentMenu)
{
- Menu* pVCLMenu = mpVCLMenu;
+ mpQMenu = pParentMenu;
if (mbMenuBar && mpQMenuBar)
mpQMenuBar->clear();
- QActionGroup* pQAG = nullptr;
+ mpQActionGroup = nullptr;
for (sal_Int32 nItem = 0; nItem < static_cast<sal_Int32>(GetItemCount()); nItem++)
{
Qt5MenuItem* pSalMenuItem = GetItemAtPos(nItem);
- sal_uInt16 nId = pSalMenuItem->mnId;
- OUString aText = pVCLMenu->GetItemText(nId);
- QMenu* pQMenu = pParentMenu;
- NativeItemText(aText);
- vcl::KeyCode nAccelKey = pVCLMenu->GetAccelKey(nId);
- bool bChecked = pVCLMenu->IsItemChecked(nId);
- MenuItemBits itemBits = pVCLMenu->GetItemBits(nId);
-
- if (mbMenuBar && mpQMenuBar)
- // top-level menu
- pQMenu = mpQMenuBar->addMenu(toQString(aText));
- else
- {
- if (pSalMenuItem->mpSubMenu)
- {
- // submenu
- pQMenu = pQMenu->addMenu(toQString(aText));
- pQAG = new QActionGroup(pQMenu);
- }
- else
- {
- if (pSalMenuItem->mnType == MenuItemType::SEPARATOR)
- pQMenu->addSeparator();
- else
- {
- // leaf menu
- QAction* pAction = pQMenu->addAction(toQString(aText));
- pSalMenuItem->mpAction = pAction;
- pAction->setShortcut(toQString(nAccelKey.GetName(GetFrame()->GetWindow())));
-
- if (itemBits & MenuItemBits::CHECKABLE)
- {
- pAction->setCheckable(true);
- pAction->setChecked(bChecked);
- }
- else if (itemBits & MenuItemBits::RADIOCHECK)
- {
- pAction->setCheckable(true);
- if (!pQAG)
- {
- pQAG = new QActionGroup(pQMenu);
- pQAG->setExclusive(true);
- }
- pQAG->addAction(pAction);
- pAction->setChecked(bChecked);
- }
-
- pAction->setEnabled(pSalMenuItem->mbEnabled);
- pAction->setVisible(pSalMenuItem->mbVisible);
-
- connect(pAction, &QAction::triggered, this,
- [pSalMenuItem] { slotMenuTriggered(pSalMenuItem); });
- }
- }
- }
+ QMenu* pQMenu = InsertMenuItem(pSalMenuItem);
if (pSalMenuItem->mpSubMenu != nullptr)
{