Qt实现类似淘宝商品展示看板功能简版

前一篇文章的简化版本只有浏览功能,前一篇文章链接如下:

Qt实现类似淘宝商品看板的界面,带有循环翻页以及点击某页跳转的功能

效果如下:

代码留给有需要的人。

cpp 复制代码
#ifndef ModelDashboardGroup_h__
#define ModelDashboardGroup_h__

#include <QGridLayout>
#include <QLabel>
#include <QWidget>
#include <QScrollArea>

QT_BEGIN_NAMESPACE
namespace Ui { class CModelDashboardGroup; };
QT_END_NAMESPACE

class CModelDashboardGroup : public QWidget
{
	Q_OBJECT

public:
	CModelDashboardGroup(QWidget *parent = nullptr);
	~CModelDashboardGroup();

	void SetItemWidgetInfos(const std::vector<std::pair<QString, QString>>& vecItemWidgetInfo);
	void AddItemWidgetInfo(const QString& strModelName, const QString& strModelImagePath);

	// 设置每行展示的模型图片的数量
	void SetPerColItemsNumber(int nNumber);

private:
	void Init();
	void AddItemToGrid(int nIndex);
	void UpdateGrid();

private:
	Ui::CModelDashboardGroup *ui;

	std::vector<std::pair<QString, QString>> m_vecItemWidgetInfo; // 模型名称和展示图片路径

	QGridLayout* m_pGridLayout;
	QScrollArea* m_pScrollArea;

	int m_nPerRowPageItemsNumber;
};

#endif // ModelDashboardGroup_h__
cpp 复制代码
#include "ui_ModelDashboardGroup.h"
#include "ModelDashboardGroup.h"
#include "ModelDashboard.h"

CModelDashboardGroup::CModelDashboardGroup(QWidget *parent)
	: QWidget(parent)
	, ui(new Ui::CModelDashboardGroup())
	, m_pGridLayout(NULL)
	, m_nPerRowPageItemsNumber(5)
{
	ui->setupUi(this);
	setAttribute(Qt::WA_TranslucentBackground, true); // 设置窗口背景透明
	Init();

	// 测试数据
	if (1)
	{
		std::vector<std::pair<QString, QString> > vecItemWidgetInfo;
		for (int i = 1; i <= 105; ++i)
		{
			// 增加商品数量以测试分页
			vecItemWidgetInfo.push_back(std::make_pair(QString::fromLocal8Bit("模型%1").arg(i), QString::fromLocal8Bit(":/dotnetIcon.png")));
		}

		SetItemWidgetInfos(vecItemWidgetInfo);
	}
	else
	{
		UpdateGrid();
	}
}

CModelDashboardGroup::~CModelDashboardGroup()
{
	delete ui;
}

void CModelDashboardGroup::SetItemWidgetInfos(const std::vector<std::pair<QString, QString>>& vecItemWidgetInfo)
{
	m_vecItemWidgetInfo.clear();
	m_vecItemWidgetInfo = vecItemWidgetInfo;
	UpdateGrid();
}

void CModelDashboardGroup::AddItemWidgetInfo(const QString& strModelName, const QString& strModelImagePath)
{
	m_vecItemWidgetInfo.push_back(std::make_pair(strModelName, strModelImagePath));
	UpdateGrid();
}

void CModelDashboardGroup::SetPerColItemsNumber(int nNumber)
{
	m_nPerRowPageItemsNumber = nNumber;
	UpdateGrid(); // Update the grid layout when the number of columns is set or changed
}

void CModelDashboardGroup::Init()
{
	QVBoxLayout* pMainLayout = new QVBoxLayout(this);

	m_pScrollArea = new QScrollArea(this);
	m_pScrollArea->setWidgetResizable(true);
	m_pScrollArea->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
	m_pScrollArea->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);

	QWidget* pGridWidget = new QWidget(this);
	m_pGridLayout = new QGridLayout(pGridWidget);
	m_pGridLayout->setSpacing(10);

	pGridWidget->setLayout(m_pGridLayout);
	m_pScrollArea->setWidget(pGridWidget);

	pMainLayout->addWidget(m_pScrollArea);
}

void CModelDashboardGroup::AddItemToGrid(int nIndex)
{
	CModelDashboard* pModelDashboard = new CModelDashboard();

	if (nIndex >= 0 && nIndex < m_vecItemWidgetInfo.size())
	{
		pModelDashboard->SetModelDisPlayName(m_vecItemWidgetInfo[nIndex].first);
		pModelDashboard->SetModelDisPlayImage(m_vecItemWidgetInfo[nIndex].second);
	}
	else
	{
		// 添加示例商品
		pModelDashboard->SetModelDisPlayName("模型");
		pModelDashboard->SetModelDisPlayImage(":/model03_normal.png");
	}

	int nRow = (m_pGridLayout->count() / m_nPerRowPageItemsNumber);  // 计算行数
	int nCol = (m_pGridLayout->count() % m_nPerRowPageItemsNumber);  // 计算列数
	m_pGridLayout->addWidget(pModelDashboard, nRow, nCol);
}

void CModelDashboardGroup::UpdateGrid()
{
	// 清空现有网格布局
	QLayoutItem* pItem;
	while ((pItem = m_pGridLayout->takeAt(0)) != NULL)
	{
		delete pItem->widget();
		delete pItem;
	}

	int nTotalItems = m_vecItemWidgetInfo.size();

	for (int i = 0; i < nTotalItems; ++i)
	{
		AddItemToGrid(i);
	}
}

CModelDashboard类实现示例参考上一篇文章。

相关推荐
一只小小汤圆6 分钟前
编译笔记:vs 中 正在从以下位置***加载符号 C# 中捕获C/C++抛出的异常
c++·c#
小俊俊的博客1 小时前
海康RGBD相机使用C++和Opencv采集图像记录
c++·opencv·海康·rgbd相机
7yewh1 小时前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
_WndProc2 小时前
C++ 日志输出
开发语言·c++·算法
薄荷故人_2 小时前
从零开始的C++之旅——红黑树及其实现
数据结构·c++
m0_748240022 小时前
Chromium 中chrome.webRequest扩展接口定义c++
网络·c++·chrome
qq_433554542 小时前
C++ 面向对象编程:+号运算符重载,左移运算符重载
开发语言·c++
努力学习编程的伍大侠2 小时前
基础排序算法
数据结构·c++·算法
yuyanjingtao3 小时前
CCF-GESP 等级考试 2023年9月认证C++四级真题解析
c++·青少年编程·gesp·csp-j/s·编程等级考试
闻缺陷则喜何志丹3 小时前
【C++动态规划 图论】3243. 新增道路查询后的最短距离 I|1567
c++·算法·动态规划·力扣·图论·最短路·路径