QT实现ListWidget排列图片

最近工作遇到了要将点线面符号排列在控件上的问题,采用QListWidget实现:

ui->listWidgetCommon->setViewMode(QListWidget::IconMode);//设置内容为图片
ui->listWidgetCommon->setIconSize(QSize(50, 50));//设置图片的大小
ui->listWidgetCommon->setSpacing(10);//设置每个item之间的间隔大小
ui->listWidgetCommon->setMovement(QListWidget::Static);//设置每个item不可拖动
ui->listWidgetCommon->setResizeMode(QListWidget::Adjust);//设置拖动时可以重新排列
QPixmap pixmap = QPixmap::fromImage(allSymbols[i]->Image());
QString name = allSymbols[i]->Symbol->Name().c_str();
QListWidgetItem* item = new QListWidgetItem(QIcon(pixmap), name);//从图片构造item
item->setData(Qt::UserRole, QVariant::fromValue(allSymbols[i]));//将符号对象设置给该item
//通过item->data(column,Qt::UserRole).value<PlottingType>()来取
item->setSizeHint(QSize(50, 65));//设置每个item的大小
item->setTextAlignment(Qt::AlignCenter);//设置item居中对齐
ui->listWidgetCommon->addItem(item);

效果如下:
在这里插入图片描述

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Qt C++ 中,可以使用 QListWidget 控件来显示多列数据。要显示多列数据,可以将 QListWidget 的显示模式设置为 IconMode,然后设置 QListWidgetItem 的大小和位置。 以下是一个示例代码,可以将 QListWidget 显示为两列数据: ```c++ // 创建 QListWidget,并设置显示模式为 IconMode QListWidget* listWidget = new QListWidget(this); listWidget->setViewMode(QListWidget::IconMode); listWidget->setFlow(QListWidget::LeftToRight); // 设置 QListWidgetItem 的大小和位置 QListWidgetItem* item1 = new QListWidgetItem(QIcon("image1"), "Item 1"); item1->setSizeHint(QSize(100, 100)); item1->setFlags(item1->flags() ^ Qt::ItemIsSelectable); listWidget->addItem(item1); item1->setPos(0, 0); QListWidgetItem* item2 = new QListWidgetItem(QIcon("image2"), "Item 2"); item2->setSizeHint(QSize(100, 100)); item2->setFlags(item2->flags() ^ Qt::ItemIsSelectable); listWidget->addItem(item2); item2->setPos(100, 0); QListWidgetItem* item3 = new QListWidgetItem(QIcon("image3"), "Item 3"); item3->setSizeHint(QSize(100, 100)); item3->setFlags(item3->flags() ^ Qt::ItemIsSelectable); listWidget->addItem(item3); item3->setPos(0, 100); QListWidgetItem* item4 = new QListWidgetItem(QIcon("image4"), "Item 4"); item4->setSizeHint(QSize(100, 100)); item4->setFlags(item4->flags() ^ Qt::ItemIsSelectable); listWidget->addItem(item4); item4->setPos(100, 100); // 设置 QListWidget 的大小 listWidget->setMinimumSize(200, 200); listWidget->setMaximumSize(200, 200); ``` 这里使用了 setViewMode 函数将 QListWidget 的显示模式设置为 IconMode,setFlow 函数设置图标的排列方向为从左到右。然后,使用 setSizeHint 函数设置 QListWidgetItem 的大小,并使用 setPos 函数设置 QListWidgetItem 的位置。最后,使用 setMinimumSize 和 setMaximumSize 函数设置 QListWidget 的大小。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

vegetablesssss

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值