zoukankan      html  css  js  c++  java
  • QListWidget添加自定义的widget并自动排序

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

    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;
    }
    

      

  • 相关阅读:
    如何才能成为一个真正的编程高手?
    C#中base 关键字的作用
    线程间值的传递
    C#多线程 线程的启动
    C#接口的作用(经典)
    IEnumerable和IQueryable和Linq的查询
    CSS-定位
    HTML 常用标签
    CSS十大选择器
    前端开发师职业生涯入坑指南
  • 原文地址:https://www.cnblogs.com/bclshuai/p/13749268.html
Copyright © 2011-2022 走看看