Control.DragEnter イベント
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
オブジェクトがコントロールの境界内にドラッグされると発生します。
public:
event System::Windows::Forms::DragEventHandler ^ DragEnter;
public event System.Windows.Forms.DragEventHandler DragEnter;
public event System.Windows.Forms.DragEventHandler? DragEnter;
member this.DragEnter : System.Windows.Forms.DragEventHandler
Public Custom Event DragEnter As DragEventHandler
イベントの種類
例
次のコード例は、2 つの ListBox コントロール間のドラッグ アンド ドロップ操作を示しています。 この例では、ドラッグ アクションの DoDragDrop 開始時に メソッドを呼び出します。 ドラッグ アクションは、イベント中にマウスの位置からマウスが移動 SystemInformation.DragSize した場合に MouseDown 開始されます。 メソッドは IndexFromPoint 、イベント中にドラッグする項目のインデックスを決定するために使用されます MouseDown
。
この例では、ドラッグ アンド ドロップ操作にカスタム カーソルを使用する方法も示します。 この例では、 3dwarro.cur
カスタム ドラッグ カーソルと 3dwno.cur
ドロップなしカーソルに対して、それぞれ 2 つのカーソル ファイル と がアプリケーション ディレクトリに存在する必要があります。 がオンになっている場合 UseCustomCursorsCheck
CheckBox は、カスタム カーソルが使用されます。 カスタム カーソルは、イベント ハンドラーで GiveFeedback 設定されます。
キーボードの状態は、 の右側ListBox
のDragOverイベント ハンドラーで評価され、Shift キー、Ctrl キー、Alt キー、または Ctrl + Alt キーの状態に基づいてドラッグ操作が決定されます。 ドロップが発生する ListBox
場所もイベント中に DragOver
決定されます。 削除するデータが でないString
場合は、 で DragDropEffectsが DragEventArgs.Effect にNone
設定されます。 最後に、ドロップの状態が に DropLocationLabel
Label表示されます。
右側 ListBox
にドロップするデータはイベント ハンドラーで DragDrop 決定され、 String
値は 内の適切な場所に ListBox
追加されます。 ドラッグ操作がフォームの境界外に移動した場合、ドラッグ アンド ドロップ操作はイベント ハンドラーで QueryContinueDrag 取り消されます。
このコードの抜粋は、 イベントの使用を DragEnter 示しています。 完全な DoDragDrop コード例については、 メソッドを参照してください。
void ListDragTarget_DragEnter( Object^ /*sender*/, System::Windows::Forms::DragEventArgs^ /*e*/ )
{
// Reset the label text.
DropLocationLabel->Text = "None";
}
private void ListDragTarget_DragEnter(object sender, DragEventArgs e)
{
// Reset the label text.
DropLocationLabel.Text = "None";
}
Private Sub ListDragTarget_DragEnter(ByVal sender As Object, ByVal e As DragEventArgs) Handles ListDragTarget.DragEnter
' Reset the label text.
DropLocationLabel.Text = "None"
End Sub
注釈
このイベントは DragEnter 、ユーザーがドラッグ アンド ドロップ操作中にマウス カーソルをコントロールの上に最初にドラッグしたときに発生します。
注意
.NET Framework 2.0 より前のバージョンでは、Windows フォームに with イベントと DragDrop イベントを配置UserControlし、デザイン時に 何かを にUserControlドラッグ アンド ドロップすると、 DropDrop
イベントと DropEnter
イベントが発生します。DragEnter ただし、ソリューションを閉じて再度開くと、 DragEnter イベントと DragDrop イベントは再び発生しません。
ドラッグ アンド ドロップ操作関連のイベントがどのように、いつ発生するかについて次に示します。
メソッドは DoDragDrop 、現在のカーソル位置の下のコントロールを決定します。 次に、コントロールが有効なドロップ ターゲットであるかどうかを確認します。
コントロールが有効なドロップ ターゲットの場合、 GiveFeedback ドラッグ アンド ドロップ効果を指定してイベントが発生します。 ドラッグ アンド ドロップ効果の一覧については、DragDropEffects 列挙体を参照してください。
マウス カーソルの位置、キーボードの状態、およびマウス ボタンの状態の変更が監視されます。
ユーザーがウィンドウの外に移動した場合、DragLeave イベントが生成されます。
マウスが別のコントロールに移動した場合は、そのコントロールの DragEnter が生成されます。
マウスが移動しても同じコントロール内の場合は、DragOver イベントが生成されます。
キーボードまたはマウス ボタンの状態が変更された場合、イベントが発生し、QueryContinueDragドラッグを続行するか、データをドロップするか、イベントQueryContinueDragEventArgsの の プロパティの値に基づいて操作をAction取り消すかが決定されます。
の DragAction 値が
Continue
の場合、操作を DragOver 続行するためにイベントが発生し、 GiveFeedback 適切な視覚的フィードバックを設定できるように、新しい効果でイベントが発生します。 有効なドロップ効果の一覧については、DragDropEffects 列挙体を参照してください。注意
DragOverイベントと GiveFeedback イベントはペアになっているため、マウスがドロップ ターゲットを移動すると、ユーザーにはマウスの位置に関する最新のフィードバックが表示されます。
の DragAction 値が
Drop
の場合、ドロップ効果の値がソースに返されるため、ソース アプリケーションはソース データに対して適切な操作を実行できます。たとえば、操作が移動の場合はデータを切り取ります。の値が のDragAction
Cancel
場合、イベントが発生しますDragLeave。注意
Xの プロパティと Y プロパティDragEventArgsは、クライアント座標ではなく画面座標内にあります。 次の Visual C# コード行は、プロパティをクライアント Pointに変換します。
Point clientPoint = targetControl.PointToClient(new Point(de.X, de.Y));
イベントの処理の詳細については、「処理とイベントの発生」を参照してください。