VB中用API函数实现文件夹列表

发表于:2007-07-14来源:作者:点击数: 标签:
山东济宁市食品进出口公司 唐成斌 ---- 在安装软件等一些操作中,需要用户指定安装路径,现在软件的安装界面都是非常友好的,一般来说给出一个缺省路径,用户如不满意可以在文件夹列表中选择其他的路径。 在WIN9X下,一般不再采用原来的先在驱动器列表框中选
山东济宁市食品进出口公司 唐成斌

---- 在安装软件等一些操作中,需要用户指定安装路径,现在软件的安装界面都是非常友好的,一般来说给出一个缺省路径,用户如不满意可以在文件夹列表中选择其他的路径。 在WIN9X下,一般不再采用原来的先在驱动器列表框中选择驱动器再在相应的驱动器中选择相应文件夹的界面,而是采用的类似资源管理器中“所有文件夹”界面:最上层是“桌面”,然后是“我的电脑”、驱动器A、C、D...等,在一个列表框中用户可实现浏览所有驱动器及文件夹的操作。这种特色的文件列表没有现成的控件可供使用,但利用API函数可方便地实现。

---- 实现方法:API函数SHBrowseForFolder可以提供这样的文件列表,它需要用到一个BROWSEINFO类型,此类型包括了列表框使用的参数,此类型的声明见下面的程序,其中这里用到的几个参数简单说明一下:

---- hwndOwner—当前窗口的句柄。

---- pidlRoot—从何根路径开始展开文件夹,缺省情况下从“桌面”开始展开。

---- lpszTitle—目录树上方的标题,用来给用户一些提示信息。

---- ulFlags—显示标志控制项:比如若赋值为BIF_BROWSEFORCOMPUTER,则只有当用户选择“我的电脑”时“确定”按钮才有效,这里我们需要的是

---- BIF_RETURNONLYFSDIRS,只有用户选择的是文件夹时“确定”按钮才有效。

---- 此函数返回值是指向项目(ITEM)的一个指针,有了这个数值,再用API函数SHGetPathFromIDList可以获得具体的路径,如果用户按的是“取消”按钮,则返回值为NULL。

---- 下面是一个例子,在窗体中放置一个命令按钮command1、一个文本框Text1,在窗体的声明部分API声明函数和类型及常量如下:

Option Explicit

Private Type BROWSEINFO
   hOwner           As Long
   pidlRoot         As Long
   pszDisplayName   As String
   lpszTitle        As String
   ulFlags          As Long
   lpfn             As Long
   lParam           As Long
   iImage           As Long
End Type

Const BIF_RETURNONLYFSDIRS = &H1

Private pidl As Long

Private Declare Function
SHGetPathFromIDList _
   Lib "shell32.dll" Alias
   "SHGetPathFromIDListA" _
  (ByVal pidl As Long, ByVal
   pszPath As String) As Long

Private Declare Function
SHBrowseForFolder Lib "shell32.dll" _
   Alias "SHBrowseForFolderA" _
  (lpBrowseInfo As BROWSEINFO) As Long

---- 双击命令按钮,写如下代码:

  Private Sub command1_Click()
  Dim bi As BROWSEINFO
  Dim r As Long
  Dim pidl As Long
  Dim path As String
  Dim pos As Integer
  注释:句柄
  bi.hOwner = Me.hWnd
  注释:展开根目录
  bi.pidlRoot = 0&
注释:列表框标题
  bi.lpszTitle = "请选择软件安装路径:"
注释:规定只能选择文件夹,其他无效
  bi.ulFlags = BIF_RETURNONLYFSDIRS
注释:调用API函数显示列表框
  pidl = SHBrowseForFolder(bi)
注释:利用API函数获取返回的路径
  path = Space$(512)
  r = SHGetPathFromIDList(ByVal pidl&, ByVal path)
  If r Then
        pos = InStr(path, Chr$(0))
        Text1 = Left(path, pos - 1)
  Else: Text1 = ""
  End If
  End Sub

---- 运行此程序,单击命令按钮,就可以看到和资源管理器中一样的“所有文件夹”列表了。

---- 此程序在中文WIN95/98、中文VB5.0专业版下调试通过,也适用于VB4.0。 

原文转自:http://www.ltesting.net