Qt之QFileIconProvider

简述

QFileIconProvider类为QDirModel和QFileSystemModel类提供了文件图标。

共有类型

枚举QFileIconProvider::IconType:

常量
QFileIconProvider::Computer 0
QFileIconProvider::Desktop 1
QFileIconProvider::Trashcan 2
QFileIconProvider::Network 3
QFileIconProvider::Drive 4
QFileIconProvider::Folder 5
QFileIconProvider::File 6

枚举QFileIconProvider::Option:
标记QFileIconProvider::Options:

常量 描述
QFileIconProvider::DontUseCustomDirectoryIcons 0x00000001 始终使用默认的目录图标。有些平台允许用户设置不同的图标,自定义图标在网络或可移动驱动上查找会造成一个很大的性能影响。

公共函数

  • QIcon icon(IconType type) const
    获取IconType图标类型对应的图标。

  • QIcon icon(const QFileInfo & info) const
    获取QFileInfo文件信息对应的图标。

  • Options options() const
    获取所有影响QFileIconProvider的选项。默认情况下,所有选项被禁用。

  • void QFileIconProvider::setOptions(Options options)
    设置所有影响QFileIconProvider的选项。

  • QString type(const QFileInfo & info) const
    获取QFileInfo文件信息对应的类型描述。

示例

IconType

获取IconType图标类型对应的图标:

效果

这里写图片描述

源码

QListWidget *pListWidget = new QListWidget(this);
pListWidget->setIconSize(QSize(48, 48));         // 设置单元项图片大小
pListWidget->setResizeMode(QListView::Adjust);   // 设置大小模式-可调节
pListWidget->setViewMode(QListView::IconMode);   // 设置显示模式
pListWidget->setMovement(QListView::Static);     // 设置单元项不可被拖动
pListWidget->setSpacing(10);                     // 设置单元项间距
for (int i = 0; i <= 6; ++i)
{
    // 获取图标
    QFileIconProvider provider;
    QIcon icon = provider.icon((QFileIconProvider::IconType)i);

    // 添加单元项
    QListWidgetItem *pItem = new QListWidgetItem(pListWidget);
    pItem->setIcon(icon);
    pListWidget->addItem(pItem);
}

QFileInfo

获取QFileInfo文件信息对应的图标、类型描述:

效果

这里写图片描述

源码

QStringList strList;
strList << QString::fromLocal8Bit("新建文件夹") << QString::fromLocal8Bit("新建公文包")
        << QString::fromLocal8Bit("不存在此文件.exe") << QString::fromLocal8Bit("新建 360压缩 ZIP 文件.zip")
        << QString::fromLocal8Bit("新建 HTTP Archive File.har") << QString::fromLocal8Bit("新建 HttpWatch Log File.hwl")
        << QString::fromLocal8Bit("新建 Microsoft Access 数据库.accdb") << QString::fromLocal8Bit("新建 Microsoft Excel 工作表.xlsx")
        << QString::fromLocal8Bit("新建 Microsoft PowerPoint 演示文稿.pptx") << QString::fromLocal8Bit("新建 Microsoft Word 文档.docx")
        << QString::fromLocal8Bit("新建日记本文档.jnt") << QString::fromLocal8Bit("新建文本文档.txt");

for (int i = 0; i < strList.count(); ++i)
{
    QFileInfo info;
    info.setFile(QString("E:\\%1").arg(strList.at(i)));

    // 获取图标、类型
    QFileIconProvider provider;
    QIcon icon = provider.icon(info);
    QString strType = provider.type(info);

    // 添加单元项
    QListWidgetItem *pItem = new QListWidgetItem(pListWidget);
    pItem->setIcon(icon);
    pItem->setText(strType);
    pListWidget->addItem(pItem);
}

这里需要注意,如果要获取文件相关的信息 - 图标、类型,那么,本地必须存在这些文件。如果不存在,那么图标不会显示,而且类型会变为Unknow(如图:不存在此文件.exe)。

那么,如果想要通过不存在的文件获取相关的信息该如何处理呢?下节我们分享。

posted @ 2016-07-04 12:32  挨踢人啊  阅读(719)  评论(0编辑  收藏  举报