MFC——MFC根据输入路径创建文件夹

//函数名:CreateDir
//函数功能:根据传入的路径创建文件夹
//参数:strSetPath  
//(入口)strSetPath:传入的完整路径
//返回值:无

void CreateDir(CString setPath)//suppose as : setPath = D:\test\temp
{
	//默认生成的文件夹
	if (setPath.IsEmpty())
	{
		MessageBox(_T("目录为空,无法创建文件夹!"));
	}
	//如果指定了目录,则根据目录生成文件夹
	else
	{
		//将路径根据"\"分割开
		CStringArray editArr;
		int nPos = setPath.Find(_T("\\"));
		//如果找到路径分隔符,则根据路径创建文件夹
		if (nPos != -1)
		{
			CString temp;
			temp = _T("");
			while(0 <= nPos)
			{
				temp = setPath.Left(nPos);
				if(!temp.IsEmpty())
					editArr.Add(temp);
				setPath = setPath.Right(setPath.GetLength() - nPos -1);
				nPos = setPath.Find(_T("\\"));
			}
			if (!setPath.IsEmpty())
			{
				editArr.Add(setPath);
			}
 
			int nSize = editArr.GetSize();
			//创建多级文件夹
			CString dirPath;
			dirPath = editArr.GetAt(0) + _T("\\") + editArr.GetAt(1);//D:\test
			if (!PathFileExists(dirPath))
			{
				CreateDirectory(dirPath,NULL);
			}
			for (int i = 2; i < nSize; i++)
			{
				dirPath = dirPath + _T("\\") + editArr.GetAt(i);
				if (!PathFileExists(dirPath))
				{
					CreateDirectory(dirPath,NULL);
				}
			}
 
		} 
		//如果没有路径分隔符"\",则在当前目录下生成改文件夹//like : setPath = test
		else
		{
			if (!PathFileExists(setPath))
			{
				CreateDirectory(setPath,NULL);
			}
		}
 
 
	}
 
}

 

//MFC选择文件存放路径
BROWSEINFO bi;  	
    ZeroMemory(&bi,sizeof(BROWSEINFO));	//指定存放文件的默认文件夹路径
    bi.ulFlags = BIF_RETURNONLYFSDIRS;   
    bi.lpszTitle="选择文件存放路径";		//添加提示语句
    LPMALLOC pMalloc;    	
    LPITEMIDLIST pidl = SHBrowseForFolder(&bi);//以默认路径打开浏览文件夹对话框	
    char szcSavePath[MAX_PATH];
    CString szSavePath="";  	
    if(pidl != NULL)   
    {		
        SHGetPathFromIDList(pidl, szcSavePath);//文件夹路径存放入szcSavePath中
       	szSavePath.Format(_T("%s"), szcSavePath);
        szSavePath=szSavePath+"\\";//在路径后增加斜杠 		
        if(SUCCEEDED(SHGetMalloc(&pMalloc)))        
        { 		
            pMalloc->Free(pidl);      
            pMalloc->Release();      
        }   
        if (4 == szSavePath.GetLength())
        {
            szSavePath = szSavePath.Left(3);
        }
    }   
    MessageBox(szSavePath);//显示所选文件夹路径

 

BROWSEINFO结构
●定义
typedef struct_browseinfo
{
HWND  hwndOwner;
LPCITEMIDLIST pidlRoot;
LPSTR   pszDisplayName;
LPCSTR lpszTitle;
UINT      ulFlags;
BFFCALLBACK  lpfn;
LPARAM   lParam;
int      iImage;
}BROWSEINFO,*PBROWSEINFO,*LPBROWSEINFO;
●成员变量
hwndOwner:浏览文件夹对话框的父窗体句柄。
pidlRoot:ITEMIDLIST结构的地址,包含浏览时的初始根目录,而且只有被指定的目录和其子目录才显示在浏览文件夹对话框中。该成员变量可以是NULL,在此时桌面目录将被使用。
pszDisplayName:用来保存用户选中的目录字符串的内存地址。该缓冲区的大小缺省是定义的MAX_PATH常量宏。
lpszTitle:该浏览文件夹对话框对话框的显示文本,用来提示该浏览文件夹对话框的功能、作用和目的。
ulFlags:该标志位描述了对话框的选项。它可以为0,也可以是以下常量的任意组合:
BIF_BROWSEFORCOMPUTER:返回计算机名。除非用户选中浏览器中的一个计算机名,否则该对话框中的“OK”按钮为灰色。
BIF_BROWSEFORPRINTER:返回打印机名。除非选中一个打印机名,否则“OK”按钮为灰色。
BIF_BROWSEINCLUDEFILES:浏览器将显示目录,同时也显示文件。
BIF_DONTGOBELOWDOMAIN:在树形视窗中,不包含域名底下的网络目录结构。
BIF_EDITBOX:浏览对话框中包含一个编辑框,在该编辑框中用户可以输入选中项的名字。
BIF_RETURNFSANCESTORS:返回文件系统的一个节点。仅仅当选中的是有意义的节点时,“OK”按钮才可以使用。
BIF_RETURNONLYFSDIRS:仅仅返回文件系统的目录。例如:在浏览文件夹对话框中,当选中任意一个目录时,该“OK”按钮可用,而当选中“我的电脑”或“网上邻居”等非有意义的节点时,“OK”按钮为灰色。
BIF_STATUSTEXT:在对话框中包含一个状态区域。通过给对话框发送消息使回调函数设置状态文本。
BIF_VALIDATE:当没有BIF_EDITBOX标志位时,该标志位被忽略。如果用户在编辑框中输入的名字非法,浏览对话框将发送BFFM_VALIDATEFAILED消息给回调函数。
lpfn:应用程序定义的浏览对话框回调函数的地址。当对话框中的事件发生时,该对话框将调用回调函数。该参数可用为NULL。
lParam:对话框传递给回调函数的一个参数指针。
iImage:与选中目录相关的图像。该图像将被指定为系统图像列表中的索引值。
SHGetPathFromIDList
功能是把项目标志符列表转换为文档系统路径:
BOOL SHGetPathFromIDList(
LPCITEMIDLIST pidl,
LPSTR pszPath
);
参数:
pidl--- 一张相对于namespace的根(桌面)的项目标识符表地址,用于指定一个文档或目录地点;
pszPath---接收文档系统路径的缓冲地址,大小至少是MAX_PATH的字符长度

 

 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值