在上一篇博文《C/C++ Qt ListWidget 列表框組件應(yīng)用》
中介紹了ListWidget組件的基本使用技巧,本次將給ListWidget組件增加一個(gè)右鍵菜單,當(dāng)用戶(hù)在ListWidget組件中的任意一個(gè)子項(xiàng)下右鍵,我們讓其彈出這個(gè)菜單,并根據(jù)選擇提供不同的功能。
站在用戶(hù)的角度思考問(wèn)題,與客戶(hù)深入溝通,找到衛(wèi)輝網(wǎng)站設(shè)計(jì)與衛(wèi)輝網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶(hù)體驗(yàn)好的作品,建站類(lèi)型包括:成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名申請(qǐng)、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋衛(wèi)輝地區(qū)。
為了增加菜單,我們首先需要在程序全局增加QAction
其中每一個(gè)QAction則代表一個(gè)菜單選項(xiàng)指針。
// 全局下設(shè)置增加菜單
QAction *NewAction;
QAction *InsertAction;
QAction *DeleteAction;
其次則是通過(guò)代碼的方式在程序中動(dòng)態(tài)創(chuàng)建一個(gè)基礎(chǔ)的右鍵菜單,并對(duì)該菜單設(shè)置子菜單以及所對(duì)應(yīng)的圖標(biāo)組,最后就是將信號(hào)連接到指定的全局菜單指針上即可,這個(gè)代碼實(shí)現(xiàn)如下。
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include
#include
#include
#include
// 全局下設(shè)置增加菜單
QAction *NewAction;
QAction *InsertAction;
QAction *DeleteAction;
// By: LyShark
// https://www.cnblogs.com/lyshark
MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
ui->setupUi(this);
// 使用 customContextMenuRequested 信號(hào)則需要設(shè)置
ui->listWidget->setContextMenuPolicy(Qt::CustomContextMenu);
// 隱藏菜單欄上的右擊菜單
this->setContextMenuPolicy(Qt::NoContextMenu);
// 創(chuàng)建基礎(chǔ)頂部菜單
QMenuBar *bar = menuBar();
this->setMenuBar(bar);
QMenu * fileMenu = bar->addMenu("菜單1");
bar->setVisible(false); // 隱藏頂部菜單欄
// 添加子菜單
NewAction = fileMenu->addAction("增加IP地址");
InsertAction = fileMenu->addAction("插入IP地址");
DeleteAction = fileMenu->addAction("刪除IP地址");
// 分別設(shè)置圖標(biāo)
NewAction->setIcon(QIcon(":/image/1.ico"));
InsertAction->setIcon(QIcon(":/image/2.ico"));
DeleteAction->setIcon(QIcon(":/image/3.ico"));
// 綁定槽函數(shù)
connect(NewAction,&QAction::triggered,this,[=](){
std::cout << "new action" << std::endl;
ui->plainTextEdit->appendPlainText(QString("新建觸發(fā)"));
});
connect(InsertAction,&QAction::triggered,this,[=](){
std::cout << "insert action" << std::endl;
ui->plainTextEdit->appendPlainText(QString("插入觸發(fā)"));
});
// 以刪除為例,演示如何刪除選中行
connect(DeleteAction,&QAction::triggered,this,[=](){
int row = ui->listWidget->currentRow();
QListWidgetItem *aItem = ui->listWidget->takeItem(row);
delete aItem;
std::cout << "delete action" << std::endl;
ui->plainTextEdit->appendPlainText(QString("刪除觸發(fā)"));
});
}
MainWindow::~MainWindow()
{
delete ui;
}
// 當(dāng)listWidget被右鍵點(diǎn)擊時(shí)則觸發(fā)
void MainWindow::on_listWidget_customContextMenuRequested(const QPoint &pos)
{
std::cout << "x pos = "<< pos.x() << "y pos = " << pos.y() << std::endl;
Q_UNUSED(pos);
// 新建Menu菜單
QMenu *ptr = new QMenu(this);
// 添加Actions創(chuàng)建菜單項(xiàng)
ptr->addAction(NewAction);
ptr->addAction(InsertAction);
// 添加一個(gè)分割線(xiàn)
ptr->addSeparator();
ptr->addAction(DeleteAction);
// 在鼠標(biāo)光標(biāo)位置顯示右鍵快捷菜單
ptr->exec(QCursor::pos());
// 手工創(chuàng)建的指針必須手工刪除
delete ptr;
}
代碼運(yùn)行效果如下:
ListWidget同樣支持一圖標(biāo)方式顯示列表框內(nèi)的元素,只需要設(shè)置setViewMode(QListView::IconMode)
屬性即可實(shí)現(xiàn)圖標(biāo)顯示,我們按照如上代碼簡(jiǎn)單改進(jìn)即可,代碼如下:
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include
#include
#include
#include
// 全局下設(shè)置增加刪除菜單
QAction *NewAction;
QAction *InsertAction;
QAction *DeleteAction;
MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
ui->setupUi(this);
// 使用 customContextMenuRequested 信號(hào)則需要設(shè)置
ui->listWidget_2->setContextMenuPolicy(Qt::CustomContextMenu);
// 隱藏菜單欄上的右擊菜單
this->setContextMenuPolicy(Qt::NoContextMenu);
// 創(chuàng)建基礎(chǔ)頂部菜單
QMenuBar *bar = menuBar();
this->setMenuBar(bar);
QMenu * fileMenu = bar->addMenu("菜單1");
bar->setVisible(false); // 隱藏頂部菜單欄
// 添加子菜單
NewAction = fileMenu->addAction("增加IP地址");
InsertAction = fileMenu->addAction("插入IP地址");
DeleteAction = fileMenu->addAction("刪除IP地址");
// 分別設(shè)置圖標(biāo)
NewAction->setIcon(QIcon(":/image/1.ico"));
InsertAction->setIcon(QIcon(":/image/2.ico"));
DeleteAction->setIcon(QIcon(":/image/3.ico"));
// 綁定槽函數(shù)
connect(NewAction,&QAction::triggered,this,[=](){
std::cout << "new action" << std::endl;
});
connect(InsertAction,&QAction::triggered,this,[=](){
std::cout << "insert action" << std::endl;
});
// 以刪除為例,演示如何刪除選中行
connect(DeleteAction,&QAction::triggered,this,[=](){
int row = ui->listWidget_2->currentRow();
QListWidgetItem *aItem = ui->listWidget_2->takeItem(row);
delete aItem;
std::cout << "delete action" << std::endl;
});
// 第二個(gè)ListWidget_使用圖標(biāo)方式展示
ui->listWidget_2->setViewMode(QListView::IconMode);
// 每一行是一個(gè)QListWidgetItem
QListWidgetItem *aItem;
// 設(shè)置ICON的圖標(biāo)
QIcon aIcon;
aIcon.addFile(":/image/1.ico");
ui->listWidget_2->clear();
for(int x=0;x<10;x++)
{
QString str = QString::asprintf("admin_%d",x);
aItem = new QListWidgetItem(); // 新建一個(gè)項(xiàng)
aItem->setText(str); // 設(shè)置文字標(biāo)簽
aItem->setIcon(aIcon); // 設(shè)置圖標(biāo)
//aItem->setCheckState(Qt::Checked); // 設(shè)為選中狀態(tài)
aItem->setFlags(Qt::ItemIsSelectable | // 設(shè)置為不可編輯狀態(tài)
Qt::ItemIsUserCheckable
|Qt::ItemIsEnabled);
ui->listWidget_2->addItem(aItem); //增加項(xiàng)
}
}
MainWindow::~MainWindow()
{
delete ui;
}
// By: LyShark
// https://www.cnblogs.com/lyshark
void MainWindow::on_listWidget_2_customContextMenuRequested(const QPoint &pos)
{
std::cout << "x pos = "<< pos.x() << "y pos = " << pos.y() << std::endl;
Q_UNUSED(pos);
// 新建Menu菜單
QMenu *ptr = new QMenu(this);
// 添加Actions創(chuàng)建菜單項(xiàng)
ptr->addAction(NewAction);
ptr->addAction(InsertAction);
// 添加一個(gè)分割線(xiàn)
ptr->addSeparator();
ptr->addAction(DeleteAction);
// 在鼠標(biāo)光標(biāo)位置顯示右鍵快捷菜單
ptr->exec(QCursor::pos());
// 手工創(chuàng)建的指針必須手工刪除
delete ptr;
}
代碼運(yùn)行效果如下: