当前位置: 主页 > 日志 > VB >

VB调出系统目录选择对话框

效果图如下:



下面为“调出目录选择对话框”的VB模块

'API函数声明
Private Declare Sub CoTaskMemFree Lib "ole32.dll" (ByVal hMem As Long)
Private Declare Function lstrcat Lib "kernel32" Alias "lstrcatA" (ByVal lpString1 As String, ByVal lpString2 As String)As Long
Private Declare Function SHBrowseForFolder Lib "shell32" (lpbi As BrowseInfoAs Long
Private Declare Function SHGetPathFromIDList Lib "shell32" (ByVal pidList As Long, ByVal lpBuffer As StringAs Long
'常量声明

Private Const BIF_RETURNONLYFSDIRS = 1
Private Const MAX_PATH = 260

'自定义类型
Private Type BrowseInfo
    hWndOwner As Long
    pIDLRoot As Long
    pszDisplayName As Long
    lpszTitle As Long
    ulFlags As Long
    lpfnCallback As Long
    lParam As Long
    iImage As Long
End Type


Public Function SelectDirectory(thehwnd As LongAs String
    Dim iNull As Integer, lpIDList As Long, lResult As Long
    Dim sPath As String, udtBI As BrowseInfo

    With udtBI
        .hWndOwner = thehwnd
        .lpszTitle = lstrcat("请选择文件夹", ""'标题
        .ulFlags = BIF_RETURNONLYFSDIRS
    End With
    
    lpIDList = SHBrowseForFolder(udtBI)
    
    If lpIDList Then
        sPath = String$(MAX_PATH, 0)
        SHGetPathFromIDList lpIDList, sPath
        CoTaskMemFree lpIDList
        iNull = InStr(sPath, vbNullChar)
        If iNull Then
            sPath = Left$(sPath, iNull - 1)
        End If
    End If
    SelectDirectory = sPath
End Function


调用SelectDirectory函数即可。

[日志信息]

该日志于 2009-02-25 15:03 由 redice 发表在 redice's Blog ,你除了可以发表评论外,还可以转载 “VB调出系统目录选择对话框” 日志到你的网站或博客,但是请保留源地址及作者信息,谢谢!!    (尊重他人劳动,你我共同努力)
   
验证(必填):   点击我更换验证码

redice's Blog  is powered by DedeCms |  Theme by Monkeii.Lee |  网站地图 |  本服务器由西安鲲之鹏网络信息技术有限公司友情提供

返回顶部