介绍一下QT中QToolBar设置QAction的原理
在Qt中,QToolBar是一个用于创建工具栏的小部件。它允许你将各种操作(QAction)组织在一起,并以按钮的形式显示在工具栏上。
QToolBar类继承自QWidget类,它提供了一些方法和信号,用于管理和显示工具栏上的操作按钮。
要将QAction设置为QToolBar上的按钮,可以使用QToolBar的addAction()方法将QAction对象添加到工具栏中。这将在工具栏上创建一个按钮,并将其与相应的QAction关联起来。
当用户点击工具栏上的按钮时,QToolBar会发出triggered()信号。您可以连接这个信号到一个槽函数,以便在按钮被点击时执行相应的操作。
QAction类是一个表示操作的抽象类。它可以包含文本、图标、快捷键等属性,并且可以与菜单、工具栏等部件关联起来。当用户与与QAction关联的部件进行交互时,QAction会发出相应的信号,以便你可以执行相应的操作。
通过将QAction添加到QToolBar中,你可以将操作按钮显示在工具栏上,并通过连接信号和槽函数来处理按钮的点击事件。这样,你可以实现在Qt中使用QToolBar和QAction创建功能丰富的工具栏界面。
如此我们不难得出,因为QAction是抽象的,不是一个具体的widget,所以我们无法直接使用setObjectName函数设置别名。
使用findChildren获取QAction的QToolButton
- 想要设置QAction 的QSS,我们需要得到QAction附加的QToolButton,通过这个QToolButton才能使用setObjectName函数设置别名。要获取相应的QToolButton需要使用findChildren函数遍历QToolBar,再使用defaultAction函数与QAction便可得到对应的QToolButton。
QList<QToolButton*> list = findChildren<QToolButton *>();
foreach (auto button, list) {
if (button->defaultAction() == ActionManager::getInstance().getAction(ActionManager::Rectangle)) {
button->setObjectName("Rectangle");
} else if (button->defaultAction() == ActionManager::getInstance().getAction(ActionManager::Circular)) {
button->setObjectName("Circular");
} else if (button->defaultAction() == ActionManager::getInstance().getAction(ActionManager::Polygon)) {
button->setObjectName("Polygon");
} else if (button->defaultAction() == ActionManager::getInstance().getAction(ActionManager::Lock)) {
button->setObjectName("Lock");
}
}
- 如此我们便可以设置QToolBar上相应QAction的样式了
动态设置Qss样式
- 当一个按钮有俩种状态,每种状态又要有鼠标划过,点击,禁用,正常四种图片时,这时候就需要设置动态样式了。
if (button) {
button->setIcon(QIcon());
if (falg) {
button->setProperty("isLock", "true");
} else {
button->setProperty("isLock", "false");
}
button->style()->unpolish(button);
button->style()->polish(button);
button->update();
}
- 如上,先将原有的图片置空,当我们按下按钮时,传入falg来获取当前按钮应该设置如何属性。再使用unpolish与polish函数更新样式表,最后调用update函数刷新即可,以下为qss以供参考。
QToolButton#Lock[isLock="false"]{
background-image:url(:/GraphicsModelingKernel/toolUnlockNormal);
}
QToolButton#Lock[isLock="false"]:hover{
background-image:url(:/GraphicsModelingKernel/toolUnlockSlid);
}
QToolButton#Lock[isLock="false"]:disabled{
background-image:url(:/GraphicsModelingKernel/toolUnlockDisable);
}
QToolButton#Lock[isLock="false"]:checked{
background-image:url(:/GraphicsModelingKernel/toolUnlockClick);
}
QToolButton#Lock[isLock="true"]{
background-image:url(:/GraphicsModelingKernel/toolLockNormal);
}
QToolButton#Lock[isLock="true"]:hover{
background-image:url(:/GraphicsModelingKernel/toolLockSlid);
}
QToolButton#Lock[isLock="true"]:disabled{
background-image:url(:/GraphicsModelingKernel/toolLockDisable);
}
QToolButton#Lock[isLock="true"]:checked{
background-image:url(:/GraphicsModelingKernel/toolLockClick);
}