大家關注的教程2來了蚌父。
第一期是代碼布局椎组,現(xiàn)在有更高級的布局方式,那就是Qt5健霹,布局完UI可以用PythonUIC命令轉(zhuǎn)成py文件凡傅,添加import
和
app = QApplication(sys.argv)
widget = QMainWindow(None)
Ui_MainWindow().setupUi(widget)
sys.exit(app.exec_())
pass
1.登陸界面
2.一個QTproject新建多個視圖
3.在窗體中打開新窗體
4.安裝QT
1.登陸
用QT可視化編程拖出來的界面就是這個樣子,用命令pyuic5 -o target.py fromfile.ui
轉(zhuǎn)化成py文件肠缔,代碼如下
登陸
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'mainwindow.ui'
#
# Created by: PyQt5 UI code generator 5.10.1
#
# WARNING! All changes made in this file will be lost!
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018/5/9 下午1:36
# @Author : fgyong 簡書:_兜兜轉(zhuǎn)轉(zhuǎn)_ http://www.reibang.com/u/6d1254c1d145
# @Site : http://fgyong.cn 兜兜轉(zhuǎn)轉(zhuǎn)的技術博客
# @File : *.py
# @Software: PyCharm
from PyQt5 import QtCore, QtGui, QtWidgets
import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
MainWindow.setObjectName("MainWindow")
MainWindow.resize(500, 341)
MainWindow.move(1500,300)
MainWindow.setWindowOpacity(1.0)
MainWindow.setAutoFillBackground(True)
self.centralWidget = QtWidgets.QWidget(MainWindow)
self.centralWidget.setObjectName("centralWidget")
self.accountLabel = QtWidgets.QLabel(self.centralWidget)
self.accountLabel.setGeometry(QtCore.QRect(80, 110, 60, 21))
self.accountLabel.setAlignment(QtCore.Qt.AlignCenter)
self.accountLabel.setObjectName("accountLabel")
self.pwdLabel = QtWidgets.QLabel(self.centralWidget)
self.pwdLabel.setGeometry(QtCore.QRect(80, 150, 60, 21))
self.pwdLabel.setAlignment(QtCore.Qt.AlignCenter)
self.pwdLabel.setObjectName("pwdLabel")
self.account = QtWidgets.QLineEdit(self.centralWidget)
self.account.setGeometry(QtCore.QRect(140, 110, 191, 21))
self.account.setObjectName("account")
self.password = QtWidgets.QLineEdit(self.centralWidget)
self.password.setGeometry(QtCore.QRect(140, 150, 191, 21))
self.password.setObjectName("password")
self.pushButton = QtWidgets.QPushButton(self.centralWidget)
self.pushButton.setGeometry(QtCore.QRect(140, 191, 201, 41))
self.pushButton.setObjectName("pushButton")
MainWindow.setCentralWidget(self.centralWidget)
self.menuBar = QtWidgets.QMenuBar(MainWindow)
self.menuBar.setGeometry(QtCore.QRect(0, 0, 500, 22))
self.menuBar.setFocusPolicy(QtCore.Qt.ClickFocus)
self.menuBar.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
self.menuBar.setInputMethodHints(QtCore.Qt.ImhNone)
self.menuBar.setObjectName("menuBar")
MainWindow.setMenuBar(self.menuBar)
self.statusBar = QtWidgets.QStatusBar(MainWindow)
self.statusBar.setObjectName("statusBar")
MainWindow.setStatusBar(self.statusBar)
self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)
MainWindow.show()
def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate("MainWindow", "登陸"))
self.accountLabel.setText(_translate("MainWindow", "賬號"))
self.pwdLabel.setText(_translate("MainWindow", "密碼"))
self.pushButton.setText(_translate("MainWindow", "登陸"))
if __name__ == '__main__':
app = QApplication(sys.argv)
widget = QMainWindow(None)
Ui_MainWindow().setupUi(widget)
sys.exit(app.exec_())
pass
2.一個QTproject新建多個視圖
如圖:
新建UI
然后在源文件->main.cpp 導入類夏跷,
#include "mainwindow.h"
#include "dialog.h"http://新建的文件
#include <QApplication>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;//默認的文件
Dialog d;//新建的文件
// w.show();//默認的注釋掉
d.show();//新建的文件show
return a.exec();
}
然后選擇新建的 Dialog.ui文件點擊運行按鈕,運行的就是Dialog視圖
4.在窗體中打開新窗體
class Example(QMainWindow):
def __init__(self):
super().__init__()
self.initGUI();
#這一句比較關鍵明未,先聲明這個窗體2等到需要show的時候在展示出來槽华。
self.child = Exaple2()
def initGUI(self):
btn = QPushButton('打開窗體', self)
btn.setToolTip('這是個btn')
btn.resize(btn.sizeHint())
btn.clicked.connect(self.showSecond)
def showSecond(self):
self.child.show()
#第二個窗口
class Exaple2(QWidget):
def __init__(self):
super().__init__()
self.configUI()
def configUI(self):
self.lable = QLabel('我是第二個窗體', self)
self.lable.setWordWrap(True) # 自動換行
#設置frame
self.lable.setGeometry(50, 100, 200, 50)
#設置新窗體frame
self.setGeometry(500,500,300,300);
4.安裝QT
下載QT5.*
下載QT5
因為下載的dmg直接點下一步下一步安裝完成
QT的官方Demo
5.新建工程
1.第一步
第一步
2.第二步
第二步
3.第三步
image.png
4.第四步 拖拽控件
image.png
5.點擊運行
image.png
6.效果圖
image.png