跟我一起学QT_QlistWidget控件的使用

QListWidget 简介

QListWidget类提供了一个基于项目的列表小部件
QListWidget是一个方便的类,它提供了一个列表视图,类似于QListView提供的列表视图,但是具有一个用于添加和删除项的经典基于项的接口。QListWidget使用一个内部模型来管理列表中的每个QListWidgetItem。要获得更灵活的列表视图小部件,请使用带有标准模型的QListView类。列表小部件的构造方法与其他小部件相同

设置多选还是单选

QListWidget selectionMode()确定可以同时选择列表中的多少项,以及是否可以创建复杂的项选择。这可以使用setSelectionMode()函数设置
首先selectionMode()成员函数返回一个枚举类型我们可以根据这个枚举类型来判断我们的listwidget是否支持多选
下面我们看一下 这个枚举类型的原型

enum QAbstractItemView::SelectionMode
{
QAbstractItemView::SingleSelection = 1,
QAbstractItemView::ContiguousSelection = 4,
QAbstractItemView::ExtendedSelection = 3,
QAbstractItemView::MultiSelection = 2,
QAbstractItemView::NoSelection = 0
};

QAbstractItemView::SingleSelection表示 当用户选择一个项目时,任何已经选择的项目都将变为未选择。用户可以取消选定的项。

QAbstractItemView::ContiguousSelection 当用户以通常的方式选择一个项目时,将清除该选择并选择新项目。但是,如果用户在单击项时按下Shift键,则根据所单击项的状态,选择或取消当前项和所单击项之间的所有项。

QAbstractItemView::ExtendedSelection 当用户以通常的方式选择一个项目时,将清除该选择并选择新项目。但是,如果用户在单击一个项目时按下Ctrl键,则单击的项目将被切换,所有其他项目将保持不变。如果用户在单击项时按下Shift键,则根据所单击项的状态选择或不选择当前项和所单击项之间的所有项。可以通过拖动鼠标来选择多个项目。

QAbstractItemView::MultiSelection 当用户以通常的方式选择一个项目时,该项目的选择状态将被切换,其他项目将保持不变。多个项目可以通过拖动鼠标来切换。

QAbstractItemView::NoSelection 无法选择项。

添加Items

向列表添加项有两种方法:可以使用列表小部件作为父小部件构造它们,或者不使用父小部件构造它们,然后将它们添加到列表中。如果在构建项目时列表小部件已经存在,那么第一个方法更容易使用:

/*第一种 创建的时候设置父类的*/
new QListWidgetItem(tr("Oak"), listWidget);
new QListWidgetItem(tr("Fir"), listWidget);
new QListWidgetItem(tr("Pine"), listWidget);
/*第二种直接用ListWidget的成员函数添加*/
QListWidgetItem *newItem = new QListWidgetItem;
newItem->setText(itemText);
listWidget->insertItem(row, newItem);

对于多个项目,可以使用insertItems()。列表中的项数可以通过count()函数找到。要从列表中删除项,请使用takeItem()。列表中的当前项可以用currentItem()找到,也可以用setCurrentItem()更改。用户还可以通过使用键盘导航或单击其他项来更改当前项。当当前项更改时,currentItemChanged()信号将与新的当前项和先前的当前项一起发出。 ## 实战代码 前面讲了那么多我们也大致了解怎么去使用这个控件了 那么下面我就实际操作写一个ListWidget控件的例子
1.Qt Creator 创建一个带UI的项目 ![image](https://i.loli.net/2019/04/08/5caab136a3ae8.png) 2、添加如下代码分别用两种方式插入我们需要插入的项

#include "MainWindow.h"
#include "ui_mainwindow.h"
#include <QListWidget>
#include <QListWidgetItem>
#include <QString>
#include <QDebug>
MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    /*
    使用listwidget
    */
    InitListItem();
}

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

void MainWindow::InitListItem()
{
    /*先用第一种方式初始化*/
    for(int i = 0 ; i<10; i++)
    {
        QString str = QString("Item %1").arg(i);
        qDebug() << str << endl;
        new QListWidgetItem(str,ui->listWidget);
    }
    /*第二种初始化方式*/
    for (int l = 10;l<20;l++)
    {
        QString str = QString("2item %1").arg(l);
        QListWidgetItem* iTems = new QListWidgetItem(str);
        ui->listWidget->addItem(iTems);
    }
}

效果图就像这样 ![效果](https://i.loli.net/2019/04/08/5caad2a7788dd.png)
3、下面我们来深入研究下QListWidget这个控件
QListWidget 的成员函数 `count`此属性保存列表中包含任何隐藏项的项数。 `currentRow`获取当前选择的行 `setCurrentRow(int row)` 是设置选中行
QListWidget 有如下信号

void
currentItemChanged(QListWidgetItem *current, QListWidgetItem *previous)
void
currentRowChanged(int currentRow)
void
currentTextChanged(const QString &currentText)
void
itemActivated(QListWidgetItem *item)
void
itemChanged(QListWidgetItem *item)
void
itemClicked(QListWidgetItem *item)
void
itemDoubleClicked(QListWidgetItem *item)
void
itemEntered(QListWidgetItem *item)
void
itemPressed(QListWidgetItem *item)
void
itemSelectionChanged()


一般情况我们使用无非就是像知道用户选中某一行或者某一行被选中我们需要处理什么


下面我直接用简单的代码实现下
首先我们定义一个 来处理 QListWidget::currentRowChanged信号的 的槽函数


#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
public:
    /*
    先定一个初始化的函数
    */
    void InitListItem();
public slots:
    /*新建一个当用户选中的项发送改变时的槽函数*/
    void CurrentChanged(int CurrentRow);
private:
    Ui::MainWindow *ui;
};

#endif // MAINWINDOW_H


然后实现的代码如下

#include "MainWindow.h"
#include "ui_mainwindow.h"
#include <QListWidget>
#include <QListWidgetItem>
#include <QString>
#include <QDebug>
MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    /*
    使用listwidget
    */
    InitListItem();
    /*用connect 连接信号和槽函数*/
    QObject::connect(ui->listWidget,&QListWidget::currentRowChanged,this,&MainWindow::CurrentChanged);
}

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

void MainWindow::InitListItem()
{
    /*先用第一种方式初始化*/
    for(int i = 0 ; i<10; i++)
    {
        QString str = QString("Item %1").arg(i);
        qDebug() << str << endl;
        new QListWidgetItem(str,ui->listWidget);
    }
    /*第二种初始化方式*/
    for (int l = 10;l<20;l++)
    {
        QString str = QString("2item %1").arg(l);
        QListWidgetItem* iTems = new QListWidgetItem(str);
        ui->listWidget->addItem(iTems);
    }
}

void MainWindow::CurrentChanged(int CurrentRow)
{
    //我们也不做过多的操作我们可以获取打印出当前选中的项目的文本数据
    if(CurrentRow!=-1)
    {
        QListWidgetItem* item =  ui->listWidget->item(CurrentRow);
        qDebug() << "Are you currently selected :" << item->text();
    }
}

当然最后的效果如下图
效果图
如果需要研究QListWidget 的其他用法可以参考QT的帮助手册


今天的和我一起学QT就先介绍到这里

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 `QStackedWidget` 和 `QListWidget` 实现界面切换功能。 1. 首先,在 Qt Designer 中创建一个 `QStackedWidget` 和一个 `QListWidget`,将 `QListWidget` 放置在需要显示菜单的位置上,将 `QStackedWidget` 放置在需要显示页面的位置上。 2. 在 `QListWidget` 中添加菜单项,并设置相应的文本和图标。 3. 在 `QStackedWidget` 中添加页面,并设置相应的 UI 界面。 4. 编写槽函数,用于响应 `QListWidget` 中菜单项的点击事件,并切换到相应的页面。 以下是示例代码: ```python from PyQt5.QtWidgets import QApplication, QMainWindow, QListWidget, QStackedWidget, QWidget, QVBoxLayout, QLabel, QPushButton class MainWindow(QMainWindow): def __init__(self): super().__init__() # 创建 QListWidget 和 QStackedWidget self.list_widget = QListWidget() self.stack_widget = QStackedWidget() # 添加菜单项 self.list_widget.addItem("Page 1") self.list_widget.addItem("Page 2") self.list_widget.addItem("Page 3") # 添加页面 page1 = QWidget() layout1 = QVBoxLayout() label1 = QLabel("This is Page 1") button1 = QPushButton("Go to Page 2") button1.clicked.connect(lambda: self.stack_widget.setCurrentIndex(1)) layout1.addWidget(label1) layout1.addWidget(button1) page1.setLayout(layout1) self.stack_widget.addWidget(page1) page2 = QWidget() layout2 = QVBoxLayout() label2 = QLabel("This is Page 2") button2 = QPushButton("Go to Page 3") button2.clicked.connect(lambda: self.stack_widget.setCurrentIndex(2)) layout2.addWidget(label2) layout2.addWidget(button2) page2.setLayout(layout2) self.stack_widget.addWidget(page2) page3 = QWidget() layout3 = QVBoxLayout() label3 = QLabel("This is Page 3") button3 = QPushButton("Go to Page 1") button3.clicked.connect(lambda: self.stack_widget.setCurrentIndex(0)) layout3.addWidget(label3) layout3.addWidget(button3) page3.setLayout(layout3) self.stack_widget.addWidget(page3) # 设置 QMainWindow 的 centralWidget central_widget = QWidget() central_layout = QHBoxLayout() central_layout.addWidget(self.list_widget) central_layout.addWidget(self.stack_widget) central_widget.setLayout(central_layout) self.setCentralWidget(central_widget) # 连接 QListWidget 和 QStackedWidget self.list_widget.currentRowChanged.connect(self.stack_widget.setCurrentIndex) if __name__ == "__main__": app = QApplication([]) window = MainWindow() window.show() app.exec_() ``` 在上述示例代码中,我们在 QMainWindow 中添加了一个 `QListWidget` 和一个 `QStackedWidget`,并且在 `QListWidget` 中添加了三个菜单项,在 `QStackedWidget` 中添加了三个页面。我们通过 `setCurrentIndex` 方法切换页面,并且连接了 `currentRowChanged` 信号,以便在 `QListWidget` 中点击菜单项时,自动切换到相应的页面。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值