// 使用 BROWSEINFO 结构体,
// SHBrowseForFolder 显示文件夹选择对话框
// SHGetPathFromIDList 获得对话框选择的路径
void CXXXDlg::OnSelectDirectory()
{
TCHAR szPath[MAX_PATH];
memset(szPath, 0, sizeof(szPath));
BROWSEINFO bi;
bi.hwndOwner = m_hWnd; // 拥有者窗体
bi.pidlRoot = NULL; //
bi.pszDisplayName = szPath;
bi.lpszTitle = TEXT("选择路径");
bi.ulFlags = 0;
bi.lpfn = NULL;
bi.lParam = 0;
bi.iImage = NULL;
LPITEMIDLIST lp = SHBrowseForFolder(&bi);
if (lp && SHGetPathFromIDList(lp, szPath))
{
m_directory = szPath;
SetTreeDir();
}
}
\*=============================================================
typedef struct _browseinfo {
HWND hwndOwner; // 父窗体句柄
LPCITEMIDLIST pidlRoot;// ITEMIDLIST结构的地址,包含浏览时的初始根目录,而且只有被指定的目录和其子目录才显示在浏览文件夹对话框中。该成员变量可以是NULL,在此时桌面目录将被使用
LPTSTR pszDisplayName;// 用来保存用户选中的目录字符串的内存地址。该缓冲区的大小缺省是定义的MAX_PATH常量宏
LPCTSTR lpszTitle;// 该浏览文件夹对话框对话框的显示文本,用来提示该浏览文件夹对话框的功能、作用和目的
UINT ulFlags;// 该标志位描述了对话框的选项
BFFCALLBACK lpfn;// 应用程序定义的浏览对话框回调函数的地址。当对话框中的事件发生时,该对话框将调用回调函数。该参数可用为NULL。
LPARAM lParam;// 对话框传递给回调函数的一个参数指针
int iImage;// 与选中目录相关的图像。该图像将被指定为系统图像列表中的索引值
} BROWSEINFO, *PBROWSEINFO, *LPBROWSEINFO;
uFlags可以使一下成员的组合:
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消息给回调函数。
=============================================================*/