QToolButton *m_btnSelCams = new QToolButton(); m_btnSelCams->setObjectName("public_toolbtn_above_tree"); QIcon iconSelCam; iconSelCam.addFile(".//skin//images//button//filter_cam.png", QSize(16, 16), QIcon::Normal, QIcon::On); iconSelCam.addFile(".//skin//images//button//filter_cam_h.png", QSize(16, 16), QIcon::Active, QIcon::On); iconSelCam.addFile(".//skin//images//button//filter_cam_p.png", QSize(16, 16), QIcon::Selected, QIcon::On); m_btnSelCams->setIcon(iconSelCam); m_btnSelCams->setIconSize(QSize(16, 16)); 设置悬浮态图标无效是什么原因
时间: 2023-12-21 22:03:38 浏览: 78
可能是因为没有设置悬浮态的图标。可以尝试添加以下代码:
```
QIcon iconSelCamHover;
iconSelCamHover.addFile(".//skin//images//button//filter_cam_h.png", QSize(16, 16), QIcon::Normal, QIcon::On);
m_btnSelCams->setIcon(iconSelCam);
m_btnSelCams->setToolTip("Select Cameras");
m_btnSelCams->setAutoRaise(true);
m_btnSelCams->setToolButtonStyle(Qt::ToolButtonIconOnly);
m_btnSelCams->setStyleSheet("QToolButton:hover{border: none; background-color: #f0f0f0;}");
m_btnSelCams->setCursor(Qt::PointingHandCursor);
m_btnSelCams->setFixedSize(24, 24);
m_btnSelCams->setSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed);
```
这里我们添加了一个`iconSelCamHover`来存储悬浮态的图标,然后设置了一些其他属性,例如工具提示、自动升起、按钮样式、样式表、鼠标光标、固定大小和大小策略。你需要根据你的需要进行调整。
相关问题
class Drawer : public QToolBox { Q_OBJECT public: Drawer(QWidget *parent=0, Qt::WindowFlags f=0); private: QToolButton *toolBtn1; QToolButton *toolBtn2; QToolButton *toolBtn3; QToolButton *toolBtn4; QToolButton *toolBtn5; QToolButton *toolBtn6; QToolButton *toolBtn7; QToolButton *toolBtn8; QToolButton *toolBtn9; public slots: void showChatWidget1(); void showChatWidget2(); void showChatWidget3(); void showChatWidget4(); void showChatWidget5(); void showChatWidget6(); void showChatWidget7(); void showChatWidget8(); void showChatWidget9(); private: Widget *chatWidget1; Widget *chatWidget2; Widget *chatWidget3; Widget *chatWidget4; Widget *chatWidget5; Widget *chatWidget6; Widget *chatWidget7; Widget *chatWidget8; Widget *chatWidget9; };实现点击QToolButton后跳出登录界面
可以在每个showChatWidgetX()槽函数中创建一个登录界面的实例,并调用它的show()函数显示出来。例如,showChatWidget1()槽函数可以实现如下:
```
void Drawer::showChatWidget1()
{
if (!chatWidget1) {
chatWidget1 = new Widget(this);
}
chatWidget1->show();
}
```
需要注意的是,在Drawer类的构造函数中要将chatWidget1等成员变量初始化为NULL。另外,Widget类是一个自定义的登录界面类,需要根据具体需求来实现。
QToolButton *textButton = new QToolButton; textButton->setCheckable(true); buttonGroup->addButton(textButton, InsertTextButton); textButton->setIcon(QIcon(QPixmap(":/images/textpointer.png"))); textButton->setIconSize(QSize(50, 50)); QGridLayout *textLayout = new QGridLayout; textLayout->addWidget(textButton, 0, 0, Qt::AlignHCenter); textLayout->addWidget(new QLabel(tr("Text")), 1, 0, Qt::AlignCenter); QWidget *textWidget = new QWidget; textWidget->setLayout(textLayout); layout->addWidget(textWidget, 1, 1); layout->setRowStretch(3, 10); layout->setColumnStretch(2, 10);
这段代码是用于创建一个可选中的 QToolButton 对象,并将其添加到一个 QButtonGroup 中。该按钮使用一个图片作为图标,并设置了图标的大小。接下来,使用一个 QGridLayout 来组织该按钮及其文本标签,并将其添加到一个 QWidget 中。最后,将该 QWidget 添加到一个布局管理器中,并使用 setRowStretch 和 setColumnStretch 方法设置行和列的伸展因子,以便在窗口大小改变时,该布局可以正确地自适应。
阅读全文