Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / BrowseFolder не работает / 5 сообщений из 5, страница 1 из 1
26.08.2005, 11:35:23
    #33235703
ANTIVIR
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
BrowseFolder не работает
http://sql.ru/forum/actualthread.aspx?tid=211554 Подскажите , плз. (
...
Рейтинг: 0 / 0
26.08.2005, 11:57:47
    #33235756
Antonariy
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
BrowseFolder не работает
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
Private Declare Function SHBrowseForFolder Lib "shell32" (lpBI As BrowseInfo) As Long
Private Declare Function SHGetPathFromIDList Lib "shell32" (ByVal pidList As Long, ByVal lpBuffer As String) As Long
Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hWnd As Long, ByVal wMsg As WindowMessageConstants, ByVal wParam As Long, lParam As Any) As Long
Private Declare Sub CoTaskMemFree Lib "ole32.dll" (ByVal hMem As Long)

Private Enum BrowseFlagsEnum
    bifBrowseForComputer = &H1000&
    bifBrowseForPrinter = &H2000&
    bifBrowseIncludeFiles = &H4000&
    bifBrowseIncludeURLs = &H80&
    bifShareable = &H8000&
    bifDontGoBelowDomain = &H2&
    bifEditBox = &H10&
    bifReturnFSAncestors = &H8&
    bifReturnOnlyFSDirs = &H1&
    bifStatusText = &H4&
    bifUseNewUI = &H40&
    bifValidate = &H20&
End Enum

Private Const WM_USER As Long = &H400

Private Enum BrowseMessages
  'Messages from browser
    bffmInitialized =  1 
    bffmSelChanged =  2 
    bffmValidateFailedA =  3  'lParam:szPath ret:1(cont),0(EndDialog)
    bffmValidateFailedW =  4  'lParam:szPath ret:1(cont),0(EndDialog)
    'Messages to browser
    bffmSetStatusTextA = (WM_USER +  100 )
    bffmEnableOk = (WM_USER +  101 )
    bffmSetSelectionA = (WM_USER +  102 )
    bffmSetSelectionW = (WM_USER +  103 )
    bffmSetStatusTextW = (WM_USER +  104 )
#If Win32 Then
    bffmSetStatusText = bffmSetStatusTextW
    bffmSetSelection = bffmSetSelectionW
    bffmValidateFailed = bffmValidateFailedW
#Else
    bffmSetStatusText = bffmSetStatusTextA
    bffmSetSelection = bffmSetSelectionA
    bffmValidateFailed = bffmValidateFailedA
#End If
End Enum

Private Type BrowseInfo
    hWndOwner As Long
    pIDLRoot As Long
    pszDisplayName As Long
    lpszTitle As Long
    ulFlags As BrowseFlagsEnum
    lpfnCallback As Long
    lParam As Long
    iImage As Long
End Type

Private Enum WindowMessageConstants
    cbFindString = &H14C&
    cbGetItemHeight = &H154&
    cbLimitText = &H141&
    emLimitText = &HC5&
    lbFindString = &H18F&
End Enum

Private BrowsePath As String

Public Function dlgBrowseFolder(OwnerForm As Form, ByRef path As String, Optional ByVal Title As String, Optional ByVal AllowExtStyle As Boolean = False, Optional ByVal AllowManualEnter As Boolean = False) As String
Dim BI As BrowseInfo, lpIDList As Long
Const MaxPath As Long =  1024 &
    BrowsePath = path
    Title = StrConv(Title, vbFromUnicode)
    With BI
        If OwnerForm Is Nothing Then
            .hWndOwner =  0 &
        Else
            .hWndOwner = OwnerForm.hWnd
        End If
        .pIDLRoot =  0 &
        .pszDisplayName =  0 &
        .lpszTitle = StrPtr(Title)
        .ulFlags = bifReturnOnlyFSDirs Or IIf(AllowExtStyle, bifUseNewUI,  0 &) Or IIf(AllowManualEnter, bifEditBox,  0 &)
        .lpfnCallback = FnPtr(AddressOf BrowseCallbackProc)
        .lParam =  0 &
        .iImage =  0 &
    End With
    lpIDList = SHBrowseForFolder(BI)
    If lpIDList <>  0  Then
        path = String$(MaxPath,  0 )
        SHGetPathFromIDList lpIDList, path
        CoTaskMemFree lpIDList
        RemoveNullChar path
        dlgBrowseFolder = path
    End If
End Function
Private Sub RemoveNullChar(ByRef Text As String)
Dim I As Long
    I = InStr(Text, vbNullChar)
    If I >  0  Then Text = Left$(Text, I -  1 )
End Sub

Private Function FnPtr(ByVal lp As Long) As Long
    FnPtr = lp
End Function

Private Function BrowseCallbackProc(ByVal hWnd As Long, ByVal uMsg As Long, ByVal lParam As Long, ByVal lpData As Long) As Long
    If uMsg = BrowseMessages.bffmInitialized Then SendMessage hWnd, BrowseMessages.bffmSetSelectionA, True, ByVal BrowsePath
    BrowseCallbackProc =  0 &
End Function
...
Рейтинг: 0 / 0
26.08.2005, 12:20:21
    #33235825
ANTIVIR
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
BrowseFolder не работает
Этот вариант не пробовал, но почему не работает мой? У меня же не только отркытие папки, но и выбор файлов есть функция...Что не так?
...
Рейтинг: 0 / 0
26.08.2005, 13:07:22
    #33235993
Antonariy
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
BrowseFolder не работает
авторно почему не работает мой?
Х.з.
Тебе нужен работающий код или разобраться почему не работает твой?
Если первое, то сюда , там не только принтер.
Если второе, то особо помочь не могу, но могу хотя бы сказать, что диалог выбора файла требует callback-функцию, которой там нет.
...
Рейтинг: 0 / 0
26.08.2005, 14:42:51
    #33236317
ANTIVIR
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
BrowseFolder не работает
Касперский антивирус закопать там где его никто не найдет !!!
...
Рейтинг: 0 / 0
Форумы / Visual Basic [игнор отключен] [закрыт для гостей] / BrowseFolder не работает / 5 сообщений из 5, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]