summaryrefslogtreecommitdiff
path: root/src/controls/qquickmenubar.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/controls/qquickmenubar.cpp')
-rw-r--r--src/controls/qquickmenubar.cpp19
1 files changed, 16 insertions, 3 deletions
diff --git a/src/controls/qquickmenubar.cpp b/src/controls/qquickmenubar.cpp
index daf647dc..d3503f89 100644
--- a/src/controls/qquickmenubar.cpp
+++ b/src/controls/qquickmenubar.cpp
@@ -63,9 +63,8 @@ QT_BEGIN_NAMESPACE
*/
QQuickMenuBar::QQuickMenuBar(QObject *parent)
- : QObject(parent), m_contentItem(0), m_parentWindow(0)
+ : QObject(parent), m_platformMenuBar(0), m_contentItem(0), m_parentWindow(0)
{
- m_platformMenuBar = QGuiApplicationPrivate::platformTheme()->createPlatformMenuBar();
}
QQuickMenuBar::~QQuickMenuBar()
@@ -77,11 +76,25 @@ QQmlListProperty<QQuickMenu> QQuickMenuBar::menus()
return QQmlListProperty<QQuickMenu>(this, 0, &QQuickMenuBar::append_menu, &QQuickMenuBar::count_menu, &QQuickMenuBar::at_menu, 0);
}
-bool QQuickMenuBar::isNative()
+bool QQuickMenuBar::isNative() const
{
return m_platformMenuBar != 0;
}
+void QQuickMenuBar::setNative(bool native)
+{
+ bool wasNative = isNative();
+ if (native) {
+ if (!m_platformMenuBar)
+ m_platformMenuBar = QGuiApplicationPrivate::platformTheme()->createPlatformMenuBar();
+ } else {
+ delete m_platformMenuBar;
+ m_platformMenuBar = 0;
+ }
+ if (isNative() != wasNative)
+ emit nativeChanged();
+}
+
void QQuickMenuBar::setContentItem(QQuickItem *item)
{
if (item != m_contentItem) {