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

我想知道这是否正常。
我如何做与PyQt5具有相同的结果

qmlscene的结果:



使用Python的结果:



感谢您的帮助。

档案:_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
                }
            }
        }
    }
}

最佳答案

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

qmlscene _test.qml --apptype gui


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

qmlscene _test.qml --apptype widgets


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

因此,分析根本差异是正在使用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的the docs


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


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



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


控制台应用程序:可以使用三种类型的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结合使用。

10-07 15:07