人人做人人澡人人爽欧美,国产主播一区二区,久久久精品五月天,羞羞视频在线观看免费

當(dāng)前位置:蘿卜系統(tǒng)下載站 > 技術(shù)開(kāi)發(fā)教程 > 詳細(xì)頁(yè)面

在類中封裝目錄選擇對(duì)話框

在類中封裝目錄選擇對(duì)話框

更新時(shí)間:2022-08-31 文章作者:未知 信息來(lái)源:網(wǎng)絡(luò) 閱讀次數(shù):

    你是否在納悶,在VB公用對(duì)話框中怎么沒(méi)有目錄選擇對(duì)話框呢,事實(shí)上在API查看器中也未聲明這個(gè)API.本例用到的兩個(gè)API如下

SHBrowseForFolder

    用于瀏覽文件夾、打印機(jī)和網(wǎng)絡(luò)

SHGetPathFromIDList

    用于將項(xiàng)標(biāo)識(shí)符列表轉(zhuǎn)換為文件系統(tǒng)路徑

有了這兩個(gè)API函數(shù),你就可以構(gòu)造一個(gè)目錄選擇對(duì)話框類以代替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      '聲明對(duì)象變量
    Set c = New clsGetPath
    With c
        .Caption = "請(qǐng)選擇一個(gè)文件夾"
        .Flags = 0
        .hwnd = Me.hwnd
    End With
    c.GetFolder
    txtPath.Text = c.Folder
End Sub

溫馨提示:喜歡本站的話,請(qǐng)收藏一下本站!

本類教程下載

系統(tǒng)下載排行

網(wǎng)站地圖xml | 網(wǎng)站地圖html
主站蜘蛛池模板: 九龙县| 佛坪县| 洛浦县| 苏州市| 丰原市| 二连浩特市| 洪洞县| 唐海县| 台东县| 噶尔县| 怀集县| 荆门市| 大石桥市| 毕节市| 罗源县| 寿阳县| 定安县| 蓬莱市| 阿拉善右旗| 钦州市| 柳林县| 北票市| 龙南县| 布拖县| 宁德市| 钟山县| 兴仁县| 防城港市| 石屏县| 内黄县| 潼南县| 申扎县| 福泉市| 桃江县| 崇阳县| 禹城市| 桓台县| 日土县| 景德镇市| 阿勒泰市| 南岸区|