- QFileSystemModel提供了一个可用于访问本机文件系统的数据类型
- QFileSystemModel可以和视图组件QTreeView、QListView、QTableView结合使用,显示文件系统的信息
//要通过QFileSystemModel获得本机的文件系统,需要用此函数为QFileSystemModel设置一个初始化根目录
QModelIndex QFileSystemModel::setRootPath(const QString &newPath);
//判断节点是不是一个目录,如果是返回真
bool QFileSystemModel::isDir(const QModelIndex &index) const;
//返回节点的目录名或者带路径的文件名
QString QFileSystemModel::filePath(const QModelIndex &index) const;
//返回描述节点类型文件。如硬盘符号是“Drivew”,文件夹是“FIle Folder”,文件则用后缀描述
QString QFileSystemModel::type(const QModelIndex &index) const;
//返回去除路径的文件名/文件夹名(节点信息)
QString QFileSystemModel::fileName(const QModelIndex &index) const;
//如果节点时文件,返回文件大小的字节数。如果文件夹,返回0
qint64 QFileSystemModel::size(const QModelIndex &index) const;
三、QDirModel类
- 用于获取磁盘文件目录的数据模型还有一个QDirModel,其功能与QFileSystemModel类似,但是QFileSystemModel采用单独的线程获取目录文件结构。而QDirModel不使用单独的线程
- 使用单独的线程就不会阻塞主线程,所以推荐使用QFileSystemModel
- 当点击treeView的某一项时,在ListView和TableView还有下面的groupBox中显示节点信息
代码:
- 在类中定义一个QFileSystemModel对象
QFileSystemModel *model;
- 在构造函数中各个view的数据模型
model=new QFileSystemModel(this); model->setRootPath(QDir::currentPath()); //设置根目录 ui->treeView->setModel(model); //设置数据模型 ui->listView->setModel(model); //设置数据模型 ui->tableView->setModel(model); //设置数据模型 //两个槽函数,点击treeView的一个项时,设置listVie和tableView的根节点 connect(ui->treeView,SIGNAL(clicked(QModelIndex)),ui->listView,SLOT(setRootIndex(QModelIndex))); connect(ui->treeView,SIGNAL(clicked(QModelIndex)),ui->tableView,SLOT(setRootIndex(QModelIndex)));
- 设置treeView的on_treeView_clicked(const QModelIndex &index)信号函数
void MainWindow::on_treeView_clicked(const QModelIndex &index) { ui->chkIsDir->setChecked(model->isDir(index)); //如果节点时目录,设置checkBox为选中状态 //下面设置各个label的内容 ui->LabPath->setText(model->filePath(index)); ui->LabType->setText(model->type(index)); ui->LabFileName->setText(model->fileName(index)); int sz=model->size(index)/1024; if(sz<1024) ui->LabFileSize->setText(QString("%1 KB").arg(sz)); else ui->LabFileSize->setText(QString::asprintf("%.1f MB",sz/1024.0)); }