您的位置:首页 > 新闻 > 资讯 > Qt第十一章 其他控件

Qt第十一章 其他控件

2024/12/23 7:39:20 来源:https://blog.csdn.net/yerennuo/article/details/140079661  浏览:    关键词:Qt第十一章 其他控件

其他控件

文章目录

  • 其他控件
    • 按钮组
    • 项目小部件
    • 输入控件
    • 显示控件
    • 容器

按钮组

  1. 命令链接按钮
    在这里插入图片描述

  2. 对话框按钮盒子
    在这里插入图片描述
    添加基础按钮
    在这里插入图片描述
    改变排列方向
    在这里插入图片描述

项目小部件

  1. 列表控件List Widget
    在这里插入图片描述
    也可以通过代码添加
    // 添加ui->listWidget->addItem("你好啊");ui->listWidget->addItem(new QListWidgetItem("heelo"));auto item1 = new QListWidgetItem("插入项");ui->listWidget->insertItem(2, item1); // 在第二行插入qDebug() << ui->listWidget->count(); // 获取有多少个项ui->listWidget->takeItem(0); // 移除第0行,但原指针还在,要彻底删除要调用delete
  1. 树控件Tree Widget
    在这里插入图片描述在这里插入图片描述
    通过代码实现改变
    ui->treeWidget->setColumnCount(5); // 设置成5列ui->treeWidget->setHeaderLabels(QStringList() << "名称"<< "修改日期"<< "类型"<< "大小"<< "所属组"); // 设置标题auto rootItem = new QTreeWidgetItem(QStringList() << "E盘"<< "2024-3-4"<< "磁盘"<< "1323"); // 定义一个项目ui->treeWidget->addTopLevelItem(rootItem); // 增加一个根项目rootItem->addChild(new QTreeWidgetItem(QStringList() << "学习资料")); // 在当前根下面添加子项目ui->treeWidget->takeTopLevelItem(1); // 移除第2个根项目,伪删除rootItem->takeChild(0); // 删除子项目ui->treeWidget->setCurrentItem(ui->treeWidget->topLevelItem(0), 0, QItemSelectionModel::Select); // 默认选中第1个根的第0列ui->treeWidget->setSortingEnabled(true); // 启用排序,默认降序    
  1. 表格控件Table Widget
    在这里插入图片描述
    qDebug() << "行数" << ui->tableWidget->rowCount() << "列数" << ui->tableWidget->columnCount();auto tableItem = new QTableWidgetItem("你好啊");ui->tableWidget->setItem(0, 0, tableItem); // 在第0行第0列设置元素ui->tableWidget->setHorizontalHeaderLabels(QStringList() << "名字"); // 设置列标签ui->tableWidget->setVerticalHeaderLabels(QStringList() << "姓名"); // 设置行标签ui->tableWidget->setEditTriggers(QTableWidget::DoubleClicked); // 设置鼠标双击才能编辑ui->tableWidget->takeItem(0, 1); // 删除第1行,第2列ui->tableWidget->takeHorizontalHeaderItem(0); // 删除第1列标签

输入控件

  1. 文本编辑器

    文本框手动插入图片
    // 手动插入图片QString path = QFileDialog::getOpenFileName();if (path.isNull())return;QImage img = QImageReader(path).read(); // 获取选择地址的图片QUrl url = path;ui->textEdit->document()->addResource(QTextDocument::ImageResource, url, img);QTextImageFormat imgfmt;imgfmt.setName(url.toString());imgfmt.setWidth(100);imgfmt.setHeight(120);ui->textEdit->textCursor().insertImage(img); // 在光标位置插入图片
  1. 纯文本编辑器
  2. 旋转盒(微调框)
    在这里插入图片描述
    在这里插入图片描述
 	ui->spinBox->setRange(0, 100); // 设置范围ui->spinBox->setSuffix("厘米"); // 设置后缀ui->timeEdit->setMaximumTime(QTime(12, 1, 1)); // 设置最大时间,12点1分1秒ui->dateEdit->setMaximumDate(QDate(2025, 12, 1)); // 设置最大日期,2025年12月1日ui->dateTimeEdit->setMaximumDateTime(QDateTime(QDate(2025, 12, 1), QTime(12, 1, 1)));ui->timeEdit->setDisplayFormat("hh:mm:ss"); // 设置时间显示格式,例如04:01:15ui->dateTimeEdit->setCalendarPopup(true); // 设置日历弹出,会有个下拉箭头,点一下弹出日历
  1. 刻度盘
    在这里插入图片描述
    ui->dial->setRange(50, 100);ui->dial->setNotchesVisible(true); // 显示周围刻度ui->dial->setSingleStep(5); // 设置步长ui->dial->setWrapping(true); // 设置环绕,如果是false,就不能在范围之外转了,默认false//连接槽void Widget::on_dial_valueChanged(int value){qDebug() << "刻度盘:" << value;}
  1. 滑动条
    在这里插入图片描述
    连接槽
void Widget::on_horizontalScrollBar_valueChanged(int value)
{ui->dial->move(value, ui->dial->geometry().y());//让刻度盘跟着滑动条滑动
}
  1. 滑块
    在这里插入图片描述
    类似于滑动条

7.键序列编辑器
在这里插入图片描述

void Widget::on_keySequenceEdit_editingFinished()
{qDebug() << "这是快捷键";
}void Widget::on_pushButton_clicked()
{ui->keySequenceEdit->clear(); // 按下旁边新建的按钮,清除当前快捷键
}

显示控件

  1. 文本浏览器textBrowser

只能浏览,不能改变
继承自QTextEdit
在这里插入图片描述

ui->textBrowser->setSource(QUrl("qrc:/example.html"));
  1. 日历
  2. LCD数码管
    ui->lcdNumber->setDigitCount(10); // 设置显示位数ui->lcdNumber->display("123.123"); // 如果之前不设置显示位数,默认显示是3.123
  1. 进度条

容器

  1. 组框
  2. 滚动区域
  3. 工具箱
  4. 选项卡
  5. 栈控件
  6. MDI区域

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com