亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? commondlg.bas

?? 智能倉庫管理系統
?? BAS
字號:
Attribute VB_Name = "modCommonDlg"
'*************************************************
'*******  模塊主要功能是取得公共對話框  **********
'*******  作用與CommonDialog控件相同    **********
'*************************************************


Option Explicit

Private Const cMaxPath = 1024
Private Const cMaxFile = 1024
Private Const sEmpty = ""


Public Enum EErrorCommonDialog
    eeBaseCommonDialog = 13450  ' CommonDialog
End Enum

Private Type OPENFILENAME
    lStructSize As Long          ' Filled with UDT size
    hwndOwner As Long            ' Tied to Owner
    hInstance As Long            ' Ignored (used only by templates)
    lpstrFilter As String        ' Tied to Filter
    lpstrCustomFilter As String  ' Ignored (exercise for reader)
    nMaxCustFilter As Long       ' Ignored (exercise for reader)
    nFilterIndex As Long         ' Tied to FilterIndex
    lpstrFile As String          ' Tied to FileName
    nMaxFile As Long             ' Handled internally
    lpstrFileTitle As String     ' Tied to FileTitle
    nMaxFileTitle As Long        ' Handled internally
    lpstrInitialDir As String    ' Tied to InitDir
    lpstrTitle As String         ' Tied to DlgTitle
    Flags As Long                ' Tied to Flags
    nFileOffset As Integer       ' Ignored (exercise for reader)
    nFileExtension As Integer    ' Ignored (exercise for reader)
    lpstrDefExt As String        ' Tied to DefaultExt
    lCustData As Long            ' Ignored (needed for hooks)
    lpfnHook As Long             ' Ignored (good luck with hooks)
    lpTemplateName As Long       ' Ignored (good luck with templates)
End Type

Private Declare Function GetOpenFileName Lib "COMDLG32" _
    Alias "GetOpenFileNameA" (file As OPENFILENAME) As Long
Private Declare Function GetSaveFileName Lib "COMDLG32" _
    Alias "GetSaveFileNameA" (file As OPENFILENAME) As Long
Private Declare Function GetFileTitle Lib "COMDLG32" _
    Alias "GetFileTitleA" (ByVal szFile As String, _
    ByVal szTitle As String, ByVal cbBuf As Long) As Long

Public Enum EOpenFile
    OFN_READONLY = &H1
    OFN_OVERWRITEPROMPT = &H2
    OFN_HIDEREADONLY = &H4
    OFN_NOCHANGEDIR = &H8
    OFN_SHOWHELP = &H10
    OFN_ENABLEHOOK = &H20
    OFN_ENABLETEMPLATE = &H40
    OFN_ENABLETEMPLATEHANDLE = &H80
    OFN_NOVALIDATE = &H100
    OFN_ALLOWMULTISELECT = &H200
    OFN_EXTENSIONDIFFERENT = &H400
    OFN_PATHMUSTEXIST = &H800
    OFN_FILEMUSTEXIST = &H1000
    OFN_CREATEPROMPT = &H2000
    OFN_SHAREAWARE = &H4000
    OFN_NOREADONLYRETURN = &H8000
    OFN_NOTESTFILECREATE = &H10000
    OFN_NONETWORKBUTTON = &H20000
    OFN_NOLONGNAMES = &H40000
    OFN_EXPLORER = &H80000
    OFN_NODEREFERENCELINKS = &H100000
    OFN_LONGNAMES = &H200000
End Enum

' Common dialog errors
Private Declare Function CommDlgExtendedError Lib "COMDLG32" () As Long

Public Enum EDialogError
    CDERR_DIALOGFAILURE = &HFFFF

    CDERR_GENERALCODES = &H0
    CDERR_STRUCTSIZE = &H1
    CDERR_INITIALIZATION = &H2
    CDERR_NOTEMPLATE = &H3
    CDERR_NOHINSTANCE = &H4
    CDERR_LOADSTRFAILURE = &H5
    CDERR_FINDRESFAILURE = &H6
    CDERR_LOADRESFAILURE = &H7
    CDERR_LOCKRESFAILURE = &H8
    CDERR_MEMALLOCFAILURE = &H9
    CDERR_MEMLOCKFAILURE = &HA
    CDERR_NOHOOK = &HB
    CDERR_REGISTERMSGFAIL = &HC

    PDERR_PRINTERCODES = &H1000
    PDERR_SETUPFAILURE = &H1001
    PDERR_PARSEFAILURE = &H1002
    PDERR_RETDEFFAILURE = &H1003
    PDERR_LOADDRVFAILURE = &H1004
    PDERR_GETDEVMODEFAIL = &H1005
    PDERR_INITFAILURE = &H1006
    PDERR_NODEVICES = &H1007
    PDERR_NODEFAULTPRN = &H1008
    PDERR_DNDMMISMATCH = &H1009
    PDERR_CREATEICFAILURE = &H100A
    PDERR_PRINTERNOTFOUND = &H100B
    PDERR_DEFAULTDIFFERENT = &H100C

    CFERR_CHOOSEFONTCODES = &H2000
    CFERR_NOFONTS = &H2001
    CFERR_MAXLESSTHANMIN = &H2002

    FNERR_FILENAMECODES = &H3000
    FNERR_SUBCLASSFAILURE = &H3001
    FNERR_INVALIDFILENAME = &H3002
    FNERR_BUFFERTOOSMALL = &H3003

    CCERR_CHOOSECOLORCODES = &H5000
End Enum

Function VBGetOpenFileName(FileName As String, _
                           Optional FileTitle As String, _
                           Optional FileMustExist As Boolean = True, _
                           Optional MultiSelect As Boolean = False, _
                           Optional ReadOnly As Boolean = False, _
                           Optional HideReadOnly As Boolean = False, _
                           Optional filter As String = "All (*.*)| *.*", _
                           Optional FilterIndex As Long = 1, _
                           Optional InitDir As String, _
                           Optional DlgTitle As String, _
                           Optional DefaultExt As String, _
                           Optional Owner As Long = -1, _
                           Optional Flags As Long = 0) As Boolean

    Dim opfile As OPENFILENAME, s As String, afFlags As Long

With opfile
    .lStructSize = Len(opfile)
    
    ' Add in specific flags and strip out non-VB flags
    .Flags = (-FileMustExist * OFN_FILEMUSTEXIST) Or _
             (-MultiSelect * OFN_ALLOWMULTISELECT) Or _
             (-ReadOnly * OFN_READONLY) Or _
             (-HideReadOnly * OFN_HIDEREADONLY) Or _
             (Flags And CLng(Not (OFN_ENABLEHOOK Or _
                                  OFN_ENABLETEMPLATE)))
    ' Owner can take handle of owning window
    If Owner <> -1 Then .hwndOwner = Owner
    ' InitDir can take initial directory string
    .lpstrInitialDir = InitDir
    ' DefaultExt can take default extension
    .lpstrDefExt = DefaultExt
    ' DlgTitle can take dialog box title
    .lpstrTitle = DlgTitle
    
    ' To make Windows-style filter, replace | and : with nulls
    Dim ch As String, i As Integer
    For i = 1 To Len(filter)
        ch = Mid$(filter, i, 1)
        If ch = "|" Or ch = ":" Then
            s = s & vbNullChar
        Else
            s = s & ch
        End If
    Next
    ' Put double null at end
    s = s & vbNullChar & vbNullChar
    .lpstrFilter = s
    .nFilterIndex = FilterIndex

    ' Pad file and file title buffers to maximum path
    s = FileName & String$(cMaxPath - Len(FileName), 0)
    .lpstrFile = s
    .nMaxFile = cMaxPath
    s = FileTitle & String$(cMaxFile - Len(FileTitle), 0)
    .lpstrFileTitle = s
    .nMaxFileTitle = cMaxFile
    ' All other fields set to zero
    
    If GetOpenFileName(opfile) Then
        VBGetOpenFileName = True
        FileName = Left$(.lpstrFile, Len(.lpstrFile))
        FileTitle = Left$(.lpstrFileTitle, Len(.lpstrFileTitle))
        Flags = .Flags
        ' Return the filter index
        FilterIndex = .nFilterIndex
        ' Look up the filter the user selected and return that
        filter = FilterLookup(.lpstrFilter, FilterIndex)
        If (.Flags And OFN_READONLY) Then ReadOnly = True
    Else
        VBGetOpenFileName = False
        FileName = sEmpty
        FileTitle = sEmpty
        Flags = 0
        FilterIndex = -1
        filter = sEmpty
    End If
End With
End Function

Function VBGetSaveFileName(FileName As String, _
                           Optional FileTitle As String, _
                           Optional OverWritePrompt As Boolean = True, _
                           Optional filter As String = "All (*.*)| *.*", _
                           Optional FilterIndex As Long = 1, _
                           Optional InitDir As String, _
                           Optional DlgTitle As String, _
                           Optional DefaultExt As String, _
                           Optional Owner As Long = -1, _
                           Optional Flags As Long) As Boolean
            
    Dim opfile As OPENFILENAME, s As String
With opfile
    .lStructSize = Len(opfile)
    
    ' Add in specific flags and strip out non-VB flags
    .Flags = (-OverWritePrompt * OFN_OVERWRITEPROMPT) Or _
             OFN_HIDEREADONLY Or _
             (Flags And CLng(Not (OFN_ENABLEHOOK Or _
                                  OFN_ENABLETEMPLATE)))
    ' Owner can take handle of owning window
    If Owner <> -1 Then .hwndOwner = Owner
    ' InitDir can take initial directory string
    .lpstrInitialDir = InitDir
    ' DefaultExt can take default extension
    .lpstrDefExt = DefaultExt
    ' DlgTitle can take dialog box title
    .lpstrTitle = DlgTitle
    
    ' Make new filter with bars (|) replacing nulls and double null at end
    Dim ch As String, i As Integer
    For i = 1 To Len(filter)
        ch = Mid$(filter, i, 1)
        If ch = "|" Or ch = ":" Then
            s = s & vbNullChar
        Else
            s = s & ch
        End If
    Next
    ' Put double null at end
    s = s & vbNullChar & vbNullChar
    .lpstrFilter = s
    .nFilterIndex = FilterIndex

    ' Pad file and file title buffers to maximum path
    s = FileName & String$(cMaxPath - Len(FileName), 0)
    .lpstrFile = s
    .nMaxFile = cMaxPath
    s = FileTitle & String$(cMaxFile - Len(FileTitle), 0)
    .lpstrFileTitle = s
    .nMaxFileTitle = cMaxFile
    ' All other fields zero
    
    If GetSaveFileName(opfile) Then
        VBGetSaveFileName = True
        FileName = Left$(.lpstrFile, Len(.lpstrFile))
        FileTitle = Left$(.lpstrFileTitle, Len(.lpstrFileTitle))
        Flags = .Flags
        ' Return the filter index
        FilterIndex = .nFilterIndex
        ' Look up the filter the user selected and return that
        filter = FilterLookup(.lpstrFilter, FilterIndex)
    Else
        VBGetSaveFileName = False
        FileName = sEmpty
        FileTitle = sEmpty
        Flags = 0
        FilterIndex = 0
        filter = sEmpty
    End If
End With
End Function

Private Function FilterLookup(ByVal sFilters As String, ByVal iCur As Long) As String
    Dim iStart As Long, iEnd As Long, s As String
    iStart = 1
    If sFilters = sEmpty Then Exit Function
    Do
        ' Cut out both parts marked by null character
        iEnd = InStr(iStart, sFilters, vbNullChar)
        If iEnd = 0 Then Exit Function
        iEnd = InStr(iEnd + 1, sFilters, vbNullChar)
        If iEnd Then
            s = Mid$(sFilters, iStart, iEnd - iStart)
        Else
            s = Mid$(sFilters, iStart)
        End If
        iStart = iEnd + 1
        If iCur = 1 Then
            FilterLookup = s
            Exit Function
        End If
        iCur = iCur - 1
    Loop While iCur
End Function

Function VBGetFileTitle(sFile As String) As String
    Dim sFileTitle As String, cFileTitle As Integer

    cFileTitle = cMaxPath
    sFileTitle = String$(cMaxPath, 0)
    cFileTitle = GetFileTitle(sFile, sFileTitle, cMaxPath)
    If cFileTitle Then
        VBGetFileTitle = sEmpty
    Else
        VBGetFileTitle = Left$(sFileTitle, InStr(sFileTitle, vbNullChar) - 1)
    End If

End Function

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品蜜臀在线观看| 免费在线观看成人| 精东粉嫩av免费一区二区三区| 色婷婷国产精品| 亚洲精品亚洲人成人网| 色综合天天天天做夜夜夜夜做| 国产精品视频一二三| 久久一区二区视频| 成人黄色a**站在线观看| 中文av字幕一区| 国产精品高清亚洲| 日韩一卡二卡三卡四卡| 国产乱人伦偷精品视频不卡 | 亚洲免费观看高清完整版在线观看 | 欧美欧美午夜aⅴ在线观看| 亚洲va欧美va人人爽午夜| 欧美一级视频精品观看| 高清国产一区二区三区| 水野朝阳av一区二区三区| 中文av字幕一区| 亚洲资源中文字幕| 欧美国产综合色视频| 日韩午夜在线影院| 国产精品美女久久久久久久久久久| 中文字幕亚洲不卡| 久久精品亚洲麻豆av一区二区 | 亚洲午夜视频在线| 国产精品国产精品国产专区不蜜 | 亚洲bdsm女犯bdsm网站| 日韩国产精品久久久久久亚洲| 亚洲欧洲99久久| 亚洲国产精品人人做人人爽| 美女尤物国产一区| 午夜精品成人在线视频| 亚洲免费毛片网站| 久久精品国产久精国产| 日韩成人午夜电影| av电影在线不卡| 成人性生交大片免费看中文网站| 看电视剧不卡顿的网站| 波波电影院一区二区三区| 欧美日本一道本在线视频| 国产精品丝袜久久久久久app| 午夜精品在线看| 成人av在线播放网址| 51精品秘密在线观看| 欧美三级乱人伦电影| 色香蕉成人二区免费| 精品久久五月天| 久久久久国产精品免费免费搜索| 久久欧美一区二区| 性欧美疯狂xxxxbbbb| 99久久免费精品| 欧美日韩一区二区电影| 国产精品污污网站在线观看| 久久99精品一区二区三区三区| 欧美日韩一级黄| 亚洲精品乱码久久久久久| 懂色av一区二区夜夜嗨| 精品欧美乱码久久久久久 | 日韩一区在线播放| 国产夫妻精品视频| 97se亚洲国产综合自在线| 久久久青草青青国产亚洲免观| 日韩福利电影在线观看| 欧美精品aⅴ在线视频| 日韩欧美一区二区视频| 欧美一区日韩一区| 天天影视涩香欲综合网| 欧美精品日韩一区| 日韩一区精品字幕| 欧美一区二区三区在线观看 | 久久九九全国免费| 国产一区二区福利视频| 91成人在线免费观看| 日韩三级视频中文字幕| 免费成人在线播放| 欧美大尺度电影在线| 狠狠色伊人亚洲综合成人| 色香色香欲天天天影视综合网| 国产精品第五页| 在线观看91精品国产入口| 久久久久久免费毛片精品| 国内精品伊人久久久久av影院 | 欧美一区午夜精品| 久久成人麻豆午夜电影| 久久久另类综合| 9i在线看片成人免费| 伊人色综合久久天天| 欧美日韩高清影院| 国内精品伊人久久久久av一坑| 亚洲国产精品二十页| 色94色欧美sute亚洲线路一ni | 国产免费观看久久| 日韩影视精彩在线| 久久久精品国产免大香伊| 99久久精品免费观看| 午夜欧美视频在线观看| 久久久亚洲欧洲日产国码αv| www.成人在线| 天天综合色天天| 国产三级一区二区| 欧美视频完全免费看| 自拍偷在线精品自拍偷无码专区| 免费日韩伦理电影| 欧美国产日韩一二三区| 欧美日韩高清一区二区不卡| 精品中文字幕一区二区| 亚洲精选视频在线| 久久亚洲免费视频| 欧美丝袜丝交足nylons| 国产福利91精品一区| 亚洲综合色网站| 亚洲国产经典视频| 欧美精品久久一区二区三区| 国产激情一区二区三区四区| 亚洲国产欧美日韩另类综合| 欧美韩国日本不卡| 日韩一区二区三区高清免费看看| 丰满白嫩尤物一区二区| 日产欧产美韩系列久久99| 亚洲图片另类小说| 精品播放一区二区| 国产成人综合精品三级| 日韩中文字幕亚洲一区二区va在线| 国产婷婷一区二区| 日韩一区二区三免费高清| 色美美综合视频| 成人avav影音| 国内精品免费在线观看| 午夜精品久久一牛影视| 亚洲男女一区二区三区| 国产三级久久久| 日韩精品一区二区三区蜜臀 | 欧美日产国产精品| 色先锋久久av资源部| 99久久综合国产精品| 国产乱子伦视频一区二区三区| 久久精品国产久精国产爱| 日韩黄色免费电影| 午夜精品久久久久久久久久久| 亚洲色图制服丝袜| 亚洲欧美日韩中文播放| 自拍偷自拍亚洲精品播放| 日本一区二区三区在线观看| 国产亚洲欧美日韩俺去了| 久久综合国产精品| 国产日韩影视精品| 国产日韩一级二级三级| 中文字幕精品—区二区四季| 亚洲国产精品精华液2区45| 国产欧美一区二区在线| 亚洲国产电影在线观看| 欧美精选在线播放| 国产成a人亚洲| 图片区小说区区亚洲影院| 自拍av一区二区三区| 亚洲日本中文字幕区| 亚洲另类在线视频| 亚洲国产美女搞黄色| 天天操天天色综合| 九九九久久久精品| 国产一区二区三区美女| 成人黄色大片在线观看| 日本乱码高清不卡字幕| 欧美日韩国产不卡| 2022国产精品视频| 亚洲欧美怡红院| 亚洲成人午夜电影| 美女视频黄频大全不卡视频在线播放| 另类小说综合欧美亚洲| 国产高清精品网站| 一本久道中文字幕精品亚洲嫩 | 欧美日韩精品欧美日韩精品一综合| 欧美浪妇xxxx高跟鞋交| 欧美mv日韩mv| 中文字幕一区二区三区在线观看 | 国产精品一区二区三区四区| 成人国产一区二区三区精品| 在线观看网站黄不卡| 91精品国产91久久久久久最新毛片| 精品入口麻豆88视频| 亚洲丝袜另类动漫二区| 日本欧美一区二区三区| 成人性生交大合| 91精品国产综合久久福利软件| 久久久五月婷婷| 午夜精品久久久久| 懂色av噜噜一区二区三区av| 欧美久久久久久蜜桃| 国产精品萝li| 久久精品国产免费| 91福利国产精品| 国产精品无人区| 精品一区二区久久| 在线观看91视频| 国产精品天美传媒| 精品综合免费视频观看| 欧美日韩一区三区四区| 国产精品久久久久久久久晋中 |