首页 > 编程语言 > 详细

QListWidget添加自定义的widget并自动排序

时间:2020-09-29 15:54:16      阅读:53      评论:0      收藏:0      [点我收藏+]

自己开发了一个股票智能分析软件,功能很强大,需要的点击下面的链接获取:

https://www.cnblogs.com/bclshuai/p/11380657.html

1.问题描述

项目中需要添加自定义的widget,有图片文字和按钮,如下图所示,但是Qlistwidget常规只能添加图片加文字,就需要自定义一个widget上面添加内容,并且自动按照相似度排序。

技术分享图片

 

 

 2.实现步骤

(1)自定义widgetItem界面

技术分享图片

 

 

 

(2)定义类去实现这个界面

//头文件
#ifndef COMPAREVIEW_H #define COMPAREVIEW_H #include <QWidget> #include "ui_CompareView.h" #include <QImage> #include"FaceDefine.h" class CompareView : public QWidget { Q_OBJECT public: CompareView(MatchData matchData); ~CompareView(); private: Ui::MatchWidget ui; MatchData m_matchData; }; #endif // COMPAREVIEW_H //源文件 #include "CompareView.h" CompareView::CompareView(MatchData matchData) { ui.setupUi(this); setWindowFlags(Qt::FramelessWindowHint); this->resize(120, 120); m_matchData = matchData; ui.MatchPercent->setText(QString::number(m_matchData.matchPercent*100)+"%"); QPixmap pix(matchData.strTargetPath); pix = pix.scaled(this->size(), Qt::KeepAspectRatio, Qt::SmoothTransformation); ui.PicTarget->setPixmap(pix); } CompareView::~CompareView() { }

(3)定义往里面添加的函数

int FaceMatch::AddToMatchList(MatchData matchData)
{
	CompareView* cItemWidget = new CompareView(matchData);//新建widget对象
	QListWidgetItem* pItem = new QListWidgetItem(QString::number(matchData.matchPercent));//新建listwidget的一个item
	pItem->setData(257, matchData.matchPercent);//设置相似度,方便按照相似度排序
	pItem->setTextAlignment(Qt::AlignCenter);//设置居中显示
	pItem->setSizeHint(QSize(130, 130));//设一项的大小
	ui.listMatchWidget->addItem(pItem);//加入listwidget
	ui.listMatchWidget->setItemWidget(pItem, cItemWidget);//将新建的widget加入到item中
	ui.listMatchWidget->sortItems(Qt::DescendingOrder);//自动排序
	ui.labelMatchCount->setText(QString::number(ui.listMatchWidget->count()));//设置总的数量
	return HPR_OK;
}

  

QListWidget添加自定义的widget并自动排序

原文:https://www.cnblogs.com/bclshuai/p/13749268.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!