在QListWidgetItem上绘制文字和图片

QListWidget上可以同时显示图片和文字,但是只有两种格式:1,图标上+文字下;2,图标左+文字右。

而项目上需要在图标的左上角显示序号,那么以上两种格式无法满足需求,只能另想方案。

经过查阅资料发现,可用画笔QPainter在图标上绘制文字和图片,对应的API是drawText和drawImage。部分代码如下:

 

// 加载图像
void KClipWidget::LoadClipImage()
{
	for (int i = 0; i < m_clipImgList.size(); i++)
	{
		// 创建剪贴板项
		m_pClipImageItemList.append(new QListWidgetItem());
		// 获取源图像
		QImage sourceImg(m_clipImgList[i]);

		//************************************************************
		// TODO:测试代码
		//************************************************************
		QImage clipImg;
		if (i % 2 == 0)
		{
			clipImg = SetClipAttribute(i,"",sourceImg,*m_cineImage);
		}
		else 
		{
			clipImg = SetClipAttribute(i,"cine",sourceImg,*m_cineImage);
		}
		//************************************************************

		// 获取目标缩略图
		QPixmap targetImg = QPixmap::fromImage(clipImg);

		// 设置单元项的宽度和高度
		m_pClipImageItemList[i]->setSizeHint(QSize(209,144));
		// 加载图像
		m_pClipImageItemList[i]->setIcon(QIcon(targetImg.scaled(QSize(201,135),Qt::IgnoreAspectRatio,Qt::SmoothTransformation)));	
	}
}
// 设置剪贴板的属性(序号,电影标志)
QImage KClipWidget::SetClipAttribute(int index,const char* type,const QImage clipImg,const QImage cineImg)
{
	QImage newImg = clipImg;
	QPainter paiter(&newImg);
	paiter.setCompositionMode(QPainter::CompositionMode_SourceOver);

	// 是否加载电影图标
	if (strcmp(type,S_CLIP_IMAGE_TYPE) == 0)
	{
		// 左电影图标区域
		QRect targetLeft(0.0,0.0,160,1080);
		// 右电影图标区域
		QRect targetRight(1760,0.0,160,1080);
		// Item区域
		QRect source(0.0,0.0,160,1080);
		// 绘制左电影图标
		paiter.drawImage(targetLeft,cineImg.scaled(QSize(160,1080),Qt::IgnoreAspectRatio,Qt::SmoothTransformation),source);
		// 绘制右电影图标
		paiter.drawImage(targetRight,cineImg.scaled(QSize(160,1080),Qt::IgnoreAspectRatio,Qt::SmoothTransformation),source);
	}
	
	// 绘制序号
	QPen pen = paiter.pen();
	pen.setColor(Qt::white);
	QFont font = paiter.font();
	font.setBold(true);
	font.setPixelSize(130);
	paiter.setPen(pen);
	paiter.setFont(font);
	paiter.drawText(newImg.rect(),Qt::AlignTop,QString::number(index + 1));

	return newImg;
}



评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值