この記事は翻訳者によって翻訳されたものです。 記事の文章にポインターを重ねると、原文のテキストが表示されます。 |
訳文
原文
|
Control.GiveFeedback イベント
ドラッグ操作中に発生します。
アセンブリ: System.Windows.Forms (System.Windows.Forms.dll 内)
ドラッグ アンド ドロップ操作が開始されたときに、GiveFeedback イベントが発生します。 GiveFeedback イベントによって、ドラッグ イベントのソースがマウス ポインターの外観を変更して、ドラッグ アンド ドロップ操作中にユーザーに視覚的フィードバックを与えることができます。
ドラッグ アンド ドロップ操作関連のイベントがどのように、いつ発生するかについて次に示します。
DoDragDrop メソッドは、現在のカーソル位置に従ってコントロールを判別します。 次に、コントロールが有効なドロップ ターゲットかどうかを確認します。
コントロールが有効なドロップ ターゲットの場合、指定したドラッグ アンド ドロップの効果が付いた状態で GiveFeedback イベントが発生します。 ドラッグ アンド ドロップ効果の一覧については、DragDropEffects 列挙体を参照してください。
マウス カーソルの位置、キーボードの状態、およびマウス ボタンの状態の変更が監視されます。
-
ユーザーがウィンドウの外に移動した場合、DragLeave イベントが生成されます。
-
マウスが別のコントロールに移動した場合は、そのコントロールの DragEnter が生成されます。
-
マウスが移動しても同じコントロール内の場合は、DragOver イベントが生成されます。
キーボードまたはマウス ボタンの状態に変更があった場合、QueryContinueDrag イベントが生成され、このイベントの QueryContinueDragEventArgs の Action プロパティの値に応じて、ドラッグを継続するか、データをドロップするか、操作をキャンセルするかが判断されます。
-
DragAction の値が Continue の場合、操作を継続するための DragOver イベントが生成され、適切な視覚的フィードバックを設定できるように新しい効果による GiveFeedback イベントが生成されます。 有効なドロップ効果の一覧については、DragDropEffects 列挙体を参照してください。
メモ
DragOver イベントおよび GiveFeedback イベントはペアになっています。したがって、マウスがドロップ ターゲットをまたがって移動した場合、マウスの位置に関する最新のフィードバックがユーザーに提示されます。
-
DragAction の値が Drop の場合、ドロップ効果の値がソースに返されます。ソース アプリケーションでは、ソース データに対して適切な操作を実行できます。たとえば、移動操作だった場合は、データの切り取りなどを実行できます。
-
DragAction の値が Cancel の場合、DragLeave イベントが生成されます。
イベント処理の詳細については、「イベントの利用」を参照してください。
2 つの ListBox コントロールの間でドラッグ アンド ドロップ操作を実行するコード例を次に示します。 この例では、ドラッグ アクションが開始したときに DoDragDrop メソッドが呼び出されます。 ドラッグ操作は、MouseDown イベント実行中のマウス位置から SystemInformation.DragSize を超えてマウスが移動したときに開始されます。 IndexFromPoint メソッドは、MouseDown イベントで、ドラッグする項目のインデックスを判別するために使用します。
この例では、ドラッグ アンド ドロップ操作でカスタム カーソルを使用する方法についても示します。 この例では、2 つのカーソル ファイル (3dwarro.cur と 3dwno.cur) がアプリケーション ディレクトリ内に存在している必要があります。なお、それぞれのファイルはドラッグ用のカスタム カーソルとドロップなしのカスタム カーソルを表します。 カスタム カーソルは、UseCustomCursorsCheck の CheckBox がオンになっている場合に使用されます。 カスタム カーソルは、GiveFeedback イベント ハンドラーで設定されます。
キーボードの状態は、右側の ListBox の DragOver イベント ハンドラーで評価されます。ドラッグ操作の内容は、Shift キー、Ctrl キー、Alt キー、または Ctrl + Alt キーの状態によって決まります。 ドロップが発生する ListBox 内の位置は、DragOver イベント時にも判定されます。 ドロップするデータが String でない場合は、DragEventArgs.Effect が DragDropEffects で None に設定されます。 最後に、ドロップのステータスが DropLocationLabel の Label に表示されます。
右側の ListBox にドロップするデータは、DragDrop イベント ハンドラーで判定されます。また、String 値が ListBox の該当する場所に追加されます。 ドラッグ操作がフォームの範囲を超えて移動した場合、ドラッグ アンド ドロップ操作は QueryContinueDrag イベント ハンドラーでキャンセルされます。
GiveFeedback イベントの使用方法を次のコード例に示します。 コード例全体については、DoDragDrop メソッドのトピックを参照してください。
private void ListDragSource_GiveFeedback(object sender, System.Windows.Forms.GiveFeedbackEventArgs e) { // Use custom cursors if the check box is checked. if (UseCustomCursorsCheck.Checked) { // Sets the custom cursor based upon the effect. e.UseDefaultCursors = false; if ((e.Effect & DragDropEffects.Move) == DragDropEffects.Move) Cursor.Current = MyNormalCursor; else Cursor.Current = MyNoDropCursor; } }
Windows 7, Windows Vista SP1 以降, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008 (Server Core はサポート対象外), Windows Server 2008 R2 (SP1 以降で Server Core をサポート), Windows Server 2003 SP2
.NET Framework では、各プラットフォームのすべてのバージョンはサポートしていません。 サポートされているバージョンについては、「.NET Framework システム要件」を参照してください。