教你如何使用QT制作一个ListView列表

文章介绍了如何使用Qt自定义一个ListView,当点击ListView的Item时,可以触发不同的OpenCV图像处理效果,如像素取反、图像融合等。通过MainListView和MainListViewItem类的扩展,实现了鼠标事件处理和图标状态的变化。
摘要由CSDN通过智能技术生成

导读

这篇文章主要为大家详细介绍了如何使用Qt制作一个ListView,点击ListView的Item可以用于测试OpenCV的各种效果,感兴趣的小伙伴可以了解一下

1、概述

案例:使用Qt制作一个ListView。点击ListView的Item可以用于测试OpenCV的各种效果

自定义一个:MainListView继承QListWidget 、MainListViewItem继承QListWidgetItem

2、代码示例

1.自定义QListWidget

mainlistview.h

class MainListView : public QListWidget

{

Q_OBJECT

public:

explicit MainListView(QWidget *parent = nullptr);

protected:

void mousePressEvent(QMouseEvent *event);

void mouseReleaseEvent(QMouseEvent *event);

void mouseMoveEvent(QMouseEvent *event);

void leaveEvent(QEvent *event);

private:

QPoint startPoint;

MainListViewItem *theHighlightItem = nullptr;

MainListViewItem *oldHighlightItem = nullptr;

MainListViewItem *theSelectedItem = nullptr;

MainListViewItem *oldSelectedItem = nullptr;

Chapter3Option * option = new Chapter3Option();

signals:

public slots:

void updateSelectedIcon();

void onMainItemClick(QListWidgetItem *item);

};

mainlistview.cpp

#include "mainlistview.h"

MainListView::MainListView(QWidget *parent) : QListWidget(parent)

{

setMouseTracking(true);

//连接信号与槽函数,如果选中项发生变化则触发item图标的更新.都是当前对象发生

connect(this,&MainListView::itemSelectionChanged,this,&MainListView::updateSelectedIcon);

connect(this,&MainListView::itemClicked,this,&MainListView::onMainItemClick);

}

/**

* 处理鼠标hove事件,item图标就变成hove状态

* @brief MainListView::mouseMoveEvent

* @param event

*/

void MainListView::mouseMoveEvent(QMouseEvent *event){

oldHighlightItem = theHighlightItem;

theHighlightItem = static_cast(itemAt(event->pos())); //旧的hover的item图标回复原状(条件是该item没有被选中) //新的hover的iten图标变成hover状态(条件是该item没有被选中) if(oldHighlightItem != theHighlightItem){ if(oldHighlightItem && !oldHighlightItem->isSelected()) oldHighlightItem->setIcon(oldHighlightItem->mIcon); if(theHighlightItem && !theHighlightItem->isSelected()) theHighlightItem->setIcon(theHighlightItem->mIconHover); }} /** * 鼠标按下(这个可以当做item的点击事件,能够正常执行) * @brief MainListView::mousePressEvent * @param event */void MainListView::mousePressEvent(QMouseEvent *event){ if(event->buttons()&Qt::LeftButton){ startPoint = event->pos(); MainListViewItem *item = static_cast(itemAt(event->pos())); QString filePath = QFileDialog::getOpenFileName(this, tr("选择视频"), "C:\\Users\\wei.yang\\Downloads\\opencv_res", tr("Image Files(*.jpg *.png)")); const char *fileRealPath = filePath.toStdString().c_str();//将QString转换为char* qDebug() <text()<<"--->"<<filerealpath<<"--- style="box-sizing: border-box;">pos:"<mPos; switch (item->mPos) { case 1://显示原图 option->showSrcImage(fileRealPath); break; case 2://像素取反 option->pixleReverse(fileRealPath); break; case 3://图像融合 option->imageFuse("",""); break; case 4://调整图像亮度及对比度 option->increaseBrightnessContrastRatio(fileRealPath); break; case 5://绘制线、矩形、椭圆、圆、多边形、文本 option->drawShape(); break; case 6://均值模糊:用于图像的降噪 option->showBlur(fileRealPath); break; case 7://高斯模糊:用于图像的降噪,其对自然界的噪声有很好的抑制作用 option->showGaussianBlue(fileRealPath); break; case 8://中值滤波:终止滤波用于图像的降噪,其对椒盐噪声有很好的抑制作用(黑白点) option->showMediaBlur(fileRealPath); break; case 9://双边滤波:其可以很好的保留边缘的同时对平坦区域进行降噪 option->showBilateralFilter(fileRealPath); break; case 10://提起图像中的英文字母 option->showCleanImage(fileRealPath); break; case 11://形态学开操作 option->showImageOpen(fileRealPath); break; case 12:// 形态学闭操作 option->showImageClose(fileRealPath); break; case 13://形态学梯度(基本梯度):膨胀减去腐蚀 option->showMorphologicalGradient(fileRealPath); break; case 14://顶帽操作:相当于原图像与开操作之间的差值图像 option->showTopHat(fileRealPath); break; case 15://黑帽操作:相当于原图像与闭操作之间的差值图像 option->showBlackHat(fileRealPath); break; case 16://小案例:提取提取项目中的字母或者直线 option->showLines(fileRealPath,0); break; case 17://上采样:利用拉普拉斯金字塔进行图像重建 option->showPyrUp(fileRealPath); break; case 18://降采样:利用高斯金字塔进行降采样 option->showPyrDown(fileRealPath); break; case 19://高斯不同:把同一张图片再不同的参数下做高斯模糊之后的结果相减,得到的输出图像称为高斯不同 option->showGaussianDiff(fileRealPath); break; case 20://使用自定义卷积核filter2D option->showCustomKernelFilter2D(fileRealPath,1); break; case 21://1.合并rebort和sobel的x方向梯度和y方向的梯度 option->showCustomKernelFilter2DMergeXY(fileRealPath); break; case 22://填充图像边缘 option->showCopyMakeBorder(fileRealPath); break; case 23://使用Sobel和Scharr计算图形梯度 option->showSobelAndScharr(fileRealPath); break; case 24://使用拉普拉斯算子显示梯度图像 option->showLaplacian(fileRealPath); break; case 25://边缘检测 option->showCanny(fileRealPath); break; } }} /** * 释放鼠标 * @brief MainListView::mouseReleaseEvent * @param event */void MainListView::mouseReleaseEvent(QMouseEvent *event){ //如果鼠标释放位置和单击位置相距超过5像素,则不会触发item选中 if((event->pos() - startPoint).manhattanLength() > 5) return; MainListViewItem *item = static_cast(itemAt(event->pos())); setCurrentItem(item); }/** * 处理鼠标离开后,hover图标回复正常状态 * @brief MainListView::leaveEvent * @param event */void MainListView::leaveEvent(QEvent *event){ Q_UNUSED(event); oldHighlightItem = theHighlightItem; if(oldHighlightItem && !oldHighlightItem->isSelected()) oldHighlightItem->setIcon(oldHighlightItem->mIcon); oldHighlightItem = theHighlightItem = nullptr; } void MainListView::updateSelectedIcon(){ oldSelectedItem = theSelectedItem; theSelectedItem = static_cast(currentItem()); //之前被选中的item图标回复原样 //新被选中的item图标变成hover状态 if(oldSelectedItem != theSelectedItem){ if(oldSelectedItem) oldSelectedItem->setIcon(oldSelectedItem->mIcon); if(theSelectedItem) theSelectedItem->setIcon(theSelectedItem->mIconHover); }} //这个槽函数并没有执行void MainListView::onMainItemClick(QListWidgetItem *item){ qDebug() << "点击了item的项目";}

2.自定义QListWidgetItem

mainlistviewitem.h

class MainListViewItem : public QListWidgetItem

{

//Q_OBJECT //由于QListWidgetItem没有QObject属性,所以Q_OBJECT需要注释掉

public:

explicit MainListViewItem(QString itemTitle,const QIcon &icon, const QIcon &iconHover,int pos,QListWidget *parent = nullptr);

/**

* 设置item的图标

* @brief setItemIcon

* @param icon

* @param iconHover

*/

// void setItemIcon(const QIcon &icon,const QIcon &iconHover);

public:

QIcon mIcon;//默认图标

QIcon mIconHover;//选中时图标

int mPos;//第一个编辑

signals:

};

mainlistviewitem.cpp

#include "mainlistviewitem.h"

/**

* 自定义主页ListView的Item项

* @brief MainListViewItem::MainListViewItem

* @param parent

*/

MainListViewItem::MainListViewItem(QString itemTitle,const QIcon &icon, const QIcon &iconHover,int pos,QListWidget *parent) : QListWidgetItem(parent)

{

setText(itemTitle);

mIcon = icon;

mIconHover = iconHover;

setIcon(mIcon);

setSizeHint(QSize(360,47));

mPos = pos;

}

3.使用

void MainWindow::createListView(QWidget *parent){

listView = new MainListView(this);

listView->setFocusPolicy(Qt::NoFocus); //这样可禁用tab键和上下方向键并且除去复选框

listView->setFixedHeight(320);

listView->setFont(QFont("宋体", 14, QFont::DemiBold));

listView->setFixedSize(QSize(360,480));

listView->move(0,menuBar()->height());

listView->setStyleSheet(

"{outline:0px;}" //除去复选框

"MainListViewItem{background:rgb(245, 245, 247); border:0px; margin:0px 0px 0px 0px;}"

"MainListViewItem::Item{height:40px; border:0px; padding-left:14px; color:rgba(200, 40, 40, 255);}"

"MainListViewItem::Item:hover{color:rgba(40, 40, 200, 255);}"

"MainListViewItem::Item:selected{background:rgb(230, 231, 234); color:rgba(40, 40, 200, 255); border-left:4px solid rgb(180, 0, 0);}"

"QListWidget::Item:selected:active{background:rgb(230, 231, 234); color:rgba(40, 40, 200, 255); border-left:4px solid rgb(180, 0, 0);}");

new MainListViewItem("显示原图",QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),1,listView);

new MainListViewItem(tr("像素取反"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),2,listView);

new MainListViewItem(tr("图像融合"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),3,listView);

new MainListViewItem(tr("调整图像亮度及对比度"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),4,listView);

new MainListViewItem(tr("绘制线、矩形、椭圆、圆、多边形、文本"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),5,listView);

new MainListViewItem(tr("均值模糊"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),6,listView);

new MainListViewItem(tr("高斯模糊"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),7,listView);

new MainListViewItem(tr("中值滤波"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),8,listView);

new MainListViewItem(tr("双边滤波"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),9,listView);

new MainListViewItem(tr("提取图像中的英文字母"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),10,listView);

new MainListViewItem(tr("形态学开操作"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),11,listView);

new MainListViewItem(tr("形态学闭操作"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),12,listView);

new MainListViewItem(tr("形态学梯度(基本梯度)"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),13,listView);

new MainListViewItem(tr("顶帽操作"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),14,listView);

new MainListViewItem(tr("黑帽操作"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),15,listView);

new MainListViewItem(tr("小案例:提取提取项目中的字母或者直线"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),16,listView);

new MainListViewItem(tr("上采样"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),17,listView);

new MainListViewItem(tr("降采样"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),18,listView);

new MainListViewItem(tr("高斯不同"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),19,listView);

new MainListViewItem(tr("使用自定义卷积核filter2D"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),20,listView);

new MainListViewItem(tr("合并rebort及Sobel的x方向梯度和y方向的梯度"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),21,listView);

new MainListViewItem(tr("填充图像边缘"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),22,listView);

new MainListViewItem(tr("使用Sobel和Scharr计算图形梯度"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),23,listView);

new MainListViewItem(tr("使用拉普拉斯算子显示梯度图像"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),24,listView);

new MainListViewItem(tr("边缘检测"),QIcon(":res/icon_main_list.png"),QIcon(":res/icon_main_list.png"),25,listView);

// connect(listView,&MainListView::itemClicked,listView,&MainListView::onMainItemClick);

}

//最后一步:创建ListView,然后运行就行了

createListView(this);

3、图片演示

到此这篇关于QT实现制作一个ListView列表的示例代码的文章就介绍到这了

www.linuxprobe.com

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值