Function GetFolderPath() As Long
Dim bi As BROWSEINFO
Dim pidl As Long
'BROWSEINFO構造体の初期化
FillMemory(VarPtr(bi),Len(bi),0)
bi.hwndOwner=hMainWnd
bi.lpszTitle="フォルダを選択してください"
bi.ulFlags=BIF_RETURNONLYFSDIRS
'「フォルダの参照」ダイアログ?#123;ックスを表示
pidl=SHBrowseForFolder(bi)
If pidl Then
'フォルダへのパスを取得(lpFolderポインタが示すバッファにコピ?#91;)
SHGetPathFromIDList(pidl, ChosenFolderPath)
CoTaskMemFree(pidl)
GetFolderPath=1
SetDlgItemText(hMainWnd, Static_NowFolderPath, ChosenFolderPath)
Else
GetFolderPath=0
End If
End Function
私の環境(Windows XP HOME SP2)でも起こってますよ。
他にもShellExecuteやGetOpenFileName・GetSaveFileNameなどでエラーが起こります。但し、例外&アクセス違反になるのはデバッグモードのときだけで、リリースコンパイルすれば問題なしです。
※そのため、プログラムのデバッグにちょっと苦労してます(^^;;
> Function GetFolderPath() As Long
> Dim bi As BROWSEINFO
> Dim pidl As Long
> Dim buf[MAX_PATH] As byte
>
> ZeroMemory(VarPtr(bi),Len(bi))
> bi.hwndOwner=0
> bi.lpszTitle="フォルダを選択してください"
> bi.ulFlags=BIF_RETURNONLYFSDIRS
>
> pidl=SHBrowseForFolder(bi)
>
> If pidl Then
> SHGetPathFromIDList(pidl,buf)
> CoTaskMemFree(pidl)
> GetFolderPath=1
> MessageBox(0,buf,"選択したパス",0)
> Else
> GetFolderPath=0
> End If
> End Function
以上のソースを以下のようにした。
Function GetFolderPath() As Long
Dim bi As BROWSEINFO
Dim pidl As Long
Dim buf[MAX_PATH] As byte
If pidl Then
SHGetPathFromIDList(pidl,buf)
CoTaskMemFree(pidl)
GetFolderPath=1
MessageBox(0,buf,"選択したパス",0)
Else
GetFolderPath=0
End If
End Function
これでも、「pidl=SHBrowseForFolder(bi)」の部分でまだアクセス違反が起こります...。(泣)