QListWidget列表控件

使用QListWidget和QStackedWidget实现动态切换界面
本文介绍了如何在Qt环境中利用QListWidget和QStackedWidget创建一个列表控件,当选择不同的列表项时,动态显示对应的QLabel内容。通过设置信号与槽,实现了在选择列表项时,QStackedWidget中的页面随之切换。
#ifndef DIALOG_H
#define DIALOG_H

#include 
#include 
#include 
#include 


class StackDialog : public QDialog
{
    Q_OBJECT

public:
    StackDialog(QWidget *parent = 0);
    ~StackDialog();

private:
    QListWidget *list;
    QStackedWidget *stack;
    QLabel *label1;
    QLabel *label2;
    QLabel *label3;

};

#endif // DIALOG_H
#include "stackDialog.h"
#include 
#include 


StackDialog::StackDialog(QWidget *parent)
    : QDialog(parent)
{
    setWindowTitle(tr("妞 给爷笑一个"));
    list = new QListWidget(this);//列表控件

    list->insertItem(0,tr("淑女"));
    list->insertItem(0,tr("萝莉"));
    list->insertItem(0,tr("少妇"));

    label1 = new QLabel(tr("淑女"));
    label2 = new QLabel(tr("萝莉"));
    label3 = new QLabel(tr("少妇"));
    QPixmap p(300,400);
    p.load(":/26.JPG");
    p.scaled(0.2,0.2);
    label2->setPixmap(p);
    stack = new QStackedWidget(this);
    stack->addWidget(label1);
    stack->addWidget(label2);
    stack->addWidget(label3);

    QHBoxLayout *layout =new QHBoxLayout(this);
    layout->setMargin(5);
    layout->setSpacing(5);
    layout->addWidget(list);
    layout->addWidget(stack,0,Qt::AlignCenter);
    layout->setStretchFactor(list,1);
    layout->setStretchFactor(stack,3);
    connect(list,SIGNAL(currentRowChanged(int)),stack,SLOT(setCurrentIndex(int)));
}

StackDialog::~StackDialog()
{

}#include "stackDialog.h"
#include 

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    StackDialog w;
    w.show();

    return a.exec();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值