Qt显示图片的展示

通过qt将图片在窗口中显示出来

1.首先说说背景图片的显示

void setBackgroundImage(const QString &strPath)

{

QPixmap pixmap(strPath);

QPalette palette=this->palette();

if(strPath.isEmpty())

{

palette.setBrush(Qpalette::Base,QBrush(QColor(0,0,225)));

}

else

{

palette.setBrush(QPalette::Brush,QBrush(pixmap.scaled(width(),height())));

}

setPalette(palette);

}

2.通过QListWidget来显示GridView形式

MainWindow::MainWindow(QWidget *parent):QMainWidget(parent)
{
//创建QListWidget
QListWidget *m_pListWidget=new QListWidget(this);
//设置QListWidget中的单元项的图片大小
m_pListWidget->setIconSize(QSize(W_ICONSIZE,H_ICONSIZE));
m_pListWidget->setResizeMode(QListView::Adjust);//当前选项卡调整选项后重新显示
//设置QListWidget的显示模式
m_pListWidget->setViewMode(QListView::IconMode);
设置QlistView中的单元项不可以被拖动
m_pListWidget->setMovement(QListView::Static);
设置QListWidget中的单元项之间的距离
m_pListWidget->setSpacing(10);

//依次创建11个单元格
for(int nIndex=0;nIndex<11;nIndex++)vo
{
获取图片路径
QString strPath=QString("D:/image.JPEG".arg(nIndex+1));
生成图像
QPixmap pixmap(strPath);
生成QLIstWidgetItem对象,对Icon进行伸缩96*96,scaled函数
QListWidgetItem *pItem=new QListWidgetItem(QIcon(pixmap.scaled(QSize(W_ICONSIZE,H_ICONSIZE))),"animal tiger");
设置单元项的宽度和高度
pItem->setSizeHint(QSize(W_ICONSIZE,H_ICONSIZE));
m_pListWidget->insertItem(nIndex,pItem)
}
setCentralWidget(m_pListWidget);
connect(m_pListWidget,SIGNAL(itemClicked(QListWidget*)),this,SLOT(SlotItemClicked(QListWidget*)));
QString m_strPath="";
setWindowTitle("Picture Show");
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好,首先需要在Qt中创建一个MainWindow窗口,然后向窗口中添加两个QListView控件。下面是一个简单的示例代码: ```cpp #include <QtWidgets/QMainWindow> #include <QtWidgets/QVBoxLayout> #include <QtWidgets/QListView> #include <QtWidgets/QListWidget> class MainWindow : public QMainWindow { Q_OBJECT public: MainWindow(QWidget *parent = nullptr) : QMainWindow(parent) { // 创建两个QListView控件 m_listView1 = new QListView(this); m_listView2 = new QListWidget(this); // 将控件添加到窗口中 QVBoxLayout* layout = new QVBoxLayout(this); layout->addWidget(m_listView1); layout->addWidget(m_listView2); QWidget* centralWidget = new QWidget(this); centralWidget->setLayout(layout); setCentralWidget(centralWidget); // 绑定信号和槽函数 connect(m_listView1, SIGNAL(clicked(const QModelIndex&)), this, SLOT(onListView1Clicked(const QModelIndex&))); } private slots: // ListView1被点击时触发 void onListView1Clicked(const QModelIndex& index) { // 获取ListView1中被点击的项的数据 QVariant data = index.data(); // 将数据添加到ListView2中 m_listView2->addItem(data.toString()); } private: QListView* m_listView1; QListWidget* m_listView2; }; ``` 在这个示例中,我们创建了两个QListView控件,分别为m_listView1和m_listView2。当m_listView1中的项被点击时,会触发onListView1Clicked槽函数,该函数将被点击的项的数据添加到m_listView2中。您可以根据自己的实际需求修改代码以满足您的要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值