一、QPushButton

1、设置背景色:

ui->pushButton->setStyleSheet("background-color: rgb(170, 0, 255)";);

2、设置鼠标放上去的提示语

在设计师界面,设置按钮的tooltip

二、QTextEdit

1、判断是否为空

QString str = ui->textEdit->toPlainText();//获取内容

if(str.isEmpty()) {do something}

2、末尾追加字符串,换行

直接用QTextEdit.append()函数;注意此函数在追加的时候会在新的一行追加

3、判断内容是否已经改变

ui->textEdit->document().isModified();//如果改变

 4、通过HTML方式设置颜色(转)

void MainWindow::stringToHtmlFilter(QString &str)//将HTML不能识别的字符转化为能够识别的

{

str.replace("&","&");

str.replace(">",">");

str.replace("<","&lt;");

str.replace("\"","&quot;");

str.replace("\'","&#39;");

str.replace(" ","&nbsp;");

str.replace("\n","<br>");

str.replace("\r","<br>");

}

void MainWindow::stringToHtml(QString &str, QColor crl)//根据传入的颜色设置成HTML字符串

{

QByteArray array;

array.append(crl.red());

array.append(crl.green());

array.append(crl.blue());

QString strC(array.toHex());

str = QString("<span style=\" color:#%1;\">%2</span>").arg(strC).arg(str);

}

ui->textEdit->insertHtml(htmlStr);

5、通过设置格式的方式改变颜色

QString appendStr("testAAtest");//给AA添加颜色

int postionOfAA = appendStr.indexOf("AA",0,Qt::CaseInsensitive);//AA在这个字符串中的位置

QTextCursor tempCursor = ui->textEdit->textCursor();//获取控件光标指针

int num1 = tempCursor.position();//之前光标的位置

ui->textEdit->append(appendStr);//添加信息

tempCursor.setPosition(num1 + postionOfAA + 1);//将光标初始位置设置在第一个A前面,+1是因为有个回车符号

tempCursor.setPosition(num1 + postionOfAA + 1 + 2,QTextCursor::KeepAnchor);//使光标位置固定,拖动到下两个字符,选中AA

QColor color(255,0,0);//定义一个红色QColor变量

QTextCharFormat fmt;//定义一个QTextCharFormat变量

fmt.setForeground(color);//颜色设置为红色

tempCursor.setCharFormat(fmt);//给这个光标对象设置这个格式变量

tempCursor.clearSelection();//设置颜色之后取消选中的位置

 6、获取行数

ui->textEdit->document()->lineCount()

7、设置scrollbar的样式

ui->textEdit->verticalScrollBar()->setStyleSheet(

"QScrollBar:vertical{width:8px;background:rgba(0,0,0,0%);margin:0px,0px,0px,0px;padding-top:9px;padding-bottom:9px;}"

"QScrollBar::handle:vertical{width:8px;background:rgba(0,0,0,25%);border-radius:4px;min-height:20;}"

"QScrollBar::handle:vertical:hover{width:8px;background:rgba(0,0,0,50%);border-radius:4px;min-height:20;}"

);

8、设置最多行数

ui->textEdit->document()->setMaximumBlockCount(1000);//最多行数限制

9、滑动条移动,内容不滚动

QScrollBar* tempScrollBar = ui->textEdit_8->verticalScrollBar();

int scrollPosition = tempScrollBar->sliderPosition();

ui->textEdit_8->setText("需要添加的内容");

tempScrollBar->setSliderPosition(scrollPosition);

10、末尾追加时不换行

ui->textEdit->moveCursor(QTextCursor::End);

ui->textEdit->insertPlainText(info);

11、插入表格



QTextCursor cursor(this->ui->textEdit->textCursor());
cursor.movePosition(QTextCursor::Start);
QTextTable* _table=cursor.insertTable(1,2);
_table->cellAt(0,0).firstCursorPosition().insertHtml("时间");
_table->cellAt(0,1).firstCursorPosition().insertHtml("日志信息");


 12、提示输入

在ui里找到placeholderText;

在代码里setPlaceholderText(QString)

QT控件学习_ico

 13、自动清空,减少内存占用、卡顿



#define TEXT_EDIT_MAX_SIZE 8000
QString textContent = textEdit->toPlainText();
int length = textContent.size();
if(length > TEXT_EDIT_MAX_SIZE) // 最大字符数
{
textEdit->clear();
}


注意不能根据rowCount行数来清空,因为QTextEdit使用换行符来判断行数的,而 有些字符串虽然看起来换行了,实际是没有的,所以可能造成:虽然看来来行数很多,实际上rowCount不多的,但内存还是增长了

 

三、QComboBox

1、添加项

直接在ui界面右键控件-》编辑项目,点+

2、获取当前的文本

ui->combox->currentText()

3、获取当前的序号

ui->comboBox->currentIndex()

4、设置当前显示索引号

ui->comboBox->setCurrentIndex(-1);//-1时显示空

5、判断当前值是输入的还是自己选的

if((ui->comboBox->currentText())==(ui->comboBox>itemText(ui->comboBox->currentIndex())))//目的地址

{

//即使用户输入了数据,currentIndex依然是原来选的,所以需要判断当前text是否与index的相同

}

四、QMessageBox

QMessageBox有几个静态函数,举例一个

QMessageBox::StandardButton tempBtn = QMessageBox::question(NULL,"Notepad","Save to NoTitle?",QMessageBox::Yes|QMessageBox::No|QMessageBox::Cancel,QMessageBox::Yes);

if(tempBtn == QMessageBox::Ok)

{

}

else if(tempBtn == QMessageBox::No)

{

}

else if(tempBtn == QMessageBox::Cancel)

{

}

五、使用QTabWidget多个子界面

第一种方式:

1、在主界面添加一个QTabWidget控件

2、添加两个QWidget的子界面,新建Qt设计师那个,带ui那种,如:

TcpServer、TcpClient

3、在工程头文件中声明两个子界面的指针变量

TcpServer *tcpServer;

TcpClient *tcpClient;

4、在工程cpp中new出界面对象

this->tcpServer = new TcpServer();

this->tcpClient = new TcpClient();

5、添加子界面

ui->tabWidget->addTab(this->tcpServer,"Tcp&Server");

ui->tabWidget->addTab(this->tcpClient,"Tcp&Client");

第二种:

直接在在tab里面拖控件(卧槽,才晓得可以这样)

ps:改变tab子名称

在ui中有个currentTabText,修改即可

 六、使用QColorDialog选取颜色

此类在设计师中没有存在其控件,需要自己用代码实现。此类提供一个静态方法getColor()来获取颜色

QColor color = QColorDialog::getColor(Qt::white,this);//第一个参数是打开是默认显示的参数,后面是其父类

 七、QLineEdit

1、设置颜色

QPalette palette;

QColor myColor(255,0,0);

palette.setColor(QPalette::Text,myColor);

ui->lineEdit->setPalette(palette);

2、设置提示输入

ui->lineEdit->setPlaceholderText("输入密码");

3、设置输入密码模式

ui里设置echoMode为password

4、设置字符串右对齐

ui->lineEdit->setAlignment(Qt::AlignRight);

5、设置只输入数据



QIntValidator validator(0, LONG_MAX, this );
le->setValidator(&validator);


 

八、QTableWidget

1、属性设置

ui->tableWidget->setSelectionBehavior(QAbstractItemView::SelectRows);//选中一行

ui->tableWidget->setSelectionMode(QAbstractItemView::ExtendedSelection);//可多选

ui->tableWidget->horizontalHeader()->setStyleSheet("QHeaderView::section{background:skyblue;}"); //设置表头背景色

ui->tableWidget->setEditTriggers(QAbstractItemView::NoEditTriggers);//设置只读

ui->tableWidget->setContextMenuPolicy(Qt::CustomContextMenu);//鼠标右键发出customContextMenuRequested信号

ui->tableWidget->verticalHeader()->setVisible(false); //隐藏行表头

ui->tableWidget->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);//占满

2、增加行、列

ui->tableWidget->insertRow(ui->tableWidget->rowCount());//这是在最后面增加一行,在当前增加一行是使用currentRow

ui->tablelWidget->insertColumn(ui->tableWidget->columnCount());//在最后面增加一列,在当前增加一列是使用currentColumn

int rowCount = ui.tableWidget->rowCount() - 1;//获取总的行号

ui.tableWidget->setItem(rowCount, 0, new QTableWidgetItem(QString(内容)));//设置新增行的0列内容

ui.tableWidget->setItem(rowCount, 1, new QTableWidgetItem(QString(内容)));//设置新增行的1列内容

3、为增加行、列设置内容

ui->tableWidget->setItem(行号,列号,new QTableWidgetItem(QString(内容)));

4、删除行、列

ui->tableWidget->removeRow(行号);

ui->tableWidget->removeColumn(列号);

5、界面适应数据

ui->tableWidget->resizeRowsToContents();//界面适应数据

ui->tableWidget->resizeColumnsToContents();

6、显示最后 一行

ui->tableWidget->scrollToBottom();

7、获取数据

用tableWidget::item::text;

8、判断某一格子是否为空

NULL==ui->tableWidget->item(i,j)//item可能是空指针,所以不能item.text

9、删除所有行

ui.tableWidget->clearContents();

ui.tableWidget->setRowCount(0);

10、窗口固定大小,可以设置最后一览固定大小,那最后一列后边总有空白,如果要让每行内容充满整个表格,需要设置head属性:

ui.tableWidget->horizontalHeader()->setStretchLastSection(true); 

11、设置文字区中

ui->tableWidget->item(i, j)->setTextAlignment(Qt::AlignCenter);//感觉效率不高

12、动态为tablewidget添加窗口

①、新建ui类Test

②、在main里new出ui对象test

③、ui->tabWidget->setCurrentIndex(ui->tabWidget->addTab(test, "test界面"));//addTab返回新增加的界面index

13、设置tablewidget可关闭

在设计师里:

QT控件学习_ico_02

ps:这里的关闭相当于是隐藏,并不会回收内存,上面的数据依旧在跑

14、右键双击清空

①、在初始化中

ui.tableWidget->setContextMenuPolicy(Qt::CustomContextMenu);//使能鼠标右键

②、在初始化中连接鼠标右键双击信号槽

QObject::connect(ui.tableWidget, SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(tableWidgetContextSlot(QPoint)));//tablewidget鼠标右键

③、在槽函数中

if (0)//免得有警告

{

qDebug() << pos.rx();

}

ui.tableWidget->clearContents();

ui.tableWidget->setRowCount(0);

15、插入checkBox



1、插入
QTableWidgetItem *check = new QTableWidgetItem;
check->setCheckState(Qt::Unchecked);
ui.tableWidget->setItem(0, 0, check);
2、使用


 if (ui.tableWidget->item(0, 0)->checkState() == Qt::Checked)

 {

    。。。

 }


 16、设置相邻两行颜色交替



ui.tableWidget->setAlternatingRowColors(true);
ui.tableWidget->setStyleSheet("border 0px;color:#6b6d7b;alternate-background-color:red;background:white;");


QT控件学习_html_03

 ps:给这个tablewidget设置了背景色之后,取出里面的控件,无法获取其控件颜色

 17、添加选取颜色的按钮

①、封装QPushButton子类:https://www.cnblogs.com/judes/p/9592637.html

②、添加按钮控件



MyQPushButton* btn = new MyQPushButton(this);//颜色
btn->setColor();//设置随机颜色
ui.tableWidget->setCellWidget(i, 4, btn);

//MyQPushButton是QPushButton子类


③、获取控件



((MyQPushButton*)ui.tableWidget->cellWidget(i, 4))->palette().color(QPalette::Button);//一定要转化为指针,否则得不到此控件


 QT控件学习_控件_04

 18、设置最后一列占满

tablewidget->horizontalHeader()->setStretchLastSection(true);

19、选中不要虚线

在QSS中:



QTableWidget{
outline:0px;
}


 20、自定义控件居中显示

设置:



WarnLabel* label = new WarnLabel(ui->tableWidget);//状态,设置大小居中
label->setMinimumSize(30,30);
label->setMaximumSize(30,30);
label->setObjectName("state");
QWidget* widget = new QWidget(ui->tableWidget);
QVBoxLayout *v = new QVBoxLayout;
v->addWidget(label);
v->setAlignment(label,Qt::AlignCenter);
v->setSpacing(0);
v->setMargin(0);
widget->setLayout(v);
ui->tableWidget->setCellWidget(rowCount, 3, widget);


20210712更新:

其实可以不用加布局也能居中,默认设置widget控件是占满的,通过设置QSS里margin-top、margin-botto、margin-left和margin-right相同即可;

同样适用与QTreewidget居中

 

获取:



ui->tableWidget->cellWidget(rowCount, 3)->findChild<WarnLabel*>("state")->changeColor((Label_Color)query.value("state").toInt());


 QT控件学习_右键_05

 21、设置某行某列隐藏

setColumnHidden

setRowHidden

 22、设置了cellWidget之后,解决焦点问题【如嵌入一个checkbox,点击之后,可能焦点一直就被checkbox获取了,tablewidget就有了点不动的感觉】



ui->tableWidget->insertRow(ui->tableWidget->rowCount());
ui->tableWidget->setItem(ui->tableWidget->rowCount()-1,0,new QTableWidgetItem(QString::number(devBriefInfo.devId)));
QCheckBox* checkBox = new QCheckBox(ui->tableWidget);
checkBox->setFocusPolicy(Qt::NoFocus);
checkBox->setChecked(devBriefInfo.isRunning);
ui->tableWidget->setCellWidget(ui->tableWidget->rowCount()-1,1,checkBox);


 23、设置和获取header标题



ui->tableWidget->setHorizontalHeaderItem(ui->tableWidget->columnCount()-1,new QTableWidgetItem(oneField.name));//设置
ui->tableWidget->horizontalHeaderItem(colIndex);//获取


 24、设置某个item不可编辑



QTableWidgetItem *nameItem = new QTableWidgetItem(name);
nameItem->setFlags(nameItem->flags() & (~Qt::ItemIsEditable));
ui->tableWidget->setItem(0, i, nameItem);


 25、文本居中



void Mymethod::setTableAligCenter(QTableWidget *tw)
{
int rowCount = tw->rowCount();
int columCount = tw->columnCount();
for(int row=0;row<rowCount;row++)
{
for(int colum=0;colum<columCount;colum++)
{
QTableWidgetItem* item = tw->item(row, colum);
if(item != nullptr)
{
item->setTextAlignment(Qt::AlignCenter);//感觉效率不高
}
}
}
}


 26、删除指定cell



pTable->removeCellWidget(i, VALUE_5);


27、动态设置标题内容 



QStringList header;
header<<"序号"<<"测试流程"<<"合格判断"<<"实测值"<<"测试结果";
pnewTable->setHorizontalHeaderLabels(header);


 

28、设置某些列指定宽度,同时某些列占满



pnewTable->setColumnWidth(VALUE_0, TABLE_COLUM_MIN_WIDTH);
pnewTable->horizontalHeader()->setSectionResizeMode(VALUE_1, QHeaderView::Stretch);
pnewTable->horizontalHeader()->setSectionResizeMode(VALUE_2, QHeaderView::Stretch);
pnewTable->horizontalHeader()->setSectionResizeMode(VALUE_3, QHeaderView::Stretch);
pnewTable->setColumnWidth(VALUE_4, TABLE_COLUM_MIN_WIDTH);
pnewTable->resizeColumnsToContents();
pnewTable->resizeRowsToContents();
pnewTable->setWordWrap(true);


QT控件学习_ico_06

 

 29、设置某一个单元格不可编辑



QTableWidgetItem* pItemNum = pTableWidget->item(row, VALUE_1);
pItemNum->setFlags(pItemNum->flags() & 33);


 

 

九、QTreeWidget

QTreewidget分两种内容,一是顶层节点,二是子节点

1、设置显示label

ui->treeWidget->setHeaderLabel("设备总览");

2、设置图标

ui->treeWidget->setIcon(0,QIcon);

3、设置顶层节点

QTreeWidgetItem *tempTopItemPc = new QTreeWidgetItem(QStringList()<<"电脑类");

tempTopItemPc->setCheckState(0,Qt::Unchecked);//是否有勾选复选框

4、为顶层节点设置子节点

QTreeWidgetItem *tempSubItem = new QTreeWidgetItem(QStringList()<<"PC001");

tempTopItemPc->addChild(tempSubItem);

5、把顶层节点放在tree中

ui->treeWidget->addTopLevelItem(tempTopItemPc);

6、其他

ui->treeWidget->setDragEnabled(true);//可以拖曳

ui->treeWidget->setAcceptDrops(true);//允许item接受拖曳过来的item

ui->treeWidget->setRootIsDecorated(false);//顶层节点不要装饰,即顶层节点不能收缩

ui->treeWidget->expandAll(); //结点全部展开

7、遍历所有item,如果item是想要的项则选中

QTreeWidgetItemIterator it(ui->treeWidget);

while (*it)

{

  if ((*it)->text(0) == tabBarStr)

  {

    (*it)->setSelected(true);

  }

  else

  {

    (*it)->setSelected(false);

  }

  ++it;

}

8、遍历所有item,把具备查询条件的所有项删除

// 查找 与轨检完全一致的项,并返回。

QList<QTreeWidgetItem*> s = ui->treeWidget->findItems(QStringLiteral("轨检"), Qt::MatchFlag::MatchExactly);

for (auto item : s)

{

delete item;

}

好像ui->treeWidget->takeTopLevelItem(5);也可以

9、把根节点的三角形去掉

QT控件学习_控件_07

 10、在项中插入其他控件

void QTreeWidget::setItemWidget(QTreeWidgetItem * item, int column, QWidget * widget)

11、通过样式表设置三角形为自定义图片

ui->treeWidget->setStyleSheet("QTreeView::branch:has-children:!has-siblings:closed,\

QTreeView::branch:closed:has-children:has-siblings{border-image: none; image: url(:/new/prefix1/right.png);}\

QTreeView::branch:open:has-children:!has-siblings,\

QTreeView::branch:open:has-children:has-siblings{border-image: none; image: url(:/new/prefix1/bottom.png);}");

加粗为自己的图片

12、Qlabel设置居中显示

在设计师里,找到alignment的“水平的”属性,改为居中

13、QSlider

常用信号

QT控件学习_json_08

 

14、将json里的信息在tree里显示

json格式为:



jsonStr = "{"
"\"common_property\": [{\"设备名称\": \"天线\"},{\"设备序号\": 100},{\"设备状态\": \"在线\"}],"
"\"special_property\": [{\"私有属性1\": 100},{\"私有属性2\": 200}]"
"}";


动态显示:



void NetNodeInfo::setInfo(const QString& jsonInfo)
{
//设置属性值
this->reset();
QJsonParseError json_error;
QJsonDocument jsonDoc(QJsonDocument::fromJson(jsonInfo.toLocal8Bit().data(), &json_error));//将内容转为json

if(json_error.error != QJsonParseError::NoError)
{
qDebug()<< getCodeLocate();
return;
}

QJsonObject rootObj = jsonDoc.object();//获取json文档对象
if(rootObj.contains(keyCommProperty))//公共属性
{
QJsonArray subAry = rootObj.take(keyCommProperty).toArray();

QStringList commList;
commList << "公共属性";
QTreeWidgetItem *commRoot = new QTreeWidgetItem(ui->treeWidget, commList);

for(auto oneAry : subAry)
{
QVariantMap map = oneAry.toObject().toVariantMap();
QStringList t;
t << map.begin().key() << map.begin().value().toString();
commRoot->addChild(new QTreeWidgetItem(commRoot, t));
}
ui->treeWidget->addTopLevelItem(commRoot);//添加整个公共属性节点
}
else
{
qDebug()<< getCodeLocate();
}
if(rootObj.contains(keySpecProperty))//私有属性
{
QJsonArray subAry = rootObj.take(keySpecProperty).toArray();

QStringList commList;
commList << "私有属性";
QTreeWidgetItem *commRoot = new QTreeWidgetItem(ui->treeWidget, commList);

for(auto oneAry : subAry)
{
QVariantMap map = oneAry.toObject().toVariantMap();
QStringList t;
t << map.begin().key() << map.begin().value().toString();
commRoot->addChild(new QTreeWidgetItem(commRoot, t));
}
ui->treeWidget->addTopLevelItem(commRoot);//添加整个公共属性节点
}
else
{
qDebug()<< getCodeLocate();
}
ui->treeWidget->expandAll();
}


 15、遍历文件夹并见里面各json文件以树的形式显示【非递归】



QString path = "cfg/fault_diagnose_cfg/fix_card/";
QStringList names = dir.entryList(QDir::Dirs);
names.removeOne(".");
names.removeOne("..");
int fileSize = names.size();
for(int i = VALUE_0; i < fileSize; i++){
QTreeWidgetItem *item = new QTreeWidgetItem(ui->treeWidget_fix_card);
item->setText(VALUE_0, names.at(i));
QString strPath = QString(path+"/%1").arg(names.at(i));
QDir strDir(strPath);
QStringList strNames = strDir.entryList(QDir::Files);
for(int i = VALUE_0; i < strNames.size(); i++){
QTreeWidgetItem *subItem = new QTreeWidgetItem(item);
subItem->setText(VALUE_0, strNames.at(i));
item->addChild(subItem);
}
}


QT控件学习_html_09

 16、递归显示文件夹内容



QFileInfoList MainWindow::allfile(QTreeWidgetItem *root,QString path)         //参数为主函数中添加的item和路径名
{
/*添加path路径文件*/
QDir dir(path); //遍历各级子目录
#if 1
QDir dir_file(path); //遍历子目录中所有文件
dir_file.setFilter(QDir::Files | QDir::Hidden | QDir::NoSymLinks); //获取当前所有文件
dir_file.setSorting(QDir::Size | QDir::Reversed);
QFileInfoList list_file = dir_file.entryInfoList();
for (int i = 0; i < list_file.size(); ++i) { //将当前目录中所有文件添加到treewidget中
QFileInfo fileInfo = list_file.at(i);
QString name = fileInfo.fileName();
QTreeWidgetItem* child = new QTreeWidgetItem(QStringList()<<name);
if(fileInfo.isFile()){
child->setIcon(0, QIcon(":/imgs/img/file.png"));
} else{
child->setIcon(0, QIcon(":/imgs/img/file_dir.png"));
}
root->addChild(child);
}
#endif

QFileInfoList file_list = dir.entryInfoList(QDir::Files | QDir::Hidden | QDir::NoSymLinks);
QFileInfoList folder_list = dir.entryInfoList(QDir::Dirs | QDir::NoDotAndDotDot); //获取当前所有目录

for(int i = 0; i != folder_list.size(); i++) //自动递归添加各目录到上一级目录
{
QString namepath = folder_list.at(i).absoluteFilePath(); //获取路径
QFileInfo folderinfo = folder_list.at(i);
QString name = folderinfo.fileName(); //获取目录名
QTreeWidgetItem* childroot = new QTreeWidgetItem(QStringList()<<name);
if(folderinfo.isFile()){
childroot->setIcon(0, QIcon(":/imgs/img/file.png"));
} else{
childroot->setIcon(0, QIcon(":/imgs/img/file_dir.png"));
}
root->addChild(childroot); //将当前目录添加成path的子项
QFileInfoList child_file_list = allfile(childroot, namepath); //进行递归
file_list.append(child_file_list);
file_list.append(name);
}
return file_list;
}

void main()
{
QString path = Config::getInstance().getFilePath();
qDebug()<<path;
QTreeWidgetItem* root = new QTreeWidgetItem(ui->treeWidget, QStringList()<<"装备承制目录结构");
allfile(root, path);
}


QT控件学习_控件_10

 16、设置高度

设置qss:



QTreeWidget::item{
height:40px;
}


17、居中

QT控件学习_控件_11

 

 18、遍历Tree



QTreeWidgetItemIterator it(ui->treeWidget);
while (*it) {
QString fileName = (*it)->text(0);
QString locateStr = (*it)->text(1);++it;
}


其中0、1就是列数

 

 

十、QLable

1、加颜色



QPalette p;
p.setColor(QPalette::WindowText,Qt::red);
ui->label->setPalette(p);


 十一、QLineEdit

1、设置密码登录



ui->lineEdit->setEchoMode(QLineEdit::Normal);//设置输入时正常显示输入文字
ui->lineEdit_2->setEchoMode(QLineEdit::Password);//设置输入时不显示文字,显示特殊字符


 2、设置提示



ui->lineEdit->setPlaceholderText("请输入用户");//设置提醒文字,在输入时会自动消失


3、设置只能输入int



QLineEdit* le = new QLineEdit(log);
le->setMaximumWidth(120);
QIntValidator validator(0, LONG_MAX, this );
le->setValidator(&validator);


 十二、QStackWidget

1、动态为每个stack添加界面

①、新建widget界面类

②、



qj_interface = new QJInterface;//new
ui->uiStackedWidget->addWidget(qj_interface);//添加
ui->uiStackedWidget->setCurrentWidget(qj_interface);//设置


 十三、QListWidget 

1、常规显示字符串



QListWidget *view = new QListWidget;
view->setWindowTitle(QString::fromLocal8Bit("ListWidget"));
view->resize(QSize(350, 50));
/* 设置为列表显示模式 */
view->setViewMode(QListView::ListMode);
/* 从左往右排列 */
view->setFlow(QListView::LeftToRight);
/* 屏蔽水平滑动条 */
view->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
/* 屏蔽垂直滑动条 */
view->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
/* 设置为像素滚动 */
view->setHorizontalScrollMode(QListWidget::ScrollPerPixel);
/* 设置鼠标左键拖动 */
QScroller::grabGesture(view,QScroller::LeftMouseButtonGesture);
/* 装载数据 */
for (int i = 0; i < 10; i++) {
QListWidgetItem *item = new QListWidgetItem(QString::number(i));
/* 设置文字居中 */
item->setTextAlignment(Qt::AlignCenter);
view->addItem(item);
}
/* 设置样式 */
view->setStyleSheet(R"(
QListWidget { outline: none; border:1px solid gray; color: black; }
QListWidget::Item { width: 50px; height: 50px; }
QListWidget::Item:hover { background: #4CAF50; color: white; }
QListWidget::item:selected { background: #e7e7e7; color: #f44336; }
QListWidget::item:selected:!active { background: lightgreen; }
)");


QT控件学习_json_12

 

 

 2、自定义QListWidgetItem



for(auto oneDevice : deviceList)
{
QListWidgetItem* item = new QListWidgetItem(ui->listWidget);
item->setSizeHint(QSize(600,400));
Delegate* delegate = new Delegate(oneDevice, ui->listWidget);
ui->listWidget->addItem(item);
ui->listWidget->setItemWidget(item,delegate);
}


deviceList是一个结构体,代表所有设备的信息集合;

Delegate是一个QWidget子类,主要把一个设备进行显示

QT控件学习_ico_13

 

 

 

3、关于内存

很多具备MVC的控件如QListWidget,为其动态new子控件的时候,如果要全部回收怎么办呢?

一般这些控件都有clear函数,这个函数内部实现应该是把控件的所有子控件递归删除,所有不需要自己去写循环获取子控件指针再delete了

QT控件学习_右键_14

 4、删除行



ui->listWidget->takeItem(i);//删除之后此行没有了
ui->listWidget->removeItemWidget(plistWidgetItem);//删除之后,内容没有但是此行还有


 十四、QToolButton

1、设置图标和文字都显示

可以在ui中:

QT控件学习_右键_15

 

 也可以在代码中:



ui->toolButton_add->setToolButtonStyle(Qt::ToolButtonTextBesideIcon);


2、设置图标



ui->toolButton_add_normal->setIcon(QIcon(":/icon/icon/add.png"));


3、设置文字

直接在ui中双击设置即可

效果:

QT控件学习_json_16

 4、QSS中设置图标及图标大小



tb->setStyleSheet("QToolButton {"
"font: 16px \"Microsoft YaHei\";"
"min-width: 100px; min-height: 32px;"
"max-width: 100px; max-height: 32px;"
"border-radius: 10px;color: #FFFFFF;"
"qproperty-icon:url(:/main/stop.png);"
"qproperty-iconSize:32px 32px;}");


最后两行就是设置图标和图标大小,其他方法没成功过。

 

十五、QScrollArea

1、设置其内容为其他widget



params = new Params(this);
ui->scrollArea_param->setWidget(params);
Params是自定义QWidget子类


2、为了不和其他背景色冲突,设置颜色



①、QScrollArea的QSS
QScrollArea#scrollArea_param{
border: 0px solid;
background-color: rgba(0, 0, 0, 0);
}
②、widget的QSS,在内容Params构造函数中
this->setStyleSheet("QWidget#Params{background-color: rgba(0, 0, 0, 0);}");


 3、往params里添加数据,让界面体现出scroll的感觉

在params中:



QGridLayout* lay = new QGridLayout(); //动态构造生成
int total = 38;
int colum = 5;
for(int i=0; i<total; i++){
QPushButton* pZparam = new QPushButton(this);
lay->addWidget(pZparam, i/colum, i%colum);
}
this->setLayout(lay)


 4、或者



QWidget* pWdiget = new QWidget(this);
pWdiget->setObjectName("QWidget_raguar");
pWdiget->setStyleSheet("QWidget#QWidget_raguar{background-color: rgba(0, 0, 0, 0);}");
QGridLayout* lay = new QGridLayout(); //动态构造生成
int total = 101;
int colum = 5;
for(int i=0; i<total; i++){
ProgressArc* pZparam = new ProgressArc(pWdiget);
pZparam->setMinimumSize(120, 120);
lay->addWidget(pZparam, i/colum, i%colum);
}
pWdiget->setLayout(lay);
ui->scrollArea_predict_raguar->setWidget(pWdiget);


QT控件学习_json_17

 注意必须给scrollArea也设置透明背景才行



QScrollArea#scrollArea_predict_raguar{ 
  background-color: rgba(255, 255, 255, 0);
  border:0px solid #1B5FA1;
}


 十六、QLabel

1、设置下划线



QFont font;
font.setUnderline(true);//下划线
ui->label_cur_fault->setFont(font);


 




长风破浪会有时,直挂云帆济沧海!