QTabWidget 设置部分tab上有关闭按钮,部分没有

QTabWidget设置setTabsClosable(true)后所有加进来的tab上都会出现关闭按钮,然后利用QTabWidget的tabCloseRequested(int)信号实现tab的关闭。

但是有时想设置几个tab不能关闭且把上面的关闭按钮去掉则需要用到QTabBar的一个函数setTabButton(index,position,*widget),把widget设为NULL即可。

((QTabBar*)(tabWidget->tabBar()))->setTabButton(tabWidget->indexOf(widget),QTabBar::RightSide,NULL);
当然一定要在setTabsClosable()后面设置。
 
如果tab上默认的关闭按钮样式不符合要求,则可设置setTabsClosable(false),然后自定义一个按钮,然后在每个需要有按钮的tab加载时
((QTabBar*)(tabWidget->tabBar()))->setTabButton(tabWidget->indexOf(widget),QTabBar::RightSide,customButton);
然后配置自己的按钮动作信号槽。



  • 9
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在QTabWidget的标签页上添加关闭按钮,可以使用自定义QWidget作为标签页,并在QWidget上添加一个关闭按钮。下面是修改后的示例代码: ```cpp #include <QApplication> #include <QListView> #include <QPushButton> #include <QTabWidget> #include <QStringListModel> #include <QVBoxLayout> #include <QWidget> int main(int argc, char *argv[]) { QApplication app(argc, argv); // 创建一个QListView和一个QTabWidget QListView listView; QTabWidget tabWidget; // 创建一个QStringListModel,并设置给QListView QStringListModel model; model.setStringList({"Tab 1", "Tab 2", "Tab 3"}); listView.setModel(&model); // 将QListView的currentChanged信号与QTabWidget的setCurrentIndex槽函数关联 QObject::connect(&listView, &QListView::clicked, [&](const QModelIndex &index) { tabWidget.setCurrentIndex(index.row()); }); // 将QTabWidget添加到主窗口中 tabWidget.setTabsClosable(true); // 允许关闭标签页 // 创建一个自定义QWidget作为标签页 QWidget *customTab = new QWidget; QVBoxLayout *layout = new QVBoxLayout(customTab); QPushButton *closeButton = new QPushButton("Close"); layout->addWidget(closeButton); layout->addStretch(); tabWidget.setTabWidget(customTab, "Custom Tab"); QObject::connect(closeButton, &QPushButton::clicked, [&]() { int currentIndex = tabWidget.currentIndex(); if (currentIndex >= 0) { tabWidget.removeTab(currentIndex); } }); // 创建一个主窗口,并将QListView和QTabWidget添加到主窗口中 QWidget mainWindow; QVBoxLayout mainLayout(&mainWindow); mainLayout.addWidget(&listView); mainLayout.addWidget(&tabWidget); mainWindow.setLayout(&mainLayout); mainWindow.show(); return app.exec(); } ``` 在这个示例中,我们首先将QTabWidget的setTabsClosable属性设置为true,以允许关闭标签页。然后,我们创建了一个自定义的QWidget作为标签页,并在其中添加了一个关闭按钮。通过连接关闭按钮的clicked信号和槽函数,当点击关闭按钮时,会根据当前选中的标签页索引来移除对应的标签页。 请注意,这只是一个简单的示例,你可以根据自己的需求进行修改和扩展。希望能帮助到你!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值