|
|
|
Диалог на выбор папки ?
|
|||
|---|---|---|---|
|
#18+
Уважаемые мастера ! Подскажите как вызвать юзеру диалог выбора ТОЛЬКО папки ...(он дожен выбрать только папку) и потом путь передать в TextBox вроде нада на API ... Jojo® ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 29.04.2004, 12:17 |
|
||
|
Диалог на выбор папки ?
|
|||
|---|---|---|---|
|
#18+
У меня на VBA Excel ****************** Option Explicit 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 Private Enum WhatBrowse BIF_RETURNONLYFSDIRS = &H1 BIF_BROWSEINCLUDEFILES = &H1 Or &H4000 BIF_BROWSEFORCOMPUTER = &H1000 BIF_BROWSEFORPRINTER = &H2000 End Enum Private Const MAX_PATH = 260 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 BrowseInfo) As Long Private Declare Function SHGetPathFromIDList Lib "shell32" (ByVal pidList As Long, ByVal lpBuffer As String) As Long Public Function fBrowseForFolder(hWndOwner As Long, sPrompt As String, WhatBr) As String Dim iNull As Integer Dim lpIDList As Long Dim lResult As Long Dim sPath As String Dim udtBI As BrowseInfo With udtBI .hWndOwner = hWndOwner .lpszTitle = lstrcat(sPrompt, "") .ulFlags = WhatBr End With lpIDList = SHBrowseForFolder(udtBI) If lpIDList Then sPath = String$(MAX_PATH, 0) lResult = SHGetPathFromIDList(lpIDList, sPath) Call CoTaskMemFree(lpIDList) iNull = InStr(sPath, vbNullChar) If iNull Then sPath = Left$(sPath, iNull - 1) End If fBrowseForFolder = sPath End Function Private Sub CbFilePer_Click() ' *********** Dim sStr As String Dim hWnd As Long 'вместо входящего параметра BIF_BROWSEINCLUDEFILES вы можете использовать одну из 'BIF-констант, описанных строчкой Private Enum WhatBrowse (смотри в разделе General_Declarations) sStr = fBrowseForFolder(hWnd, "Выберите файл !", BIF_BROWSEINCLUDEFILES) Workbooks("zt.xls").Sheets("Общие_данные").Cells(17, 8).Value = sStr ' *********** End Sub ****************** Jojo® ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 29.04.2004, 12:18 |
|
||
|
Диалог на выбор папки ?
|
|||
|---|---|---|---|
|
#18+
Есть другие варианты более компактные ? Jojo® ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 29.04.2004, 12:19 |
|
||
|
Диалог на выбор папки ?
|
|||
|---|---|---|---|
|
#18+
Со свойствами CommonDialog пробовал поиграться? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 29.04.2004, 12:27 |
|
||
|
Диалог на выбор папки ?
|
|||
|---|---|---|---|
|
#18+
там конечно можно вытянуть ...путь ...но так некрасиво это делается ... лучше уж я оставлю 1 вариант ...на API он красиво работает :) Jojo® ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 29.04.2004, 12:43 |
|
||
|
Диалог на выбор папки ?
|
|||
|---|---|---|---|
|
#18+
Во как : **************************************************** Option Explicit 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 Private Enum WhatBrowse BIF_RETURNONLYFSDIRS = &H1 'BIF_BROWSEINCLUDEFILES = &H1 Or &H4000 ' Мне файлов не надо 'BIF_BROWSEFORCOMPUTER = &H1000 ' Компов тоже 'BIF_BROWSEFORPRINTER = &H2000 ' Принтеров тоже не нада End Enum Private Const MAX_PATH = 260 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 BrowseInfo) As Long Private Declare Function SHGetPathFromIDList Lib "shell32" (ByVal pidList As Long, ByVal lpBuffer As String) As Long Public Function fBrowseForFolder(hWndOwner As Long, sPrompt As String, WhatBr) As String Dim iNull As Integer Dim lpIDList As Long Dim lResult As Long Dim sPath As String Dim udtBI As BrowseInfo With udtBI .hWndOwner = hWndOwner .lpszTitle = lstrcat(sPrompt, "") .ulFlags = WhatBr End With lpIDList = SHBrowseForFolder(udtBI) If lpIDList Then sPath = String$(MAX_PATH, 0) lResult = SHGetPathFromIDList(lpIDList, sPath) Call CoTaskMemFree(lpIDList) iNull = InStr(sPath, vbNullChar) If iNull Then sPath = Left$(sPath, iNull - 1) End If fBrowseForFolder = sPath End Function Private Sub BtZt_Click() ' *********** Dim sStr As String Dim hWnd As Long 'вместо входящего параметра BIF_BROWSEINCLUDEFILES вы можете использовать одну из 'BIF-констант, описанных строчкой Private Enum WhatBrowse (смотри в разделе General_Declarations) sStr = fBrowseForFolder(hWnd, "Выберите каталог !", BIF_RETURNONLYFSDIRS) Tbzt.Text = sStr ' *********** End Sub Jojo® ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 29.04.2004, 13:08 |
|
||
|
|

start [/forum/topic.php?fid=60&fpage=244&tid=2164405]: |
0ms |
get settings: |
9ms |
get forum list: |
15ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
61ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
32ms |
get tp. blocked users: |
1ms |
| others: | 235ms |
| total: | 373ms |

| 0 / 0 |
