PyQt5基本控件详解之QFontDialog(十五)

QFontDialog

前言

QFontDialog控件是一个常用的字体选择对话框,可以让用户选择所显示文本的字号大小,样式和格式,QFontDialog是QDialog控件对话框的一部分,使用QFontDialog类的静态方法getFont(),可以从字体选择对话框中选择文本的显示字号大小样式和格式

实例:QFontDialog的使用

import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class FontDialogdemo(QWidget):
    def __init__(self,parent=None):
        super(FontDialogdemo, self).__init__(parent)

        #垂直布局
        layout=QVBoxLayout()

        #创建按钮,绑定自定义槽函数,添加到布局中
        self.fonButton=QPushButton('Choose Font')
        self.fonButton.clicked.connect(self.getFont)
        layout.addWidget(self.fonButton)

        #创建标签,添加dao到布局中
        self.FontLineEdit=QLabel('Hello 测试字体的例子')
        layout.addWidget(self.FontLineEdit)

        #设置主窗口布局及标题
        self.setLayout(layout)
        self.setWindowTitle("Font Dialog例子")

    def getFont(self):
        font,ok=QFontDialog.getFont()
        if ok:
            self.FontLineEdit.setFont(font)

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

运行程序,显示效果如下如
这里写图片描述

代码分析

在这个例子中,通过字体选择对话框选择相应的字体,并且选择字体的效果显示在QLineEdit的文本
实例化fontButton和fontLineEdit对象,并将FontButton的clicked信号和槽函数getFont()绑定在一起

self.fonButton=QPushButton('Choose Font')
self.fonButton.clicked.connect(self.getFont)

创建垂直布局QVBoxLayout布局,在垂直布局管理器中添加fontButton和fontLineEdit组件,并按照相应的位置添加到栅格布局中

layout = QVBoxLayout()
layout.addWidget(self.fonButton)
layout.addWidget(self.FontLineEdit)

当单击fontButton按钮时,将clicked信号发送到槽函数getFont(中)

self.fonButton.clicked.connect(self.getFont)

自定义槽函数,选择字体,并将字体效果设置到fontLineEdit中,getFont()方法返回的为元祖类型,同时返回所选择的字体和函数执行的状态

 def getFont(self):
        font,ok=QFontDialog.getFont()
        if ok:
            self.FontLineEdit.setFont(font)

源码以及相关文件下载:https://download.csdn.net/download/jia666666/10597897

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jia666666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值