qmlscene和Python之间的不同屏幕:工具栏

时间:2019-08-18 20:14:57

标签: python pyqt qml pyqt5 toolbar

当我在PyQt5中使用qml文件时,工具栏出现问题。结果似乎不是:鼠标悬停时没有背景图像,图像没有自动调整大小。

我想知道这是否正常。 如何使用PyQt5获得相同的结果

qmlscene的结果:

enter image description here

Python的结果:

enter image description here

感谢您的帮助。

文件:_test.py


from PyQt5.QtCore import (
    pyqtProperty,
    pyqtSignal,
    pyqtSlot,
    QAbstractListModel,
    QModelIndex,
    QObject,
    Qt,
    QTimer,

)
from PyQt5.QtGui import QGuiApplication
from PyQt5.QtQml import QQmlApplicationEngine
from PyQt5.QtQuick import QQuickView


class MainWindow(QObject):

    def __init__(self, parent=None):
        super().__init__(parent)



if __name__ == "__main__":
    import sys

    app = QGuiApplication(sys.argv) 
    engine = QQmlApplicationEngine()
    engine.quit.connect(app.quit)
    main_window = MainWindow()
    engine.load("_test.qml")
    if not engine.rootObjects():
        sys.exit(app.exec_())

    sys.exit(app.exec())

文件:_test.qml


import QtQuick 2.4
import QtQuick.Layouts 1.1
import QtQuick.Controls 1.3
import QtQuick.Controls.Styles 1.3

ApplicationWindow {
    width: 500
    height: 200
    visible: true

    ToolBar {
        Layout.fillWidth: true

        RowLayout {
            anchors.fill: parent


            ToolButton {
                //width: parent.height
                anchors.margins: 4                  
                iconSource: "ico/abacus.png"
            }

            ToolButton {
                width: parent.height
                Image {
                    source: "ico/quitter.png"
                    anchors.fill: parent
                    anchors.margins: 4
                }                   
            }

            ToolButton {
                width: parent.height
                iconSource: "ico/start.png"
                anchors.margins: 4
            }

            ToolButton {
                width: parent.height
                Image {
                    source: "ico/stop.png"
                    anchors.fill: parent
                    anchors.margins: 4
                }                   
            }
        }
    }
}

1 个答案:

答案 0 :(得分:2)

分析qmlscene的source code并使用--apptype选项进行测试,我得到以下信息:

qmlscene _test.qml --apptype gui

enter image description here

qmlscene _test.qml --apptype widgets

enter image description here

因此,分析根本差异是正在使用QApplicacion而不是QGuiApplication,因此在内部应激活一些缩放图标的标志。

考虑到上述情况,解决方案是:

from PyQt5.QtCore import QUrl
from PyQt5.QtWidgets import QApplication
from PyQt5.QtQml import QQmlApplicationEngine


if __name__ == "__main__":
    import os
    import sys

    app = QApplication(sys.argv)

    engine = QQmlApplicationEngine()
    current_dir = os.path.dirname(os.path.realpath(__file__))
    file = os.path.join(current_dir, "_test.qml")
    engine.load(QUrl.fromLocalFile(file))
    if not engine.rootObjects():
        sys.exit(-1)
    sys.exit(app.exec_())

根据Qt Quick Controls 1的the docs

  

注意:我们在此使用的是QApplication而不是QGuiApplication   例。尽管您可以改用QGuiApplication,但是这样做   消除依赖平台的样式。这是因为它依赖   小部件模块以提供原始的外观。

因此,图标的缩放似乎是平台样式的一部分。


每种类型的项目都需要一个QXApplication:

  • 控制台应用程序:您可以使用3种类型的QXApplication中的任何一种,但是使用QCoreApplication是最佳选择,因为其他QXApplication要求它们具有在这种情况下不必要的窗口系统。

  • QML应用程序:它至少需要一个QGuiApplication,但是对于某些特定需求,例如需要使用每个平台的样式,则必须使用QApplication。

  • Qt Widgets应用程序:QApplication是必需的,因为QWidgets使用每个平台的样式。


大小会改变,这是QtQuick.Controls 1的问题吗?

是的,QQC1和QQC2之间的主要区别之一是第一个被开发为支持桌面平台,因此您可以使用样式,而第二个则是为嵌入式系统设计的,其主要目标是性能。有关更多信息,请阅读Differences with Qt Quick Controls 1


结论:

  • 如果希望使用QML制作的GUI尊重桌面平台的样式,则必须将QQC1与QApplication一起使用。

  • 如果您的目标是您的应用程序样式除了希望获得更高的性能之外,还不尊重桌面样式,则应将QQC2与QGuiApplication结合使用。

相关问题