Come modificare l' .qml estensione di un .interfaccia utente per l'uso in pyqt5 applicazione

0

Domanda

Creare il design del mio app con qt designer e quindi trasformare ogni finestra di un file python utilizzando il comando pyuic5 esempio.ui -o example.py in grado di ottenere un Ui_Form classe e chiamare nel mio programma. Così ogni cosa è al lavoro, ma ora abbiamo cambiato il nostro disegno e si ottiene un file qml. La mia domanda è come lavorare con questo file qml senza cambiare i concetti di app. C'è un metodo come il pyuic5 (per ottenere il Ui_Form classe) per trasformare il qml e utilizzare in pyqt5.

Questo è un esempio della vecchia app:

from main_screen import Ui_Form as Ui_main_screen
class MainScreen(QWidget, Ui_main_screen):
    teachButton = False
    manageButton = False
    utilitiesButton = False
    adminButton = False
    helpButton = False
    systemButton = False
    inspectionButton = False
    modelSelected = None
    def __init__(self):
        super(MainScreen, self).__init__()
        #QWidget.__init__(self)
        self.setupUi(self)
        self.trans = QTranslator(self)

        self.toLanguage()
        self.product()
        self.Menu() .....

Come potete vedere, ho importato il Ui_Form in MainScreen classe. Ora voglio fare lo stesso con il file qml

import QtQuick 2.7
Item {
    width:904
    height:678
    Image {
        id: background
        source: "images/background.png"
        x: 0
        y: 1
        opacity: 1
    }
    Image {
        id: logo
        source: "images/logo.png"
        x: 691
        y: 34
        opacity: 1
    }
    Image {
        id: teach
        source: "images/teach.png"
        x: 717
        y: 154
        opacity: 1
    }
    Image {
        id: administration
        source: "images/administration.png"
        x: 711
        y: 410
        opacity: 0.49803921568627
    }
    Image {
        id: system
        source: "images/system.png"
        x: 708
        y: 468
        opacity: 0.49803921568627
    }
    Image {
        id: utilities
        source: "images/utilities.png"
        x: 711
        y: 353
        opacity: 0.49803921568627
    }
    Image {
        id: help
        source: "images/help.png"
        x: 712
        y: 524
        opacity: 0.49803921568627
    }
    Image {
        id: teachinf_wizard
        source: "images/teachinf_wizard.png"
        x: 740
        y: 196
        opacity: 1
    }
    Image {
        id: inspection
        source: "images/inspection.png"
        x: 713
        y: 295
        opacity: 0.49803921568627
    }
    Image {
        id: manage
        source: "images/manage.png"
        x: 714
        y: 239
        opacity: 1
    }
}

Così come ottenere qualcosa di simile Ui_Form classe con file qml

pyqt5 python qml
2021-11-12 10:19:15
1

Migliore risposta

2

Risposta Breve:

No, non può essere fatto.

Risposta Lunga:

L' .ui sono solo un insieme di istruzioni su come i qwidgets deve essere visualizzato, invece, qml è un linguaggio di programmazione, dal momento che indicano come gli oggetti interagiscono.

La cosa più vicina a ciò che si desidera essere in grado di incorporare la qml in un QWidget, utilizzando, ad esempio, QQuickWidget:

import os
import sys
import os
from pathlib import Path


from PyQt5.QtCore import QUrl
from PyQt5.QtWidgets import QApplication
from PyQt5.QtQuickWidgets import QQuickWidget


CURRENT_DIRECTORY = Path(__file__).resolve().parent


def main():

    app = QApplication(sys.argv)

    widget = QQuickWidget(resizeMode=QQuickWidget.ResizeMode.SizeRootObjectToView)
    filename = os.fspath(CURRENT_DIRECTORY / "main.qml")
    url = QUrl.fromLocalFile(filename)
    widget.setSource(url)
    widget.show()

    sys.exit(app.exec_())


if __name__ == "__main__":
    main()
2021-11-12 23:10:07

In altre lingue

Questa pagina è in altre lingue

Русский
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................