Mr.Victor

梦里不知身是客,一晌贪欢!
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

如何使用“浏览文件夹”选择对话窗

Posted on 2011-08-20 16:33  Mr-Victor  阅读(729)  评论(0编辑  收藏  举报

本文摘自:http://www.cnblogs.com/wangliang651/archive/2006/07/07/445473.html(稍作修改)

有时我们需要获得某个文件夹的路径,而不是文件的路径,这时需要用API函数SHBrowseForFolder来实现。

函数原型为:

LPITEMIDLIST SHBrowseForFolder(LPBROWSEINFO lpbi);

其中LPBROWSEINFO为BROWSEINFO结构的指针。

Visual C++(VC)中,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:与选中目录相关的图像。该图像将被指定为系统图像列表中的索引值。

调用例子如下: 
void CXXXDlg::OnBnClickedButton3()
{
  CString sFolderPath; //用来存储路径
  char szPath[MAX_PATH] = {0}; //用来得到你选择的活页夹路径,相当于提供一个缓冲区

  BROWSEINFO m_bi;
  m_bi.ulFlags = BIF_RETURNONLYFSDIRS | BIF_STATUSTEXT | BIF_EDITBOX |   BIF_NEWDIALOGSTYLE;
  m_bi.hwndOwner = GetSafeHwnd();  //获得父窗口句柄
  m_bi.pidlRoot = NULL;
  m_bi.lpszTitle = "Select Folder";
  m_bi.lpfn = NULL;
  m_bi.lParam = NULL;
  m_bi.pszDisplayName = szPath;  //此参数如为NULL则不能显示对话框
  LPITEMIDLIST pidl = ::SHBrowseForFolder(&m_bi);  //调用显示对话框
  //弹出文件夹浏览目录,并选取目录
  if(pidl)
  {
    //取得文件夹路径到szPath里
    if(!::SHGetPathFromIDList(pidl,szPath))
      szPath[0] = 0;
    //将路径保存到一个CString对象里
    sFolderPath = szPath;

    IMalloc * pMalloc = NULL;
    if(SUCCEEDED(::SHGetMalloc(&pMalloc)))  //取得IMalloc分配器接口
    {
      pMalloc->Free(pidl); //释放内存
      pMalloc->Release();  //释放接口
    }
  }
  MessageBox(sFolderPath);
}