1 /**************************************************************************
\r
5 (C) Copyright 1996-2002 By Tomoaki Nakashima. All right reserved.
\r
6 http://www.nakka.com/
\r
9 **************************************************************************/
\r
11 #ifndef _INC_OLEDRAGDROP
\r
12 #define _INC_OLEDRAGDROP
\r
14 #define IDROPTARGET_NOTIFY_DRAGENTER 0
\r
15 #define IDROPTARGET_NOTIFY_DRAGOVER 1
\r
16 #define IDROPTARGET_NOTIFY_DRAGLEAVE 2
\r
17 #define IDROPTARGET_NOTIFY_DROP 3
\r
19 typedef struct _IDROPTARGET_NOTIFY{
\r
20 POINTL *ppt; //マウスの位置
\r
21 DWORD dwEffect; //ドラッグ操作で、ドラッグされる対象で許される効果
\r
22 DWORD grfKeyState; //キーの状態
\r
23 UINT cfFormat; //ドロップされるデータのクリップボードフォーマット
\r
24 HANDLE hMem; //ドロップされるデータ
\r
25 LPVOID pdo; //IDataObject
\r
26 }IDROPTARGET_NOTIFY , *LPIDROPTARGET_NOTIFY;
\r
32 BOOL APIPRIVATE OLE_IDropTarget_RegisterDragDrop(HWND hWnd, UINT uCallbackMessage, UINT *cFormat, int cfcnt);
\r
34 //ドラッグ&ドロップのターゲットとして登録します。
\r
37 // ドラッグ&ドロップ操作が行われたときに指定のウィンドウの指定のメッセージに通知されます。
\r
38 // wParam に操作の種類(IDROPTARGET_NOTIFY_)が設定されています。
\r
39 // lParam に IDROPTARGET_NOTIFY 構造体へのポインタが設定されています。
\r
41 // cFormat は 受け取ることが可能なクリップボードフォーマットのリストを指定します。
\r
42 // cfcnt はクリップボードフォーマットの配列の要素数を指定します。
\r
44 void APIPRIVATE OLE_IDropTarget_RevokeDragDrop(HWND hWnd);
\r
46 //ドラッグ&ドロップのターゲットを解除します。
\r
52 int APIPRIVATE OLE_IDropSource_Start(HWND hWnd, UINT uCallbackMessage, UINT uCallbackDragOverMessage, UINT *ClipFormtList, int cfcnt, int Effect);
\r
54 //ドラッグ&ドロップを開始するときに指定します。
\r
55 //ドラッグ&ドロップ操作は自動的に行われますが、データが必要な時は、指定のウィンドウメッセージでデータ要求を行います。
\r
58 // hWnd に uCallbackMessage を送ってデータの要求を行います。
\r
59 // この時 wParam に要求するクリップボードフォーマットの値が入っています。
\r
60 // プログラムは *(HANDLE *)lParam にデータを設定して返します。(NULLでも可)
\r
62 // ClipFormtList はサポートしているクリップボードフォーマットの配列を指定します。
\r
63 // cfcnt はクリップボードフォーマットの配列の要素数を指定します。
\r
65 // Effect は ドラッグ操作でドラッグされる対象で許される効果の組み合わせを指定します。
\r
68 //ドロップが行われた場合は、ドロップ先のアプリケーションが設定した効果を返します。
\r
69 //キャンセルやエラーの場合は -1 を返します。
\r