QT 多目录选择对话框实现

1.QT QFileDialog默认是不支持多目录选择的,网上其他实现方式界面都比较丑,网图:

2.参考MFC的多目录选择对话框,我采用了QT调用MCF库方式实现,QT和MFC参考大佬文章:

VS2017编写MFC库以及使用Qt调用MFC库方法_长沙红胖子Qt的博客-CSDN博客_qt 调用lib

效果图:

首先上MFC实现代码

头文件:

extern "C" _declspec(dllexport) char * __stdcall OpenDirectory(char* title, char * dirpath);

Cpp文件:

char* __stdcall OpenDirectory(char* title, char* dirpath)
{
    std::vector<CString>ans;
    CString allpath = _T("");
    CWnd* pWnd = NULL;
    AFX_MANAGE_STATE(AfxGetStaticModuleState());
    CFolderPickerDialog dlg(NULL, OFN_FILEMUSTEXIST | OFN_ALLOWMULTISELECT | OFN_ENABLESIZING, pWnd);
    dlg.m_ofn.lpstrTitle = CString(title);
    if (dlg.DoModal() == IDOK) {
        POSITION pos = dlg.GetStartPosition();
        while (pos) {
            ans.push_back(dlg.GetNextPathName(pos));
        }
    }

    for (std::vector<CString>::iterator iter = ans.begin(); iter != ans.end(); ++iter)
    {
        allpath = allpath + *iter + _T(";");
    }
    allpath= allpath.Left(allpath.GetLength() - 1);
    int len = WideCharToMultiByte(CP_ACP, 0, allpath, -1, NULL, 0, NULL, NULL);
    char* ptxtTemp = new char[len + 1];
    WideCharToMultiByte(CP_ACP, 0, allpath, -1, ptxtTemp, len, NULL, NULL);
    return ptxtTemp;
}

导出定义 .def

; OpenDirectoryLibrary.def: 声明 DLL 的模块参数。

LIBRARY

EXPORTS
    ; 此处可以是显式导出
    OpenDirectory @ 1

最后:QT 端调用类

采用内联类,不说废话 直接上代码 ,动态库编译后放QT编译后程序运行目录下

#ifndef FOLDERMULTIDIALOG_H
#define FOLDERMULTIDIALOG_H
#include <QList>
#include <QString>
#include <QLibrary>

#include <QTextCodec>
#include <qDebug>

class FolderMultiDialog
{
public :
    static QList<QString> FolderMultiDialog::getExistingDirectory(QString title= "选择目录")
    {
        QLibrary lib("OpenDirectoryLibrary.dll");
        if (lib.load()) {
            qDebug() << "load ok!";
        }
        else {
            qDebug() << "load failed!";
        }
        typedef char* (*OpenDirectory)(const char*, const char*);
        OpenDirectory fpAdd = (OpenDirectory)lib.resolve("OpenDirectory");
        QTextCodec* pCodec = QTextCodec::codecForName("GBK");
        QByteArray data = pCodec->fromUnicode(title);
        char* titledata = data.data();
        char* nSum = fpAdd(titledata, "");
        QString selectdirs = QString::fromLocal8Bit(nSum);
        QList<QString> selectdirlists = selectdirs.split(";");
        lib.unload();//卸载
        return selectdirlists;
    }
};
#endif

QT下调用  超简单 一句话

#include "FolderMultiDialog.h"

QList<QString> dirs = FolderMultiDialog::getExistingDirectory("选择目录");

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Qt是一个跨平台的C++应用程序开发框架,提供了多种功能模块和工具类,包括打开文件选择对话框。该对话框实现可以通过QFileDialog类来完成。我们可以使用该类的静态函数getOpenFileName或getOpenFileNames来打开文件选择对话框,分别用于选择单个文件或多个文件。其函数原型如下: QString QFileDialog::getOpenFileName(QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFlags<Options> options = QFlags<Options>()) QStringList QFileDialog::getOpenFileNames(QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFlags<Options> options = QFlags<Options>()) 其中,参数parent表示父窗口,可以为nullptr;参数caption表示对话框标题,可以为空;参数dir表示对话框打开时的默认路径,可以为空,表示系统默认路径;参数filter表示对话框筛选文件的类型,例如 "*.txt" 表示只显示txt文件;参数selectedFilter表示默认选中的文件类型;参数options表示对话框的选项,例如默认选择的文件名等等。返回值为QString或QStringList类型,表示选择的文件路径或文件列表。 具体使用方法如下: QString filename = QFileDialog::getOpenFileName(this, tr("Open File"), QDir::currentPath(), tr("Text Files (*.txt);;All Files(*)")); QStringList filenames = QFileDialog::getOpenFileNames(this, tr("Open Files"), QDir::currentPath(),tr("Text Files (*.txt);;All Files(*)")); 其中,参数this表示当前窗口,tr表示对字符串进行国际化处理,QDir::currentPath()表示当前路径。选中的文件路径或文件列表会存储在filename或filenames中。通过上述的两个静态函数,我们可以非常方便地实现Qt打开文件选择对话框

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

承蒙時光不弃

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

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

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

打赏作者

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

抵扣说明:

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

余额充值