1、brew安装pyqt5,全局环境
/bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)" source /Users/xxx/.zprofile 这条指令在上一条指令执行结束会有提示brew install pyqt@5 ,这条指令执行结束,会有额外的python 3.9版本 (也是本次遇到的问题)
2、python3.10 下载
3、下载pycharm
4、学习使用pyqt5
QMainWindow , 继承了QWidget,增添了toolbar 扩展功能等等。 QWidget , 面板 QDialog,对话框,主要是一些提示框,有“人机交互”的作用
if __name__ == '__main__':
app = QApplication(sys.argv)
w = QWidget()
w.resize(250, 150)
w.move(300, 300)
w.setWindowTitle('Simple')
w.show()
sys.exit(app.exec_())
class PromptText(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
QToolTip.setFont(QFont('SansSerif', 10))
self.setToolTip('This is a <b>QWidget</b> widget')
btn = QPushButton('Button', self)
btn.setToolTip('This is a <b>QPushButton</b> widget')
btn.resize(btn.sizeHint())
btn.move(300, 100)
self.setGeometry(300, 100, 600, 600)
self.setWindowTitle('Tooltips')
self.show()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = PromptText()
sys.exit(app.exec_())
class CloseW(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
qbtn = QPushButton('Quit', self)
qbtn.clicked.connect(QCoreApplication.instance().quit)
qbtn.resize(qbtn.sizeHint())
qbtn.move(500, 50)
self.setGeometry(300, 100, 600, 600)
self.setWindowTitle('excise')
self.show()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = CloseW()
sys.exit(app.exec_())
信号:需要明确 发送者和 接收者是哪个
class MessageBox(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
qbtn = QPushButton('Quit', self)
qbtn.clicked.connect(QCoreApplication.instance().quit)
qbtn.resize(qbtn.sizeHint())
qbtn.move(500, 50)
self.setGeometry(300, 100, 600, 600)
self.setWindowTitle('excise')
self.show()
def closeEvent(self, event):
reply = QMessageBox.question(self, 'Message',
"Are you sure to quit?", QMessageBox.Yes |
QMessageBox.No, QMessageBox.No)
if reply == QMessageBox.Yes:
event.accept()
else:
event.ignore()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = MessageBox()
sys.exit(app.exec_())
主要是这个statusBar 类中方法的使用
class StatusBar(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.statusBar().showMessage('Ready')
self.setGeometry(300, 300, 250, 150)
self.setWindowTitle('Statusbar')
self.show()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = StatusBar()
sys.exit(app.exec_())
class ToolBar(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
exitAction = QAction('Exit', self)
exitAction.setShortcut('Ctrl+Z')
exitAction.triggered.connect(qApp.quit)
self.toolbar = self.addToolBar('Exit')
self.toolbar.addAction(exitAction)
self.setGeometry(300, 300, 300, 200)
self.setWindowTitle('Toolbar')
self.show()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = ToolBar()
sys.exit(app.exec_())
- 注意:mac里的菜单栏会显示在mac的上方
- menubar.setNativeMenuBar(False),可以让菜单显示在窗口,但有点儿丑
- Mac中的pyqt5 的菜单使用 需要 配备QAction 这个类,否则显示不出菜单
import sys
from PyQt5.QtWidgets import QMainWindow, QAction, QMenu, QApplication
class Example(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
menubar = self.menuBar()
fileMenu = menubar.addMenu('file')
exitMenu = menubar.addMenu('edit')
impMenu = QMenu('a', self)
impAct = QAction('a-b', self)
impMenu.addAction(impAct)
newAct = QAction('b', self)
fileMenu.addAction(newAct)
fileMenu.addMenu(impMenu)
exitAct = QAction('g', self)
exitMenu.addAction(exitAct)
self.setGeometry(300, 300, 300, 200)
self.setWindowTitle('Submenu')
self.show()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())
6、参考博客
|