PyQt5学习例子整理

基本框架

# PyQt5引入的组件其实只需要QtWidgets、QApplication就可以实现最基本的窗体显示
# 还需要引入sys作为窗体应用进程的控制
from PyQt5.QtWidgets import QApplication,QWidget,QHBoxLayout,QLineEdit,QPushButton
import sys

class TemplateForm(QWidget):
    def __init__(self):
        super().__init__()

        hlayout=QHBoxLayout()
        self.setLayout(hlayout)
        lineEdit=QLineEdit()
        lineEdit.setText('Hello,world!')
        button=QPushButton()
        button.setText('Please press me!')
        button.clicked.connect(self.close)
        hlayout.addWidget(lineEdit,1)
        hlayout.addWidget(button,2)

# Press the green button in the gutter to run the script.
if __name__ == '__main__':
    app=QApplication(sys.argv)
    form=TemplateForm()
    form.show()
    app.exit(app.exec_())

基本组件使用

  • QMainWindow
  • QWidget
from PyQt5.QtCore import Qt
# 设置窗口背景透明
mywin.setAttribute(Qt.WA_TranslucentBackground)
#  隐藏窗口边框
mywin.setWindowFlags(Qt.FramelessWindowHint)
# 设置窗口边框带阴影
from PyQt5.QtWidgets import QGraphicsDropShadowEffect
effect=QGraphicsDropShadowEffect(self)
effect.setBlurRadius(12) # 设置阴影画笔强度
effect.setOffset(0,0)
effect.setColor(Qt.gray)
mywin.setGraphicsEffect(effect)

在隐藏窗体边框后鼠标不能拖动窗体,需要重写鼠标事件,首先为窗体设置一个变量m_Drag判断鼠标左键是否按下。

# 在窗体类里定义m_Drag
def __init__(self):
    super().__init__()
    self.m_Drag=False

#  重写鼠标事件
"""重写隐藏边框后的鼠标事件,因为隐藏边框后不能移动窗体"""
def mousePressEvent(self, event):
    if event.button() == Qt.LeftButton:
        self.m_Drag = True
        # event.globalPos()是鼠标当前点击位置相对于电脑桌面左上角的坐标
        # self.pos()是当前窗体相对于电脑桌面左上角的坐标
        self.m_DragPosition = event.globalPos() - self.pos()
        # 将拖动时鼠标的光标形状变成小手
        self.setCursor(QCursor(Qt.OpenHandCursor))

def mouseMoveEvent(self, event):
    # 只有单击鼠标左键才能移动
    if Qt.LeftButton and self.m_Drag:
        # move(QPoint()),是将窗体移动到某一点
        self.move(event.globalPos() - self.m_DragPosition)

def mouseReleaseEvent(self, event):
    self.m_Drag = False
    self.setCursor(QCursor(Qt.ArrowCursor))
  • QPushButton
    按键用得最多的就是“单击事件”:
def myfunc():
    pass

button=QPushButton()
button.clicked.connect(myfunc)
# 如果自定义函数是带参数的,使用lambda表达式
button.clicked.connect(lambda : myfunc(parm1,parm2...))

然后就是对QPushButton的QSS装饰(QSS代码):

/*QPushButton的正常样式*/
QPushButton{
    width:100px;
    height:25px;
    background-color:#FFFFFF;
    /*设置圆角*/
    border:1px solid #00CCCC;
    border-radius:5px;
    color:#000000;
}
# 当鼠标悬浮在QPushButton时的样式
QPushButton:hover{
    background-color:#00CCFF;
    color:#888888;
}
# 单击QPushButton时的样式
QPushButton:pressed{
    background-color:red;
    color:black;
}

第二就是如何使用QPushButton控件做一个圆形的logo,主要还是qss的修饰:

from PyQt5.QtWidgets import QApplication,QWidget,QPushButton,QHBoxLayout,QGraphicsDropShadowEffect
from PyQt5.Qt import Qt # 使用Qt里的颜色
import sys

qssStyleSheet='''
    QPushButton {
        /*限制最小最大尺寸*/
        min-width: 96px;
        max-width: 96px;
        min-height: 96px;
        max-height: 96px;
        border-radius: 48px; /*圆形*/
        border:none;
        background:white;
        /* 设置按钮的背景图片 */
        border-image:url(./backgroundimg2.png);
    }
'''

class MyLogoButtonForm(QWidget):
    def __init__(self):
        super(MyLogoButtonForm, self).__init__()

        self.myButton=QPushButton()
        hlayout=QHBoxLayout()
        hlayout.addWidget(self.myButton)
        self.setLayout(hlayout)

        # 为按钮周边设置阴影
        logoShadow=QGraphicsDropShadowEffect(self) # 这里的self是当前按钮的父控件,不一定是self
        logoShadow.setBlurRadius(8)
        logoShadow.setOffset(0,0)
        logoShadow.setColor(Qt.gray)
        self.myButton.setGraphicsEffect(logoShadow)

        self.setStyleSheet(qssStyleSheet)

if __name__ == '__main__':
    app=QApplication(sys.argv)
    myform=MyLogoButtonForm()
    myform.show()
    sys.exit(app.exec_())

在这里插入图片描述
第三是将按键设置成那种带小图标的样式:

# 在上述例子中引入QIcon和QPixmap
from PyQt5.QtGui import QIcon,QPixmap # 设置一个图标样式的按钮
# 为按钮准备一个小图标
icon=QIcon()
# 用QPixmap为按键添加图标图片
icon.addPixmap(QPixmap('./searchIcon48.png'),QIcon.Normal,QIcon.Off)
self.myBtn2=QPushButton()
self.myBtn2.setObjectName('searchpushButton')
self.myBtn2.setIcon(icon)
# 还要将按钮文本设为空字符串
self.myBtn2.setText('')

然后按照惯例修饰一下按钮(QSS代码)

QPushButton#searchpushButton{
width:60px;
height:25px;
background-color:#FFFFFF;
border:1px solid #00CCCC;
border-radius:5px;
color:#000000;
}
QPushButton#searchpushButton:hover{
    background-color:#00CCFF;
    color:#888888;
}

在这里插入图片描述

  • QLineEdit
    单行文本输入框我只使用了其获取文本的功能/设置提示文本功能/设置掩码(密码输入)功能,至于还有什么骚操作有待探索。
# 单行文本框获取文本的方法
myLineEdit=QlineEdit()
textstr=myLineEdit.text()
# 设置文本框为掩码模式,输入密码是是黑点
textstr.setEchoMode(QLineEdit.Password)
# 设置提示文本
textstr.setPlaceholderText("你想要的提示文本")
  • QProgressBar—进度条
    进度条的使用是动态的,进度值是在后台不断变化的,这就需要我们在使用时进度条时引入线程,不然界面在进度条动态变化时可能会“假死”。
    首先,来看如何创建进度条:
# 首先来看如何创建进度条,先引入需要的组件
from PyQt5.QtWidgets import QApplication,QWidget,QProgressBar,QHBoxLayout
import sys
class ProgressBarForm(QWidget):
    def __init__(self):
        super(ProgressBarForm, self).__init__()
        self.myprogressbar=QProgressBar()
        hlayout=QHBoxLayout()
        hlayout.addWidget(self.myprogressbar)
        self.setLayout(hlayout)

if __name__ =='__main__':
    app=QApplication(sys.argv)
    myform=ProgressBarForm()
    myform.show()
    myform.setProgressBarValue()
    sys.exit(app.exec_())

这样的进度条是不会动的,要使进度条的进度值显示动态变化,引入线程:
为了实现目的,我们需要增加三样东西:
1.线程ProgressBarThread,其中使用了Qt的signal-slot机制,在线程中改变进度条的值,再用信号signal绑定回调函数slot,使用信号将进度条的进度值传递给回调函数(通知)。
2.回调函数setProgressBarValue_CallBack,接收信号传递来的进度值,然后更新进度条显示的进度值。
3.控制函数setProgressBarValue,创建线程对象、将线程中的信号signal和回调函数slot绑定起来、启动线程。

from PyQt5.QtWidgets import QApplication,QWidget,QProgressBar,QHBoxLayout
# 引入线程使得进度条值在后台自动变化
from PyQt5.QtCore import QThread,pyqtSignal
import sys
import time # 用于停止线程

class ProgressBarThread(QThread):
    '''
    线程,用于控制进度条的进度值
    '''
    triggerSignal=pyqtSignal(int)

    def __init__(self):
        super(ProgressBarThread, self).__init__()

    def run(self):
        num=1
        while num<100:
            self.triggerSignal.emit(num)
            time.sleep(1)
            num+=1

class ProgressBarForm(QWidget):
    def __init__(self):
        super(ProgressBarForm, self).__init__()
        self.myProgressBar=QProgressBar()
        hlayout=QHBoxLayout()
        hlayout.addWidget(self.myProgressBar)
        self.setLayout(hlayout)

    def setProgressBarValue(self):
        self.myThread=ProgressBarThread()
        self.myThread.triggerSignal.connect(self.setProgressBarValue_CallBack)
        self.myThread.start()

    def setProgressBarValue_CallBack(self,ivalue):
        self.myProgressBar.setValue(ivalue)

if __name__ =='__main__':
    app=QApplication(sys.argv)
    myform=ProgressBarForm()
    myform.show()
    myform.setProgressBarValue()
    sys.exit(app.exec_())

第三是来看看进度条如何美化(QSS代码):

qssStyleSheet='''
    /* 设置进度条的三种样式 */
    #RedProgressBar {
        /* 进度值居中 */
        text-align:center;
    }
    #RedProgressBar::chunk {
        /* 设置进度条里进度值显示的栅栏格子样式 */
        background-color:#F44336;
    }
    #GreenProgressBar {
        min-height: 12px;
        max-height: 12px;
        border-radius: 6px;
    }
    #GreenProgressBar::chunk {
        /* 设置进度条里进度值显示的栅栏格子样式 */
        background-color:#009688;
        border-radius: 6px;
    }
    #BlueProgressBar {
        text-align:center;
        /* 设置进度条边框及其颜色 */
        border: 2px solid #00CCCC;
        /* 设置圆角 */
        border-radius: 5px;
        background-color:#FFFFFF;
    }
    #BlueProgressBar::chunk {
        /* 设置进度条里进度值显示的栅栏格子样式 */
        background-color:#00CCCC;
        width: 5px;
        margin: 0.5px;
    }
'''

在这里插入图片描述

  • QThread—Qt线程
    在进度条使用例子里,就是我第一次接触QThread,主要思路就是创建一个自己的类继承QThread,然后自定义线程类的run函数即可。
from PyQt5.QtCore import QThread
class MyThread(QThread):
    def __init__(self):
        super(MyThread,self).__init__()
    
    def run(self):
        # 自定义的功能函数
  • QTableWidget—QT表格控件
    QTableWidget主要包括:
    水平表头、垂直表头
    表格行、列
    单元格

如何使用表格,主要包括:
先看modifierTableWidget里如何设置表格
再看如何往表格里添加内容,包括添加文本、添加控件
然后是如何删除表格的内容、如何清空表格内容
最后是如何美化表格(qss)

from PyQt5.QtWidgets import QApplication,QWidget,QHBoxLayout,QPushButton,\
    QTableWidget,QAbstractItemView,QHeaderView,QTableWidgetItem
from PyQt5.Qt import Qt
import sys

class MyTableWidget(QWidget):
    def __init__(self):
        super(MyTableWidget, self).__init__()
        hlayout=QHBoxLayout()
        self.tableWidget=QTableWidget()
        # 设置表格属性
        self.modifierTableWidget()

        # 为表格添加点内容
        btnStr='Hello,world!'
        btn=QPushButton(btnStr)
        btn1=QPushButton(btnStr)
        # 在表格添加文本
        textItem=QTableWidgetItem('I am super man!')
        # self.tableWidget.insertRow(0)  # 增加第一行
        self.tableWidget.setItem(0,0,textItem)
        # 在表格添加控件
        # self.tableWidget.insertRow(1) # 增加第一行
        self.tableWidget.setCellWidget(1,0,btn) # 在第一行、第一列放置按钮
        # self.tableWidget.insertRow(2) # 增加第二行
        self.tableWidget.setCellWidget(2,1,btn1) # 在第二行、第一列放置按钮
        # 删除表格内容
        # self.tableWidget.removeCellWidget(1,0) # 删除表格中第二行第一列的内容
        # self.tableWidget.removeColumn(1) # 删除表格的某一列
        # self.tableWidget.removeRow(1) # 删除表格的某一行
        # self.tableWidget.takeItem(1,0) # 这个也是删除某行某列的内容,但好像不起作用
        # 获取单击按钮所在的表格行位置
        rowIndex=self.tableWidget.indexAt(btn.pos()).row() # 这里好像返回的都是0,没搞清楚
        print(rowIndex)

        # 清空表格内容
        # self.tableWidget.clear()
        # self.tableWidget.clearContents()
        # self.tableWidget.setRowCount(0)

        hlayout.addWidget(self.tableWidget)
        self.setLayout(hlayout)

        self.setStyleSheet(qssStyleSheet)

    def modifierTableWidget(self):
        self.tableWidget.setRowCount(5) # 设置行数,设置了行数就不需要用insertRow
        self.tableWidget.setColumnCount(2) # 设置表格列数
        self.tableWidget.setEditTriggers(QAbstractItemView.NoEditTriggers) # 禁止编辑
        self.tableWidget.setSelectionBehavior(QAbstractItemView.SelectRows) # 整行选中
        self.tableWidget.horizontalHeader().setVisible(False) # 设置水平表头不可见
        self.tableWidget.verticalHeader().setVisible(True) # 设置垂直表头可见
        # self.tableWidget.verticalHeader().setSectionResizeMode(QHeaderView.Stretch) # 设置行高根据内容伸缩
        self.tableWidget.verticalHeader().setSectionResizeMode(QHeaderView.Fixed) # 设置行高固定
        self.tableWidget.verticalHeader().setDefaultSectionSize(
            int(self.tableWidget.height() / 7)
        ) # 设置每一行的默认高度
        self.tableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch) # 设置列根据内容伸缩
        # self.mywidget.tableWidget.setFrameStyle(QFrame.NoFrame) # 去掉边框
        self.tableWidget.setShowGrid(False) # 去掉单元格虚线
        self.tableWidget.setVerticalScrollBarPolicy(Qt.ScrollBarAsNeeded) # 设置滚动条
        self.tableWidget.setVerticalHeaderLabels(['header1','header2']) # 设置垂直表头内容

if __name__ == '__main__':
    app=QApplication(sys.argv)
    myform=MyTableWidget()
    myform.show()
    sys.exit(app.exec_())

在这里插入图片描述

  • QDateEdit/QDateTimeEdit
from PyQt5.QtWidgets import QApplication,QWidget,QHBoxLayout,QDateEdit,QDateTimeEdit
from PyQt5.QtCore import QDate,QTime,QDateTime
import sys

class MyDateEditForm(QWidget):
    def __init__(self):
        super(MyDateEditForm, self).__init__()
        hlayout=QHBoxLayout()
        self.dateEdit=QDateEdit()
        self.dateTimeEdit=QDateTimeEdit()

        # 设置日期控件为日历
        self.dateEdit.setCalendarPopup(True)
        # 设置日期控件显示为当前时间
        self.dateEdit.setDate(QDate.currentDate())
        # 设置时间控件显示的时间格式为“yy-mm-dd"
        self.dateEdit.setDisplayFormat("yyyy-MM-dd")

        # 设置日期控件为日历
        self.dateTimeEdit.setCalendarPopup(True)
        # 设置日期控件显示为当前时间
        self.dateTimeEdit.setDate(QDate.currentDate())
        self.dateTimeEdit.setTime(QTime.currentTime())
        self.dateTimeEdit.setDateTime(QDateTime.currentDateTime())
        # 设置时间控件显示的时间格式为“yy-mm-dd"
        self.dateTimeEdit.setDisplayFormat("yyyy-MM-dd hh:mm:ss")

        # 获取控件时间的方法
        time1=self.dateEdit.date()
        print(time1)
        time2=self.dateTimeEdit.time().hour()
        print(time2)

        hlayout.addWidget(self.dateEdit)
        hlayout.addWidget(self.dateTimeEdit)
        self.setLayout(hlayout)

if __name__ =='__main__':
    app=QApplication(sys.argv)
    myform=MyDateEditForm()
    myform.show()
    sys.exit(app.exec_())

结语

好了,懒懒的自己将毕设的东西慢慢整理出来,走出校园,走进职场,只能慢慢努力了,做一个热爱编程的人。
—偷得浮生半日闲,又摘桃花换酒钱!

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pyqt4精彩实例讲解,适合pyqt4初级学习者,经供参考第6行创建了一个 QPush Button对象,并设置它的显示文木为“ Hello Kitty!",由于此处并 没有指定按钮的父窗体,因此以自己作为主窗凵 第7行调用show()方法,显示此按钮。控件被创建时,默认是不显示的,必须调用show() 区数来显示它。 第8行的 connect方法是αt最重要的特征,即信号与槽的机制。当按钮被按下则触发 clicked 信号,与之相连的 APplication对象的槽quit(响应按钮单击信号,执行退出应用程序的操 作。关于信号与槽机制在本实例最后将进行详细的分析。 最后调用 APplication的exec()方法,程序进入消息循环,等待可能输入进行响应。Qt 完成事件处理及显示的工作,并在应用程序退出时返叫exec_Q)的值 最后执行程序即可出现上图所示的对话框,一个简单的 Hello Kitty!例子完成。 信号与槽机制作为αt最重要的特性,提供了任意两个Qt对象之间的通信机制。其中,信 号会在某个特定情况或动作下被触发,槽是用于接收并处理信号的函数。例如,要将一个窗 口中的变化情况通知给另一个窗口,则一个窗口发送信号,另一个窗口的槽接收此信号并进 行相应的操作,即可实现两个窗∏之间的通信。这比传统的图形化程序采用回调函数的方式 实现对象间通信要简单灵活得多。每个Qt对象都包含预定的信号和槽,当一某一特定事件 发生时,一个信号被发射,与信号相关联的槽则会响应信号完成相应的处理。 信号与槽机制常用的连接方式为 connect(Object1, SIGNAL(signal), Object2, SLOT (slot) signal|为对象 Object1的信号,sot为对象 Object2的槽,Qt的窗口部件都包含若十个预定 义的信号和若干个预定乂的槽。当一个类被继承时,该类的信号和槽也同时被继承。开始人 也可以根据需要定义自己的信号和槽。 信号与槽机制可以有多种连接方式,下图描述了信号与槽的多种可能连接方式。 Object 1 Object 2 signal 1 si巴nall signal 2 SeFa 2 slot 1 slot 1 lot 2 Object 3 signal 2 slot 1 slot 2 个信号可以与另一个信号相连 connect(object1, SIGNAL(signal1),Object2, SIGNAL(signal 1)) 即表示 Object11的信号1发射可以触发 Object2的信号1发射 2.表示一个信号可以与多个槽相连 connect(Object1, SIGNAL(signal2), Object2, SLOT(slot2)) connect(object1, SIGNAL(signal2), Object3. SLOT(slot1) 3表示同一个槽可以响应多个信号 connect(object1, SIGNAL(signal2), Object2, SLOT(slot2)) connect(object3, SIGNAL(signal2),object2, SLOT (slot2)) 注:本文基本上是经过改编的《 Linux窗口程序设计-Qt4精彩实例分析》一书的PyQt4for windows版本 可以这么写: b clicked. connect( app. quit) 这样就少了一些 hardcode的字符串了,更加 pythonic 实例2标准对话框的使用 分类:-PyQ42010-12-0310:342105人阅读评论(2)收藏举报 和人多数操作系统一样, Windows及Linuⅹ都提供了一系列的标准对话框,如文件选择, 字体选择,颜色选择等,这些标准对话框为应用程序提供了一致的观感。Qt对这些标准对 话框都定义了相关的类,这些类让使用者能够很方便地使用标准对话框进行文件,颜色以及 字体的选择。标准对话框在软件设计过程中是经常需要使用的。 αt提供的标准对话框除了本实例提到的,还有 QErrorMessage, QInputDialog, QMessage Box, QPrintDialog, QProcess Dialog等,这些标准对话框的使用在本书的后续 部分将会陆续介绍。 本实例主要演示上面几种标准对话框的使用,如下图所示 St andard dialog 文件对话框 颜色对话框 字体对话框 Hello wor1l! 在上图中,单击“文件对话框”按钮,会弹出文件选择对话框,选中的文件名将显示在右连, 单击“颜色对话栏”按钮,会弹岀颜色选择对话框,选中的颜色将显小在右边,单击“字体对话 框”按钮,会弹出字体选择对话框,选中的字体将更新右边显示的字符串。 实现代码如下: [python] view plaincopyprint? 1.*-* -coding: utf-8 2. from PyQt4.QtGui import 3. from PyQt4. QtCore import 4. import sys 6.QText Codec. setCodecForTr(QText Codec codec ForName(utf8")) 8 class Standard Dialog(QDialog) 9 10. def init (self, parent=None) 1. super(StandardDialog, self). init (parent) 12 13. self. setWindow Title( Standard Dialog") 14 15. file Push Button= QPush Button(sefr("文件对话恒") 16 colorPushButton= QPush Button( self.tr-色对话框") font PushButton= QPushButton( self.tr("字体对话框") 19 self. fileLine Edit=QLine Edito self. colorFrame=QFrame( 21 self. colorFrame setFrame Shape(QFrame. Box) 22 self. colorFrame.setAutoFillBackground(True 23. self. fontAine Edit=QLine Edit( Hello World! " 24 25 layout=Q GridLayouto 26 layout. addWidget(filePushButton, 0, 0) layout. addWidget(self. fileLineEdit, 0, 1) 28 layout. addWidget(color PushButton, 1, 0) 29 layout. addWidget(self. colorFrame, 1,1) 30. layout. addWidget(fontPush Button, 2,0) layout. addWidget(self. fontLineEdit, 2, 1) 32 33. self. setLayout(layout) 34 35. self connect(filePushButton, SIGNALCclickedo"), self. open File) 36 self connect(colorPushButton, SIGNAL(clicked(), self. open Color) 37. self connect(fontPush Button, SIGNAL(clicked("), self. openFont) 38 39. def open File(self) 40. s=QFile Dialog getOpen FileName(self, Open file dialog","/","Python files( py)") 42. self. fileLineEdit. setText(str(s)) 43 44. def open Color(selt 45 46. c=Q Color Dialog. get Color(Qt. blue 47. if c is Valid(: 48. self. colorFrame. setPalette(QPalette(c)) 49 50. def open Font(self) 51 52 f, ok=QFontDialog getFont 53 if ok. 54 self. fontLineEdit setFont(f) 55 56. app=QApplication(sys. argv) 57 form= StandardDialogo 58 form. showO 69. app. exec O 第6行设定tr方法使用u邯8编码来解析文字。 第13行设置程序的标题。 第15到17行创建各个按钮控件。 第19行创建一个 LIne edit类实例 filelineedit,用米显示选择的文件名。 第20行创建一个 FRame类实例 doorframe,当用户选择不同的颜色时, color frame会 根据用户选择的颜色更新其背景 第23行创建一个 QLine Edit类实例 fontaine edit.,当用户选择不同的字体时, fontaine edit 会根据用户选择的字体更新其内容。 第25到33行将各个控件进行布局 第35到37行将各个按钮的 clicked信号相应的槽进行连接 sottIle(方法是文件对话框按钮的 clicked信号的槽,其中 getopenFileName()是 QFileDialog类的一个静态方法,返回用户选择的文件名,如果用户选择取消,则返回一个 空串。函数形式如下: QString getopen FileName(QWidget parent= None, QString caption= QString(, Q String directory = QString(, QString filter= QString(, Options options =0) QString getOpen FileName(QWidget parent None, QString caption QString(, QString directory= QString(), QString filter=QStringo, QString selectedFilter= None, Options options = 0) 调用 getOpen FileName(函数将创建一个模态的文件对话框,如下图所示。 directory参数 指定了默认的目录,如果 directory参数带有文件名,则该文件将是默认选中的文件,fter 参数对文件类型走行过滤,只有与过滤器匹配的文件类型才显示, filter可以同时指定多种 过滤方式供用户选择,多种过滤器之间用";"隔开,用广选择的过滤器通过参数 selectedFilter 返回 Open file dialog ②区 查找范围):「本地避盘(:) OMy Book My Doc 我最近的文档yFim @My Hidden aMy Music 桌面 laMy Othe oMy Pic 品 7 Softwa 我的文档 My Study aMy Work 我的电脑 网上邻居 文件名① [打开@)1 文件类型): Python files(,py) 取消 QFileDialog类还提供了类似的其他静态函数,如卜表,通过这些函数,用户可以方使地定 制自己的文件对话框。 静态函数 说明 ge lOpenFilename 获得用户选择的文件名 getsaveFileName 获得用户保存的文件名 getExistingdirectory 获得用户选择的已存在的目录名 getOpenl'ileNames 获得用户选择的文件名列表 slotcolor()函数是颜色对话框按钮 clicked信号的槽。其中 decolor()是 QColorDialog的 个静态函数,返回用户选择的颜色值,函数形式如下: QColor Q Dialog getColor(Q Color initial=Qt. white, QWidget parent= None) QColor Q Color Dialog. getColor(QColor, QWidget, QString, Color DialogOptions options 0 调用 getcolor(函数将创建一个模态的颜色对话框,如下图所示。 initial参数指定了默认的 颜色,默认为白色,通过 is valid(可以判断用户选择的颜色是否有效,若用户选择取消, isValid将返回 false Select Font 冈 Font Font style eIze Normal 仿宋GB2312 Normal 华文中宋 工 telic 华文仿 Bold 8 华文宋体 Bold italic 9 华文彩云 10 华文新魏 11 华文楷体 12 华文琥珀 华文细黑 1日 文 18 华文隶书 2 2在-1Rnn 4 E£ Eects Sample □ Strikeout 口 nderline AaBblyLr Writing System ty OK[ Cancel slotFont()函数是字体对话框按钮 clicked信号的槽。其中 getFont(是 QFontDialog的个 静态函数,返回用户选择的字体,函数形式如下: (QFont, bool) getFont(QFont, QWidget, QString, FontDialogOptions) (QFont, bool) getFont(QFont, QWidget, QString) (QFont, bool) getFont(QFont, QWidget parent= None) (QFont, bool) getFont(QWidget parent = None 调用 getFont()函数将创建个模态的字体对话框,如下图所示。用户选择OK,函数返回(用 户选择的字体True)否则返回(默认字体, False) ■ Select font Font Font styl Size 宋体 Normal 仿宋GB2312 orm 文中宋 工taic 华文仿 Bold 8 华文宋体 Bold italic 9 10 华文新魏 11 华文楷体 12 华文琥 华文细 1日 18 华文隶 2 22 宋体-1Rn3n Effects ample □ Strikeout □nler1ine AaBbyyli Writing System Any 匚[caca 实例3各类位置信 分类:-PyQt42010-12-0417:071226人阅读评论()收藏举报 Qt提供了很多关于获取窗体位置及显示区域大小的函数,本实例利用一个简单的对话框显 示窗体的各种位置信息,包括窗体的所在点位置,长,宽信息等。木实例的目的是分析各个 有关位置信息的函数之间的区别,如x(,yO,posO),rect), size(), geometry)等,以及在不同的 情况下应使用哪个函数来获取位置信息。实现的效果如下图

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值