ページ 1 / 1
複数のドラッグアンドドロップ
Posted: 2016年11月26日(土) 20:13
by TISAproject
複数のファイルとフォルダーがドラッグアンドドロップされた場合、一つずつ表示するにはどうすればいいでしょう?
コード: 全て選択
Dim Onthefile
Function DropEditProc(hWnd As HWND, message As DWORD, wParam As DWORD, lParam As DWORD) As DWORD
Select Case message
Case WM_DROPFILES
Dim hDrop As HDROP
Dim FileName[MAX_PATH] As Byte
Dim FileName2 As string
hDrop=wParam As HDROP
'ドロップされたファイル名を取得
DragQueryFile(hDrop, 0, FileName, MAX_PATH)
Onthefile = FileName
SetWindowText(hMainWnd, "Fast-Deleter" )
SetWindowText(GetDlgItem(hMainWnd,CommandButton1),"[ " & Onthefile & " ]: 削除しますか。" )
KillTimer(hMainWnd,0)
DragFinish(hDrop)
DropEditProc=0
Exit Function
End Select
DropEditProc=CallWindowProc(DefEditProc As VoidPtr, hWnd, message, wParam, lParam)
End Function
Sub MainWnd_Create(ByRef CreateStruct As CREATESTRUCT)
DefEditProc=SetWindowLong(GetDlgItem(hMainWnd, CommandButton1), GWL_WNDPROC, AddressOf(DropEditProc) As Long)
End Sub
Re: 複数のドラッグアンドドロップ
Posted: 2016年11月27日(日) 20:49
by たかせ
WIN API32のDragQueryFileの第2パラメータに-1を指定するとドロップされたファイルの数が返却値に設定されます。
そしてドロップされたファイルの数分表示します。
下記にコーディング例を記載しますのでご確認下さい。
ただし私の場合はドラッグアンドドロップイベントをRADで自動生成していますのでTISAprojectさんのコーディング形式とまったく異なりますのでご了承願います。
詳細はABのヘルプに記載されています。
SUB MainWnd_DropFiles(HDROP AS HANDLE)
DIM SUU AS Long
DIM IDX AS Long
SUU = DragQueryFile(HDROP,-1,NULL,0)
FOR IDX = 0 TO SUU - 1
DragQueryFile(HDROP,IDX,FILENAME,255)
MessageBox(hMainWnd,FILENAME,PGMID,MB_OK)
NEXT
DragFinish(HDROP)
END SUB
Re: 複数のドラッグアンドドロップ
Posted: 2016年11月28日(月) 21:29
by TISAproject
現在、ドラッグアンドドロップされたファイルをツリービューに表示するprojectを練っているのですが、なかなか上手く行きません。
コード: 全て選択
'-----------------------------------------------------------------------------
' イベント プロシージャ
'-----------------------------------------------------------------------------
' このファイルには、ウィンドウ [MainWnd] に関するイベントをコーディングします。
' ウィンドウ ハンドル: hMainWnd
' TODO: この位置にグローバルな変数、構造体、定数、関数を定義します。
'-----------------------------------------------------------------------------
' ウィンドウメッセージを処理するためのコールバック関数
Function MainWndProc(hWnd As HWND, dwMsg As DWord, wParam As WPARAM, lParam As LPARAM) As DWord
' TODO: この位置にウィンドウメッセージを処理するためのコードを記述します。
' イベントプロシージャの呼び出しを行います。
MainWndProc=EventCall_MainWnd(hWnd,dwMsg,wParam,lParam)
End Function
'-----------------------------------------------------------------------------
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub MainWnd_Destroy()
FastDeleterplus_DestroyObjects()
PostQuitMessage(0)
DragFinish(HDROP)
End Sub
SUB MainWnd_DropFiles(HDROP AS HANDLE)
DIM SUU AS Long
DIM IDX AS Long
DIM FILENAME AS string
DIM PGMID As *Byte
SUU = DragQueryFile(HDROP,-1,NULL,0)
FOR IDX = 0 TO SUU - 1
DragQueryFile(HDROP,IDX,FILENAME,255)
Dim hAny As Long
Dim tvi As TVINSERTSTRUCT
Dim hTreeItem As Long
'ツリービューのハンドルを得る
hAny = GetDlgItem( hMainWnd, TreeView1 )
'ルートの項目(アイテム)を追加する。
tvi.hParent = TVI_ROOT
tvi.hInsertAfter = TVI_SORT
tvi.item.mask = TVIF_TEXT
tvi.item.pszText = FILENAME
hTreeItem = TreeView_InsertItem( hAny , tvi )
NEXT
DragFinish(HDROP)
END SUB
'TreeViewで使用する追加定義。
Function TreeView_InsertItem( hWnd As Long, ByRef lpis As TVINSERTSTRUCT ) As Long
TreeView_InsertItem = SendMessage( hWnd, TVM_INSERTITEM, 0, VarPtr(lpis) )
EndFunction
結果
(50) "tvi.item.pszText" 型が違います
Re: 複数のドラッグアンドドロップ
Posted: 2016年11月28日(月) 22:38
by たかせ
私はツリービューについてまったくわかりませんが、
tvi.item.pszTextはポインタ型なので変数の型が違うとエラーが出ます。
なのでFILENAMEをString型からByte/Char型の配列で定義すればよいと思います。
例 DIM FILENAME[255] AS Byte
11月29日追加
またはFILENAMEをString型のままにして以下の様にすることもできます。
tvi.item.pszText=StrPtr(FILENAME)
Re: 複数のドラッグアンドドロップ
Posted: 2016年11月30日(水) 21:01
by TISAproject
コード: 全て選択
'-----------------------------------------------------------------------------
' イベント プロシージャ
'-----------------------------------------------------------------------------
' このファイルには、ウィンドウ [MainWnd] に関するイベントをコーディングします。
' ウィンドウ ハンドル: hMainWnd
' TODO: この位置にグローバルな変数、構造体、定数、関数を定義します。
' TODO: この位置にグローバルな変数、構造体、定数、関数を定義します。
Dim DefEditProc As Long
Dim Onthefile As string
Dim Onput As string
Dim strURL As string
Dim Option1 As long
Dim cloud1 As Long
Dim fos As SHFILEOPSTRUCT
Dim deletePath As String
Dim A1 As String
Dim Button As Long
Dim Button2 As Long
Dim lpMsgBuf As BytePtr
Dim Classter As long
Dim present As string
Dim ID As Integer
#include<api_mmsys.sbp>'PlaySound関数を使うとき必要!
open "./Plus_Actions/Operation.CPUCOMP" For Input As #1
'TreeViewで使用する追加定義。
Function TreeView_InsertItem( hWnd As Long, ByRef lpis As TVINSERTSTRUCT ) As Long
TreeView_InsertItem = SendMessage( hWnd, TVM_INSERTITEM, 0, VarPtr(lpis) )
EndFunction
'-----------------------------------------------------------------------------
' ウィンドウメッセージを処理するためのコールバック関数
Function MainWndProc(hWnd As HWND, dwMsg As DWord, wParam As WPARAM, lParam As LPARAM) As DWord
' TODO: この位置にウィンドウメッセージを処理するためのコードを記述します。
' イベントプロシージャの呼び出しを行います。
MainWndProc=EventCall_MainWnd(hWnd,dwMsg,wParam,lParam)
End Function
Declare Function SetLayeredWindowAttributes Lib "user32" (hwnd As Long,crKey As Long, bAlpha As Byte,_
dwFlags As Long) As Long
Const LWA_ALPHA=&H2
'-----------------------------------------------------------------------------
' ここから下は、イベントプロシージャを記述するための領域になります。
Sub MainWnd_Destroy()
Active120_DestroyObjects()
PostQuitMessage(0)
END
End Sub
Sub MainWnd_Create(ByRef CreateStruct As CREATESTRUCT)
SetWindowLong(hMainWnd, GWL_EXSTYLE, GetWindowLong(hMainWnd, GWL_EXSTYLE) or &H80000)
SetLayeredWindowAttributes(hMainWnd,0,1000,LWA_ALPHA)'200を変えると、透過度が変わります。
End Sub
SUB MainWnd_DropFiles(HDROP AS HANDLE)
DIM SUU AS Long
DIM IDX AS Long
DIM FILENAME AS string
Dim Clear As string
DIM PGMID As *Byte
SUU = DragQueryFile(HDROP,-1,NULL,0)
FOR IDX = 0 TO SUU - 1
DragQueryFile(HDROP,IDX,FILENAME,255)
Button=GetDlgItem(hMainWnd,TreeView1)
EnableWindow(Button,FALSE)
Button2=GetDlgItem(hMainWnd,TreeView1)
EnableWindow(Button2,FALSE)
SetWindowText(hMainWnd, "Fast-Deleter:削除処理中 (" & Onthefile )
cloud1 = DeleteFile (FILENAME)
If cloud1 <> 0 Then
SetWindowText(hMainWnd, " 削除完了しました。 FILE" )
EnableWindow(Button,TRUE)
present = "{ 削除完了しました }"
Onthefile = ""
Classter = 1
MessageBeep (MB_ICONASTERISK/* ここに型を入力*/)
Else
A1 = FILENAME
deletePath = A1 + Chr$(0)
fos.wFunc = FO_DELETE
fos.pFrom = StrPtr(deletePath)
fos.fFlags = FOF_SILENT Or FOF_NOCONFIRMATION Or FOF_NOERRORUI
If SHFileOperation(fos) = 0 And fos.fAnyOperationsAborted = FALSE Then
fos.pFrom = StrPtr(deletePath)
fos.fFlags = FOF_SILENT Or FOF_NOCONFIRMATION Or FOF_NOERRORUI
SetWindowText(hMainWnd, "削除完了しました。FOLDER" )
present = "{ 削除処理END }"
Onthefile = ""
Classter = 1
MessageBeep (MB_ICONASTERISK/* ここに型を入力*/)
Else
SetWindowText(hMainWnd, "削除処理ERROR <もう一度処理するには再ドラッグアンドドロップ>" )
present = "{ 削除できませんでした。使用されているか、存在しない、またはこのappより上の権限がかかっています }"
MessageBeep (MB_ICONHAND/* ここに型を入力*/)
End If
End If
EnableWindow(Button,TRUE)
EnableWindow(Button2,TRUE)
FlashWindow(hMainWnd,TRUE) 'TRUEはオン、FALSEはオフ
Sleep (500)
FlashWindow(hMainWnd,TRUE) 'TRUEはオン、FALSEはオフ
Dim hAny As Long
Dim tvi As TVINSERTSTRUCT
Dim hTreeItem As Long
'ツリービューのハンドルを得る
hAny = GetDlgItem( hMainWnd, TreeView1 )
'ルートの項目(アイテム)を追加する。
tvi.hParent = TVI_ROOT
tvi.hInsertAfter = TVI_SORT
tvi.item.mask = TVIF_TEXT
Clear = FILENAME & present
tvi.item.pszText=StrPtr(FILENAME)
hTreeItem = TreeView_InsertItem( hAny , tvi )
FILENAME = ""
Sleep (600)
NEXT
DragFinish(HDROP)
END SUB
これで、ファイルかフォルダーをドラッグアンドドロップし、削除させると、何回かでAppが動作を停止してしまうのですが、どうすればいいでしょう?
Re: 複数のドラッグアンドドロップ
Posted: 2016年12月10日(土) 21:46
by たかせ
>これで、ファイルかフォルダーをドラッグアンドドロップし、削除させると、何回かでAppが動作を停止してしまうのですが、どうすればいいでしょう?
「問題が発生しました・・・・」というポップアップメッセージが表示されて異常終了したのですか?
そのときの例外コードわかりますか?
私の方では動作確認出来ないので何ともいえませんがもしかしたらWin32 APIでString変数を使用しているところで異常終了の可能性があると思います。
Re: 複数のドラッグアンドドロップ
Posted: 2016年12月11日(日) 11:28
by TISAproject
では、String変数をどうすればいいでしょう?
削除まではうまくいくので、ツリービューに表示するところでエラーが発生していると考えられます。