網站首頁 編程語言 正文
Qt窗體中默認會附加一個QstatusBar組件,狀態欄組件位于主窗體的最下方,其作用是提供一個工具提示功能,當程序中有提示信息是可以動態的顯示在這個區域內,狀態欄組件內可以增加任何Qt中的通用組件,只需要通過addWidget函數動態追加即可引入到底部,底部狀態欄在實際開發中應用非常普遍,以下代碼是對該組件基本使用方法的總結。
首先我們通過new新增3個QLabel組件,并將該組件依次排列在底部狀態欄內,實現代碼如下所示:
#include "mainwindow.h" #include "ui_mainwindow.h" #include <QLabel> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); // 初始化狀態欄 QLabel *labCellIndex = new QLabel("當前坐標: 0.0",this); labCellIndex->setMinimumWidth(250); QLabel *labCellType=new QLabel("單元格類型: null",this); labCellType->setMinimumWidth(200); QLabel *labStudID=new QLabel("學生ID: 0",this); labStudID->setMinimumWidth(200); // 將初始化的標簽添加到底部狀態欄上 ui->statusBar->addWidget(labCellIndex); ui->statusBar->addWidget(labCellType); ui->statusBar->addWidget(labStudID); } MainWindow::~MainWindow() { delete ui; }
運行代碼效果如下:
QLabel組件除了可以增加提示信息以外,通過設置setOpenExternalLinks可以將這個組件設置為以鏈接形式出現,有利于我們增加網頁跳轉等功能。
#include "mainwindow.h" #include "ui_mainwindow.h" #include <QLabel> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); // 隱藏狀態欄下方三角形 ui->statusBar->setSizeGripEnabled(false); // 新增標簽欄 QLabel *label_url = new QLabel(this); QLabel *label_about = new QLabel(this); // 配置連接 label_url->setFrameStyle(QFrame::Box | QFrame::Sunken); label_url->setText(tr("<a href=\"https://lyshark.cnblogs.com\">訪問主頁</a>")); label_url->setOpenExternalLinks(true); label_about->setFrameStyle(QFrame::Box | QFrame::Sunken); label_about->setText(tr("<a href=\"https://lyshark.cnblogs.com\">關于我</a>")); label_about->setOpenExternalLinks(true); // 將信息增加到底部(永久添加) ui->statusBar->addPermanentWidget(label_url); ui->statusBar->addPermanentWidget(label_about); } MainWindow::~MainWindow() { delete ui; }
運行代碼效果如下:
同理,只要是通用組件都可以被安置到底部菜單欄,如果我們需要增加進度條組件只需要這樣寫:
#include "mainwindow.h" #include "ui_mainwindow.h" #include <QLabel> #include <QProgressBar> QProgressBar *pro; MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); pro = new QProgressBar(this); // 自動計算 ui->statusBar->addPermanentWidget(pro, 1); // 設置進度是否顯示 pro->setTextVisible(true); // 設置初始化進度位置 pro->setValue(0); } MainWindow::~MainWindow() { delete ui; } void MainWindow::on_pushButton_clicked() { qint32 count = pro->value(); count = count +10; pro->setValue(count); }
運行代碼效果如下:
接著我們增加一個tablewidget并初始化參數,tableWidget組件存在一個on_tableWidget_currentCellChanged屬性,該屬性的作用是,只要Table表格存在變化則會觸發,當用戶選擇不同的表格,我們可以將當前表格行列自動設置到狀態欄中,從而實現同步狀態欄消息提示,起到時刻動態顯示的作用。
#include "mainwindow.h" #include "ui_mainwindow.h" #include <QLabel> #include <QTableWidget> #include <QTableWidgetItem> QLabel *labCellIndex; MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); // ------------------------------------------------------------------------------------ // 初始化狀態欄 labCellIndex = new QLabel("當前坐標: 0.0",this); labCellIndex->setMinimumWidth(250); // 將初始化的標簽添加到底部狀態欄上 ui->statusBar->addWidget(labCellIndex); // ------------------------------------------------------------------------------------ // 填充數據,對表格進行初始化操作 QStringList header; header << "姓名" << "性別" << "年齡"; ui->tableWidget->setColumnCount(header.size()); // 設置表格的列數 ui->tableWidget->setHorizontalHeaderLabels(header); // 設置水平頭 ui->tableWidget->setRowCount(5); // 設置總行數 ui->tableWidget->setEditTriggers(QAbstractItemView::NoEditTriggers); // 設置表結構默認不可編輯 // 填充數據 QStringList NameList; NameList << "lyshark A" << "lyshark B" << "lyshark C"; QStringList SexList; SexList << "男" << "男" << "女"; qint32 AgeList[3] = {22,23,43}; // 針對獲取元素使用 NameList[x] 和使用 NameList.at(x)效果相同 for(int x=0;x< 3;x++) { int col =0; // 添加姓名 ui->tableWidget->setItem(x,col++,new QTableWidgetItem(NameList[x])); // 添加性別 ui->tableWidget->setItem(x,col++,new QTableWidgetItem(SexList.at(x))); // 添加年齡 ui->tableWidget->setItem(x,col++,new QTableWidgetItem( QString::number(AgeList[x]) ) ); } } // 當前選擇單元格發生變化時觸發響應事件,也就是將底部狀態欄標簽設置 // https://www.cnblogs.com/lyshark void MainWindow::on_tableWidget_currentCellChanged(int currentRow, int currentColumn, int previousRow, int previousColumn) { Q_UNUSED(previousRow); Q_UNUSED(previousColumn); // 顯示行與列的變化數值 //std::cout << "currentRow = " << currentRow << " currentColumn = " << currentColumn << std::endl; //std::cout << "pre Row = " << previousRow << " pre Column = " << previousColumn << std::endl; // 獲取當前單元格的Item QTableWidgetItem *item = ui->tableWidget->item(currentRow,currentColumn); if(item == NULL) return; // 設置單元格坐標 labCellIndex->setText(QString::asprintf("當前坐標: %d 行 | %d 列",currentRow,currentColumn)); } MainWindow::~MainWindow() { delete ui; }
運行代碼效果如下:
原文鏈接:https://www.cnblogs.com/LyShark/p/15637184.html
相關推薦
- 2023-04-07 C#?PadLeft、PadRight用法詳解_C#教程
- 2022-07-29 Ubuntu中的sudo和su命令介紹_linux shell
- 2022-05-17 qt 解決Error while building/deploying project Hmi (k
- 2021-12-29 CentOS系統rpm安裝Nginx和配置_nginx
- 2022-04-08 swift自定義表格控件(UITableView)_Swift
- 2022-11-04 python使用tqdm模塊處理文件閱讀進度條顯示_python
- 2022-06-10 FreeRTOS使用任務通知實現命令行解釋器_操作系統
- 2022-07-19 typedef struct LNode *p和typedef struct LNode筆記
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支