Qt应用开发(基础篇)——文件选择对话框 QFileDialog

一、前言

        QFileDialog类继承于QDialog,提供了一个允许用户选择文件或目录的对话框。

        对话框窗口 QDialog

        QFileDialog文件选择对话框允许用户在当前文件系统中选择一个或者多个文件或者文件路径,使用静态函数创建是很简便的方式,比如:

QString fileName = QFileDialog::getOpenFileName(this,
     tr("Open Image"), "/home/jana", tr("Image Files (*.png *.jpg *.bmp)"));

        在上面的例子的中,使用静态函数创建文件选择的模式对话框,分别传入标题、文件路径和文件过滤规则,比如你想要多个过滤器,那么用两个分号隔开。返回fileName为选择的文件名,如果没有选择则是空字符串。

"Images (*.png *.xpm *.jpg);;Text files (*.txt);;XML files (*.xml)"

        当然我们也可以不使用静态函数创建,而是使用API创建,比如:

QFileDialog dialog(this);
dialog.setFileMode(QFileDialog::ExistingFile);
dialog.setNameFilter(tr("Image Files (*.png *.jpg *.bmp)"));
dialog.setWindowTitle("Open Image");
dialog.setDirectory("/home/jana");
QStringList fileNames;
if (dialog.exec())
     fileNames = dialog.selectedFiles();

        在上面的实例中setFileMode()可以指定选择的是文件还是路径或者是全部都可以,使用setNameFilter()过滤文件类型,然后通过selectedFiles()得到选择的文件名称。

二、QFileDialog类

1、acceptMode

        该属性表示对话框的操作策略,定义对话框是用于打开还是保存文件。默认为AcceptOpen,表示打开文件,另一个属性AcceptSave表示保存文件,相当于静态函数getOpen系列和getSave系列。

QFileDialog::AcceptMode acceptMode() const
void setAcceptMode(QFileDialog::AcceptMode mode)

2、defaultSuffix

        该属性表示指定一个字符串,如果文件名没有后缀的话,则添加后文件名的后面。通常后缀是用来表示文件类型,比如txt表示文本,bin表示二进制文件,hex表示十六进制文件,ini表示配置文件等。

QString defaultSuffix() const
void setDefaultSuffix(const QString &suffix)

3、fileMode

        该属性表示选择文件策略,定义了用户希望在对话框中选择的项的数量和类型。默认是AnyFile,该属性会影响文件选择时候的标签。

QFileDialog::FileMode fileMode() const
void setFileMode(QFileDialog::FileMode mode)
QFileDialog::FileMode描述
QFileDialog::AnyFile用户可以选择任何文件,甚至指定一个不存在的文件
QFileDialog::ExistingFile用户只能选择单个存在的文件名称
QFileDialog::Directory用户可以选择一个目录名称
QFileDialog::ExistingFiles用户可以选择一个或者多个存在的文件名称

4、options

        该属性表示影响对话框外观的各种选项,默认是没有的。

QFileDialog::Options options() const
void setOptions(QFileDialog::Options options)
void setOption(QFileDialog::Option option, bool on = true)
QFileDialog::Option描述
ShowDirsOnly文件对话框中只显示目录。默认情况下,同时显示文件和目录。(仅在目录文件模式下有效。)
DontResolveSymlinks不要在文件对话框中解析符号链接。默认情况下,对符号链接进行解析。
DontConfirmOverwrite如果选择了现有文件,请不要要求确认。默认情况下,请求确认。
DontUseNativeDialog不要使用本机文件对话框。默认情况下,将使用本机文件对话框。

5、supportedSchemes

        该属性表示文件对话框应该允许导航到的URL方案,设置此属性允许限制用户能够选择的url类型,设置为空字符串表示没有任何限制。

QStringList supportedSchemes() const
void setSupportedSchemes(const QStringList &schemes)

6、viewMode

        该属性表示文件和目录在对话框中的显示方式,默认下,使用Detail模式显示文件和目录信息,另一个则为List模式仅显示目录中每个项目的图标和名称。

QFileDialog::ViewMode viewMode() const
void setViewMode(QFileDialog::ViewMode mode)

7、公共函数

1)directory

        返回当前显示在对话框中的目录。

QDir directory() const
2)setDirectory

        设置当前显示在对话框中的目录。

void setDirectory(const QString &directory)
void setDirectory(const QDir &directory)
3)directoryUrl

        返回当前显示在对话框中的目录的url。

QUrl directoryUrl() const
4)setDirectoryUrl

        设置当前显示在对话框中的目录的url。

void setDirectoryUrl(const QUrl &directory)
5)history

        将文件对话框的浏览历史记录作为路径列表返回。

QStringList history() const
6)history

        设置文件对话框的浏览历史记录以包含给定的路径。

void setHistory(const QStringList &paths)
7)iconProvider

        返回文件对话框使用的图标,使用QFileIconProvider封装。

QFileIconProvider *iconProvider() const
8)setIconProvider

        返回文件对话框使用的图标,使用QFileIconProvider封装。

void setIconProvider(QFileIconProvider *provider)
9)nameFilters

        返回在此文件对话框上运行过滤器。

QStringList nameFilters() const
10)setNameFilters

        设置在此文件对话框上运行过滤器。

void setNameFilters(const QStringList &filters)
 const QStringList filters({"Image files (*.png *.xpm *.jpg)",
                            "Text files (*.txt)",
                            "Any files (*)"
                           });
 QFileDialog dialog(this);
 dialog.setNameFilters(filters);
 dialog.exec();
11)mimeTypeFilters

        返回在此文件对话框上运行的MIME类型过滤器。

QStringList mimeTypeFilters() const
12)setMimeTypeFilters

        设置在此文件对话框上运行的MIME类型过滤器。这是比setNameFilters更方便的方法,使用QMimeType从每个MIME类型中定义的全局模式和描述创建名称过滤器。

void setMimeTypeFilters(const QStringList &filters)
 QStringList mimeTypeFilters({"image/jpeg", // will show "JPEG image (*.jpeg *.jpg *.jpe)
                              "image/png",  // will show "PNG image (*.png)"
                              "application/octet-stream" // will show "All files (*)"
                             });

 QFileDialog dialog(this);
 dialog.setMimeTypeFilters(mimeTypeFilters);
 dialog.exec();
13)labelText

        返回指定标签中文件对话框中显示的文本。

QString labelText(QFileDialog::DialogLabel label) const
14)labelText

        设置指定标签中文件对话框中显示的文本。

void setLabelText(QFileDialog::DialogLabel label, const QString &text)
15)open

        将它的一个信号连接到由接收器和成员指定的插槽。如果fileMode是ExistingFiles,则绑定filesSelected()信号,如果fileMode是其他任何东西,则绑定fileSelected()信号。当对话框关闭时,信号槽断开。

void open(QObject *receiver, const char *member)
16)proxyModel

        返回文件对话框使用的QAbstractProxyModel代理模型。默认情况下,没有设置代理。

QAbstractProxyModel *proxyModel() const
17)setProxyModel

        将视图的模型设置为给定的QAbstractProxyModel代理模型。用于修改底层模型,例如,添加列、筛选数据或添加驱动器。

void setProxyModel(QAbstractProxyModel *proxyModel)
18)itemDelegate

        返回用于呈现文件对话框中视图中的项的项QAbstractItemDelegate委托。

QAbstractItemDelegate *itemDelegate() const
19)setItemDelegate

        设置用于呈现文件对话框中视图中的项的项QAbstractItemDelegate委托。

void setItemDelegate(QAbstractItemDelegate *delegate)
20)restoreState

        将对话框的布局、历史记录和当前目录恢复到指定的状态。

bool restoreState(const QByteArray &state)
21)saveState

       保存对话框的布局、历史和当前目录的状态。一般返回QByteArray保存在外部文件或者缓存中,可以使用ini文件保存某一时刻的状态,然后必要的时候使用restoreState恢复到目标状态。

QByteArray saveState() const
22)selectedFiles

        返回包含对话框中所选文件的绝对路径的字符串列表。如果没有选择文件,或者模式不是ExistingFiles或ExistingFile,则selectedFiles()包含视口中的当前路径。

QStringList selectedFiles() const
23)selectedFile

        返回在文件对话框中选择给定的文件名。

void selectFile(const QString &filename)
24)selectedUrls

        返回包含对话框中选定文件的url列表。如果没有选择文件,或者模式不是ExistingFiles或ExistingFile,则selectedUrls()包含视口中的当前路径。

QList<QUrl> selectedUrls() const
 25)selectedNameFilter

        返回用户在文件对话框中选择的过滤器。

QString selectedNameFilter() const
 26)selectedMimeTypeFilter

        返回用户在文件对话框中选择的文件的mime类型。

QString selectedMimeTypeFilter() const
27)sidebarUrls

        返回位于侧边栏中的url。

QList<QUrl> sidebarUrls() const
 28)setSidebarUrls

        设置位于侧边栏中的url。

void setSidebarUrls(const QList<QUrl> &urls)
QList<QUrl> urls;
urls << QUrl::fromLocalFile("/Users/foo/Code/qt5")
          << QUrl::fromLocalFile(QStandardPaths::standardLocations(QStandardPaths::MusicLocation).first());

QFileDialog dialog;
dialog.setSidebarUrls(urls);
dialog.setFileMode(QFileDialog::AnyFile);
if(dialog.exec()) {
    // ...
}

8、静态函数

1)模式对话框

        QFileDialog使用静态函数创建模式对话框,传入父窗口指针、标题、路径、窗口样式、过滤器,在父窗口居中显示,以下这些用法都大同小异,参考开头示例。

QString getExistingDirectory(QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), QFileDialog::Options options = ShowDirsOnly)
QUrl getExistingDirectoryUrl(QWidget *parent = nullptr, const QString &caption = QString(), const QUrl &dir = QUrl(), QFileDialog::Options options = ShowDirsOnly, const QStringList &supportedSchemes = QStringList())
void getOpenFileContent(const QString &nameFilter, const std::function<void (const QString &, const QByteArray &)> &fileOpenCompleted)
QString getOpenFileName(QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options())
QStringList getOpenFileNames(QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options())
QUrl getOpenFileUrl(QWidget *parent = nullptr, const QString &caption = QString(), const QUrl &dir = QUrl(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options(), const QStringList &supportedSchemes = QStringList())
QList<QUrl> getOpenFileUrls(QWidget *parent = nullptr, const QString &caption = QString(), const QUrl &dir = QUrl(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options(), const QStringList &supportedSchemes = QStringList())
QString getSaveFileName(QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options())
QUrl getSaveFileUrl(QWidget *parent = nullptr, const QString &caption = QString(), const QUrl &dir = QUrl(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options(), const QStringList &supportedSchemes = QStringList())
2)saveFileContent

         让用户选择的文件名和位置将fileContent保存到文件中,提供fileNameHint来向用户建议文件名。

void saveFileContent(const QByteArray &fileContent, const QString &fileNameHint = QString())

9、信号

1)currentChanged

        当当前文件因本地操作而更改时,将发出此信号,并将新文件名作为路径参数。

void currentChanged(const QString &path)
2)currentUrlChanged

        当当前文件发生变化时,该信号将以新文件URL作为URL参数发出。

void currentUrlChanged(const QUrl &url)
3)directoryEntered 

        当用户进入目录时,为本地操作发出此信号。

void directoryEntered(const QString &directory)
4)directoryUrlEntered 

        当用户进入目录时发出此信号。

void directoryUrlEntered(const QUrl &directory)
5)fileSelected 

        当本地操作的选择发生变化并且对话框被接受时,该信号将与所选文件(可能为空)一起发出。

void fileSelected(const QString &file)
6)filesSelected 

        当本地操作的选择发生变化并且接受对话框时,该信号将与所选文件的(可能为空的)列表一起发出。

 void filesSelected(const QStringList &selected)
7)filterSelected 

        当用户选择过滤器时,会发出此信号。

void filterSelected(const QString &filter)
8)urlSelected 

        当选择更改并且接受对话框时,该信号将与所选url(可能为空)一起发出。

void urlSelected(const QUrl &url)
9)urlsSelected 

        当选择更改并且接受对话框时,将发出此信号,其中包含所选url的列表(可能为空)。

void urlsSelected(const QList<QUrl> &urls)
  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

波塞冬~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值