【PyQt学习篇 · ⑪】:QPushButton和QCommandLinkButton的使用

构造函数

QPushButton的构造函数如下:

    """
    QPushButton(parent: Optional[QWidget] = None)
    QPushButton(text: Optional[str], parent: Optional[QWidget] = None)
    QPushButton(icon: QIcon, text: Optional[str], parent: Optional[QWidget] = None)
    """

示例代码:

from PyQt5.Qt import *
from PyQt5.QtGui import QIcon
import sys


app = QApplication(sys.argv)

window = QWidget()
window.resize(300, 300)

btu = QPushButton(QIcon('mouse.png'), '按钮', window)     # 使用最全的构造函数

btu.setIconSize(QSize(50, 50))
btu.resize(80, 50)

window.show()
sys.exit(app.exec_())

运行结果:

在这里插入图片描述

菜单设置

在 PyQt5 中,QPushButton 类提供了设置菜单的功能。以下是 QPushButton 菜单相关的 API 以及 QMenu 相关的 API 的说明:

  1. setMenu(QMenu)
    • setMenu(QMenu) 用于将一个 QMenu 对象设置为 QPushButton 的下拉菜单。当用户单击按钮时,会自动显示菜单。
  2. menu()
    • menu() 返回与 QPushButton 关联的 QMenu 对象,如果未设置菜单,则返回 None。
  3. showMenu()
    • showMenu() 在不单击按钮的情况下强制显示菜单。
  4. QMenu 相关 API:
    • addMenu(QMenu) 用于将子菜单添加到菜单中。
    • addSeparator() 用于在菜单中添加分隔线。
    • addAction(QAction) 用于添加动作到菜单中。
    • setTitle(str) 用于设置菜单标题。
    • setIcon(QIcon) 用于设置菜单图标。
    • triggered(QAction) 信号在菜单中的动作被触发时发出。可以使用该信号处理菜单事件。

示例1代码:

from PyQt5.Qt import *
from PyQt5.QtGui import QIcon
import sys


app = QApplication(sys.argv)

window = QWidget()
window.resize(300, 300)

btu = QPushButton(QIcon('mouse.png'), '按钮', window)     # 使用最全的构造函数
btu.setIconSize(QSize(50, 50))
btu.resize(100, 50)

# 菜单的设置
mean = QMenu()

# 行为动作:新建、打开、分割线、退出
new_action = QAction(QIcon('mouse.png'), '新建')
new_action.triggered.connect(lambda: print('新建文件'))

open_action = QAction(QIcon('mouse.png'), '打开')
open_action.triggered.connect(lambda: print('打开文件'))

exit_action = QAction('退出')
exit_action.triggered.connect(lambda: print('退出'))

# 子菜单
open_recent_menu = QMenu(mean)      # 将子菜单添加到主菜单中
open_recent_menu.setTitle('最近打开')

file_action = QAction('PyQt5学习')

# 添加
mean.addAction(new_action)
mean.addAction(open_action)

# 子菜单添加行为后添加到主菜单中
open_recent_menu.addAction(file_action)
mean.addMenu(open_recent_menu)

mean.addSeparator()     # 添加分割线
mean.addAction(exit_action)

btu.setMenu(mean)   # 设置菜单

window.show()
sys.exit(app.exec_())

运行结果:

在这里插入图片描述

扁平化

在 PyQt5 中,QPushButton 类提供了扁平化按钮的功能。以下是 QPushButton 中与扁平化相关的 API 的说明:

  1. setFlat(bool):
    • setFlat(bool) 用于设置按钮是否扁平化。
    • 参数 bool 为 True,按钮将显示为扁平化样式;为 False,按钮将显示为正常样式。
  2. isFlat():
    • isFlat() 返回一个布尔值,表示按钮是否处于扁平化状态。
    • 如果按钮被设置为扁平化,则返回 True;否则返回 False。

示例代码:

from PyQt5.Qt import *
import sys


app = QApplication(sys.argv)

window = QWidget()
window.resize(300, 300)

btu = QPushButton(window)
btu.setStyleSheet('background-color: red;')
btu.setText('这是一个按钮')
btu.setFlat(True)   # 设置按钮为扁平化

print(btu.isFlat())

window.show()
sys.exit(app.exec_())

运行结果:
设置背景颜色之后,再设置为扁平化,就不会绘制按钮的背景颜色。

在这里插入图片描述

默认处理

在 PyQt5 中,QPushButton 类提供了默认处理按钮的功能。使用默认处理功能后,当用户按下回车键时,会自动触发与该按钮相关联的信号,从而实现点击该按钮的效果。

以下是 QPushButton 中与默认处理相关的 API 的说明:

  1. setAutoDefault(bool)
    • setAutoDefault(bool) 用于设置按钮的默认处理功能是否打开。
    • 参数 bool 为 True,按钮默认处理功能打开;为 False,按钮默认处理功能关闭。
  2. autoDefault()
    • autoDefault() 返回一个布尔值,表示按钮是否开启了默认处理功能。
    • 如果按钮开启了默认处理功能,则返回 True;否则返回 False。
    • 示例用法:
  3. setDefault(bool)
    • setDefault(bool) 用于设置按钮为默认按钮。
    • 默认按钮表示当用户按下回车键时,会自动触发与该按钮相关联的信号。
    • 参数 bool 为 True,按钮设置为默认按钮;为 False,按钮取消默认按钮的设置。
  4. isDefault():
    • isDefault() 返回一个布尔值,表示按钮是否为默认按钮。
    • 如果按钮为默认按钮,则返回 True;否则返回 False。

示例代码:

from PyQt5.Qt import *
import sys


app = QApplication(sys.argv)

window = QWidget()
window.resize(300, 300)

btu1 = QPushButton(window)
btu1.setText('btu')

btu = QPushButton(window)
btu.setText('这是一个按钮')
btu.move(100, 100)

btu.pressed.connect(lambda: print('这个按钮被按下'))

btu.setAutoDefault(True)    # 给btu设置为自动默认

window.show()
sys.exit(app.exec_())

运行结果:
运行后鼠标点击“这是一个按钮”按钮被点击选中,按下回车键,按钮被点击,执行打印结果。

在这里插入图片描述
将以上btu.setAutoDefault(True)换成btu.setDefault(True),即运行程序后,在一开始就将按钮变为默认按钮。

运行结果:

在这里插入图片描述

右键菜单

在 PyQt5 中,QPushButton 类提供了右键菜单的功能。通过使用该功能,用户可以在右键单击按钮时弹出自定义菜单。

以下是 QPushButton 中与右键菜单相关的 API 的说明:

  1. customContextMenuRequested(QPoint)

    • customContextMenuRequested(QPoint) 是一个信号,当用户在按钮上右键单击时发射。
    • 该信号会将鼠标右键单击的位置(QPoint)作为参数传递给与之相关联的槽函数,槽函数可以利用此位置信息进行自定义菜单的弹出操作。
  2. setContextMenuPolicy(Qt.CustomContextMenu)

    • setContextMenuPolicy(Qt.CustomContextMenu) 用于设置按钮的菜单策略为自定义菜单。
    • 自定义菜单策略开启后,当用户在该按钮上右键单击时,customContextMenuRequested(QPoint) 信号就会被触发。
  3. Qt.DefaultContextMenu()

    • Qt.DefaultContextMenu() 是一个用于内置菜单的常量,表示用户在按钮上右键单击时弹出的默认菜单。
    • 调用对象方法contextMenuEvent(event),它 是一个重写的方法,用于在用户右键单击按钮时弹出内置菜单。
  4. Qt.CustomContextMenu

    • Qt.CustomContextMenu 是一个用于自定义菜单的常量,表示用户在按钮上右键单击时必须弹出自定义菜单。

示例1代码:

from PyQt5.Qt import *
import sys


class Window(QWidget):
    def contextMenuEvent(self, evt):
        mean = QMenu(self)  # 主菜单

        new_action = QAction(QIcon('mouse.png'), '新建')
        new_action.triggered.connect(lambda: print('新建文件'))

        open_action = QAction(QIcon('mouse.png'), '打开')
        open_action.triggered.connect(lambda: print('打开文件'))

        exit_action = QAction(QIcon('mouse.png'), '关闭')
        exit_action.triggered.connect(lambda: print('关闭'))

        open_recent_menu = QMenu(mean)
        open_recent_menu.setTitle('最近打开')
        open_recent_action = QAction('PyQt5学习')

        # 将创建的行为动作和子菜单添加到主菜单中
        mean.addAction(new_action)
        mean.addAction(open_action)

        open_recent_menu.addAction(open_recent_action)
        mean.addMenu(open_recent_menu)

        mean.addSeparator()
        mean.addAction(exit_action)

        mean.exec_(evt.globalPos())

if __name__ == '__main__':
    app = QApplication(sys.argv)

    window = Window()
    window.resize(300, 300)

    window.show()
    sys.exit(app.exec_())

运行结果:

在这里插入图片描述
示例2代码:

from PyQt5.Qt import *
from PyQt5.QtCore import Qt
import sys

app = QApplication(sys.argv)

window = Window()
window.resize(300, 300)

def show_menu(point):   # point介绍到的是相对于窗口的位置
    mean = QMenu(window)  # 主菜单

    new_action = QAction(QIcon('mouse.png'), '新建')
    new_action.triggered.connect(lambda: print('新建文件'))

    open_action = QAction(QIcon('mouse.png'), '打开')
    open_action.triggered.connect(lambda: print('打开文件'))

    exit_action = QAction(QIcon('mouse.png'), '关闭')
    exit_action.triggered.connect(lambda: print('关闭'))

    open_recent_menu = QMenu(mean)
    open_recent_menu.setTitle('最近打开')
    open_recent_action = QAction('PyQt5学习')

    # 将创建的行为动作和子菜单添加到主菜单中
    mean.addAction(new_action)
    mean.addAction(open_action)

    open_recent_menu.addAction(open_recent_action)
    mean.addMenu(open_recent_menu)

    mean.addSeparator()
    mean.addAction(exit_action)
    # 将局部window上的point点,映射到全局屏幕mapToGlobal上的点
    dest_point = window.mapToGlobal(point)
    mean.exec_(dest_point)

window.setContextMenuPolicy(Qt.CustomContextMenu)
window.customContextMenuRequested.connect(show_menu)

window.show()
sys.exit(app.exec_())

运行结果:
如以上代码所示,因为point获取的是相对于窗口的坐标,而mean.exec_()是将菜单放到全局坐标(全屏幕)上,所以需要映射,将局部window上的point点,映射到全局屏幕mapToGlobal上的点。

在这里插入图片描述

QCommandLinkButton的使用

QCommandLinkButton 是 PyQt5 中的一个组件,它是一个带有标题和描述的命令按钮,通常用于表达重要操作的步骤。

使用 QCommandLinkButton 可以让用户更容易地理解和操作应用程序。

在 PyQt5 中,我们可以使用 QCommandLinkButton 构造函数创建命令链接按钮。QCommandLinkButton 构造函数有以下几种:

  • QCommandLinkButton(parent=None),创建一个没有文本和描述的命令链接按钮。
  • QCommandLinkButton(text, parent=None),创建一个具有文本但是没有描述的命令链接按钮。
  • QCommandLinkButton(text, description, parent=None),创建一个同时具有文本和描述的命令链接按钮。

示例代码:

from PyQt5.Qt import *
import sys

app = QApplication(sys.argv)

window = QWidget()
window.resize(300, 300)

combtu1 = QCommandLinkButton('按钮1', '这是描述1', window)
combtu1.move(100, 0)

combtu2 = QCommandLinkButton(window)
combtu2.setText('按钮')
combtu2.setDescription('这是描述2')
combtu2.setIcon(QIcon('mouse.png'))
combtu2.move(100, 100)

print(combtu1.description())    # 打印按钮1的描述

window.show()
sys.exit(app.exec_())

运行结果:

在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

街 三 仔

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

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

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

打赏作者

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

抵扣说明:

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

余额充值