QTabWidget多页面部件的用法及程序示例
*重要函数:*
1.void setTabText(int, QString); //设置页面的名字.
2.void setTabToolTip(QString); //设置页面的提示信息.
3.void setTabEnabled(bool); //设置页面是否被激活.
4.void setTabPosition(QTabPosition::South); //设置页面名字的位置.
5.void setTabsClosable(bool); //设置页面关闭按钮。
6.int currentIndex(); //返回当前页面的下标,从0开始.
7.int count(); //返回页面的数量.
8.void clear(); //清空所有页面.
9.void removeTab(int); //删除页面.
10.void setMoveable(bool); //设置页面是否可被拖拽移动.
11.void setCurrentIndex(int); //设置当前显示的页面.
signals:
1.void tabCloseRequested(int). //当点击第参数个选项卡的关闭按钮的时候,发出信号.
2.void tabBarClicked(int). //当点击第参数个选项卡的时候,发出信号.
3.void currentChanged(int). //当改变第参数个选项卡的时候,发出信号.
4.void tabBarDoubleClicked(int). //当双击第参数个选项卡的时候,发出信号.
首先在Qt设计师中拖拽出如下的布局:
以下是”c.cpp”下的代码:
#include"c.h"c::c(QWidget*parent):QMainWindow(parent){ui.setupUi(this);//连接信号与槽.connect(ui.insertButton,SIGNAL(clicked()),this,SLOT(addPageSlot()));connect(ui.removeButton,SIGNAL(clicked()),this,SLOT(removePageSlot()));connect(ui.dragButton,SIGNAL(clicked()),this,SLOT(dragPageSlot()));}c::~c(){}voidc::addPageSlot(){//定义一个QWidget.QWidget*temp=newQWidget;//在当前页面的后面插入一个新的页面.ui.tabWidget->insertTab(ui.tabWidget->currentIndex()+1,temp,QIcon("Icons/2.png"),QString::number(count));//显示新的页面.ui.tabWidget->setCurrentIndex(ui.tabWidget->indexOf(temp));count++;}voidc::removePageSlot(){//删除当前的页面.ui.tabWidget->removeTab(ui.tabWidget->currentIndex());}voidc::dragPageSlot(){//设置页面项是可被移动的.ui.tabWidget->setMovable(true);}12345678910111213141516171819202122232425262728293031323334353637383940
然后是”c.h”下的代码:
#ifndefC_H#defineC_H#include<QtWidgets/QMainWindow>#include"ui_c.h"#include<QTabWidget>#include<QPushButton>classc:publicQMainWindow{Q_OBJECTpublic:c(QWidget*parent=0);~c();privateslots:voidaddPageSlot();voidremovePageSlot();voiddragPageSlot();private:Ui::cClassui;intcount=0;};#endif//C_H123456789101112131415161718192021222324252627
最后是”main.cpp”下的代码:
#include"c.h"#include<QtWidgets/QApplication>intmain(intargc,char*argv[]){QApplicationa(argc,argv);cw;w.show();returna.exec();}
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。