六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

在類中封裝目錄選擇對話框

[摘要]你是否在納悶,在VB公用對話框中怎么沒有目錄選擇對話框呢,事實上在API查看器中也未聲明這個API.本例用到的兩個API如下SHBrowseForFolder 用于瀏覽文件夾、打印機和網絡SHGetPathFromIDList 用于將項標識符列表轉換為文件系統路徑有了這兩個API函數,...
    你是否在納悶,在VB公用對話框中怎么沒有目錄選擇對話框呢,事實上在API查看器中也未聲明這個API.本例用到的兩個API如下

SHBrowseForFolder

    用于瀏覽文件夾、打印機和網絡

SHGetPathFromIDList

    用于將項標識符列表轉換為文件系統路徑

有了這兩個API函數,你就可以構造一個目錄選擇對話框類以代替VB中的目錄控件.類clsGetPath的完整代碼如下:

Option Explicit
'API聲明部分
Private Declare Function SHBrowseForFolder Lib "shell32.dll" Alias "SHBrowseForFolderA" (lpBrowseInfo As BROWSEINFO) As Long
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

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

Private Const BIF_RETURNONLYFSDIRS = 0
Private Const BIF_DONTGOBELOWDOMAIN = 1
Private Const BIF_STATUSTEXT = 2
Private Const BIF_RETURNFSANCESTORS = 3
Private Const BIF_BROWSEFORCOMPUTER = 4
Private Const BIF_BROWSEFORPRINTER = 5

'變量聲明
Private mvarCaption As String
Private mvarhWnd As Long
Private mvarFlags As Integer
Private mvarFolder As Variant

'類的屬性
Public Property Let Folder(ByVal vData As Variant)
    mvarFolder = vData
End Property

Public Property Set Folder(ByVal vData As Variant)
    Set mvarFolder = vData
End Property

Public Property Get Folder() As Variant
    If IsObject(mvarFolder) Then
        Set Folder = mvarFolder
    Else
        Folder = mvarFolder
    End If
End Property

Public Property Let Flags(ByVal vData As Integer)
    mvarFlags = vData
End Property

Public Property Get Flags() As Integer
    Flags = mvarFlags
End Property

Public Property Let hwnd(ByVal vData As Long)
    mvarhWnd = vData
End Property

Public Property Get hwnd() As Long
    hwnd = mvarhWnd
End Property

Public Property Let Caption(ByVal vData As String)
    mvarCaption = vData
End Property

Public Property Get Caption() As String
    Caption = mvarCaption
End Property

'類的方法
Public Sub GetFolder()
    Dim bi As BROWSEINFO
    Dim pidl As Long
    Dim ret As String

    ret = String$(255, Chr$(0))

    With bi
        .hOwner = hwnd
        .ulFlags = Flags
        If Caption <> "" Then
            .lpszTitle = Caption & Chr$(0)
        Else
            .lpszTitle = "Select a Folder..." & Chr$(0)
        End If
    End With

    pidl = SHBrowseForFolder(bi)

    If SHGetPathFromIDList(ByVal pidl, ByVal ret) Then
        Folder = Left$(ret, InStr(ret, Chr$(0)) - 1)
    Else
        Folder = ""
    End If
End Sub

在程序中使用類的代碼:

Private Sub cmdBrowse_Click()
    Dim c As clsGetPath      '聲明對象變量
    Set c = New clsGetPath
    With c
        .Caption = "請選擇一個文件夾"
        .Flags = 0
        .hwnd = Me.hwnd
    End With
    c.GetFolder
    txtPath.Text = c.Folder
End Sub


主站蜘蛛池模板: 亚洲欧美日韩专区一 | 泄欲网站免费观看 | 中文字幕人成乱在线视频 | 亚洲成人播放 | 又硬又粗又长又爽免费看 | 天天干网站 | 日韩视频在线免费 | 欧美在线视频观看 | 日韩国产中文字幕 | 亚洲国产精品成人综合色在线婷婷 | 亚洲国产欧美在线人成精品一区二区 | 青草福利| 欧美一区日韩一区中文字幕页 | 一级做a爰片久久毛片美女图片 | 人人网碰人人网超 | 色欧美片视频在线观看 | 亚洲四虎 | 日本综合在线观看 | 亚洲欧美大片 | 日日操日日爽 | 青青久在线视频免费观看 | 欧美一级片网址 | 日韩午夜激情视频 | 欧美视频在线免费看 | 日韩美女一区 | 四虎永久精品免费观看 | 四虎国产成人免费观看 | 一区二区三区福利 | 天天拍久久 | 日本最新伦中文字幕 | 亚洲日韩精品欧美一区二区 | 影音先锋色先锋 | 青草青草视频 | 一级做a爰片久久毛片毛片 一级做a爰片久久毛片看看 | 欧美亚洲免费 | 亚洲春色第一页 | 青青草黄| 四虎国产永久在线精品免费观看 | 日产精品久久久一区二区 | 日韩国产有码在线观看视频 | 日本在线日本中文字幕日本在线视频播放 |