简介
QToolButton
类提供了一个快速访问命令或选项的按钮,通常在 QToolBar
内部使用。
工具按钮是一种特殊的按钮,用于快速访问特定的命令或选项。与普通的命令按钮相反,工具按钮通常不显示文本标签,而是显示一个图标。
通常情况下,工具按钮是通过使用 QToolBar::addAction()
创建新的 QAction
实例或将现有的操作添加到工具栏的方式来创建的。还可以像创建任何其他小部件一样构造工具按钮,并将它们与其他小部件一起布局排列。
工具按钮的一个经典用途是选择工具;例如,绘图程序中的 “画笔” 工具。这可以通过使用 QToolButton
作为切换按钮(参见 setToggleButton()
)来实现。
QToolButton
支持自动凸起。在自动凸起模式下,只有当鼠标指向按钮时,按钮才会绘制 3D 边框。当按钮在 QToolBar
内部使用时,该功能会自动开启。可以使用 setAutoRaise()
方法进行更改。
工具按钮的图标是使用 QIcon
设置的。这样可以为禁用状态和活动状态指定不同的像素图。禁用的像素图在按钮的功能不可用时使用。当鼠标悬停在按钮上时,活动的像素图将显示出来,因为按钮会自动凸起。
可以使用 setToolButtonStyle()
和 setIconSize()
调整按钮的外观和尺寸。当在 QMainWindow
中的 QToolBar
中使用时,按钮会自动调整为 QMainWindow
的设置(参见 QMainWindow::setToolButtonStyle()
和 QMainWindow::setIconSize()
)。工具按钮还可以显示一个箭头符号,可以使用 arrowType
指定。
工具按钮可以在弹出菜单中提供额外的选择。可以使用 setMenu()
设置弹出菜单。使用 setPopupMode()
来配置具有菜单设置的工具按钮的不同模式。默认模式是 DelayedPopupMode
,该模式通常与 Web
浏览器中的 “返回” 按钮一起使用。按住按钮一段时间后,会弹出一个菜单,显示要跳转到的可能页面列表。默认的延迟时间是 600 毫秒,可以使用 setPopupDelay()
进行调整。
常用函数
QToolButton
是 Qt 框架提供的一个工具按钮控件,用于在用户界面中提供快捷访问命令或选项的按钮。
以下是关于 QToolButton
的构造函数、枚举、常用函数、信号和槽的介绍:
-
构造函数
:- QToolButton(QWidget *parent = nullptr):使用指定的父窗口创建一个默认的 QToolButton 实例。
- QToolButton(const QString &text, QWidget *parent = nullptr):使用指定的文本和父窗口创建一个 QToolButton 实例。
-
枚举
:- ToolButtonPopupMode:枚举类型,定义了工具按钮的弹出菜单模式:
- QToolButton::DelayedPopup:默认模式,长按按钮后延迟弹出菜单。
- QToolButton::MenuButtonPopup:点击按钮箭头图标后立即弹出菜单。
- QToolButton::InstantPopup:点击按钮后立即弹出菜单。
- ToolButtonPopupMode:枚举类型,定义了工具按钮的弹出菜单模式:
-
常用函数
:- void setIcon(const QIcon &icon):设置工具按钮的图标。
- QIcon icon() const:获取工具按钮的图标。
- void setText(const QString &text):设置工具按钮的文本。
- QString text() const:获取工具按钮的文本。
- void setAutoRaise(bool enable):设置是否在鼠标指向按钮时自动凸起。
- bool autoRaise() const:检查按钮是否在鼠标指向时自动凸起。
- void setPopupMode(QToolButton::ToolButtonPopupMode mode):设置工具按钮的弹出菜单模式。
- QToolButton::ToolButtonPopupMode popupMode() const:获取工具按钮的弹出菜单模式。
-
信号和槽
:- void clicked(bool checked = false):点击工具按钮时触发的信号。参数 checked 表示按钮的选中状态。
- void triggered(QAction *action):当有菜单项被触发时,发送该信号。可以使用 action 参数来获取触发的菜单项。
使用信号和槽机制,可以通过连接 QToolButton 的 clicked 信号和自定义的槽函数来响应按钮的点击事件。例如:
QObject::connect(toolButton, &QToolButton::clicked, [&]() {
// 工具按钮点击事件的逻辑处理
});
通过连接 clicked()
信号,可以在工具按钮被点击时执行相关的操作或逻辑处理。
QToolButton
提供了许多其他的函数和属性,用于设置按钮的图标、文本、样式和弹出菜单等,以满足在用户界面中提供快捷访问命令或选项的需求。根据具体需求,可以使用这些函数和属性对 QToolButton
进行定制和扩展。
示例
以下是一个简单的 QToolButton 的示例代码,展示了如何创建一个工具按钮并处理其点击事件:
#include <QApplication>
#include <QMainWindow>
#include <QToolButton>
#include <QMessageBox>
int main(int argc, char *argv[])
{
QApplication app(argc, argv);
QMainWindow window;
window.setWindowTitle("toolBtn");
// 创建一个工具按钮
QToolButton *toolButton = new QToolButton(&window);
toolButton->setText("Click me"); // 设置按钮显示的文本
// 连接按钮的 clicked 信号和槽函数
QObject::connect(toolButton, &QToolButton::clicked, [&]() {
QMessageBox::information(&window, "Clicked", "Button has been clicked!");
});
// 将具按钮添加到主窗口的工具栏
QToolBar *pBar = window.addToolBar("bar");
pBar->addWidget(toolButton);
window.show();
return app.exec();
}
效果
在这个示例中,创建了一个简单的 QMainWindow 窗口,并在窗口上添加了一个带有文本 “Click me” 的工具按钮。
然后,通过连接工具按钮的 clicked 信号和一个 lambda 函数,当按钮被点击时,会弹出一个消息框显示"Button has been clicked!"的信息。