QueryContinueDragEventHandler QueryContinueDragEventHandler QueryContinueDragEventHandler QueryContinueDragEventHandler Delegate

定義

QueryContinueDragControl イベントを処理するメソッドを表します。Represents the method that will handle the QueryContinueDrag event of a Control.

public delegate void QueryContinueDragEventHandler(System::Object ^ sender, QueryContinueDragEventArgs ^ e);
public delegate void QueryContinueDragEventHandler(object sender, QueryContinueDragEventArgs e);
type QueryContinueDragEventHandler = delegate of obj * QueryContinueDragEventArgs -> unit
Public Delegate Sub QueryContinueDragEventHandler(sender As Object, e As QueryContinueDragEventArgs)

パラメーター

sender
Object Object Object Object

イベントのソース。The source of an event.

継承
QueryContinueDragEventHandlerQueryContinueDragEventHandlerQueryContinueDragEventHandlerQueryContinueDragEventHandler

次の例では、2 つの間でドラッグ アンド ドロップ操作ListBoxコントロール。The following example demonstrates a drag-and-drop operation between two ListBox controls. 例では、DoDragDropドラッグ操作の開始メソッド。The example calls the DoDragDrop method when the drag action starts. ドラッグ操作の開始、マウスが移動した場合は、複数のSystemInformation.DragSize中にマウスの位置から、MouseDownイベント。The drag action starts if the mouse has moved more than SystemInformation.DragSize from the mouse location during the MouseDown event. IndexFromPointメソッドを使用中にドラッグする項目のインデックスを確認して、MouseDownイベント。The IndexFromPoint method is used to determine the index of the item to drag during the MouseDown event.

例では、カスタム カーソルをドラッグ アンド ドロップ操作を使用しても示しています。The example also demonstrates using custom cursors for the drag-and-drop operation. この例ではその 2 つカーソル ファイル、3dwarro.cur3dwno.cur、カスタム ドラッグ用のアプリケーション ディレクトリ内に存在および非ドロップ カーソルの場合、それぞれします。The example assumes that two cursor files, 3dwarro.cur and 3dwno.cur, exist in the application directory, for the custom drag and no-drop cursors, respectively. 場合に使用されるカスタム カーソル、 UseCustomCursorsCheck CheckBoxがチェックされます。The custom cursors will be used if the UseCustomCursorsCheckCheckBox is checked. カスタム カーソルが設定されて、GiveFeedbackイベント ハンドラー。The custom cursors are set in the GiveFeedback event handler.

キーボードの状態が評価される、DragOver右側のイベント ハンドラー ListBox、ドラッグ操作を決定する SHIFT、CTRL、alt キーを押し、または CTRL + ALT キーの状態に基づいています。The keyboard state is evaluated in the DragOver event handler for the right ListBox, to determine what the drag operation will be based upon state of the SHIFT, CTRL, ALT, or CTRL+ALT keys. 内の場所、ListBox中にも決定されますが、ドロップが発生、DragOverイベント。The location in the ListBox where the drop would occur is also determined during the DragOver event. 削除するデータがない場合、 StringDragEventArgs.Effectに設定されているDragDropEffects.Noneします。If the data to drop is not a String, then the DragEventArgs.Effect is set to DragDropEffects.None. ドロップダウンの状態を表示する最後に、 DropLocationLabelLabelします。Finally, the status of the drop is displayed in the DropLocationLabelLabel.

右側のドロップするデータListBoxで決定されます、DragDropイベント ハンドラーとStringの適切な場所にある値を追加、ListBoxします。The data to drop for the right ListBox is determined in the DragDrop event handler and the String value is added at the appropriate place in the ListBox. ドラッグ操作が、フォームの境界の外側に移動しでドラッグ アンド ドロップ操作を取り消したかどうか、QueryContinueDragイベント ハンドラー。If the drag operation moves outside the bounds of the form, then the drag-and-drop operation is canceled in the QueryContinueDrag event handler.

このコードの抜粋では、使用方法を示します、QueryContinueDragEventHandlerを持つデリゲート、QueryContinueDragイベント。This code excerpt demonstrates using the QueryContinueDragEventHandler delegate with the QueryContinueDrag event. 参照してください、DoDragDrop完全なコード例のメソッド。See the DoDragDrop method for the complete code example.

void ListDragSource_QueryContinueDrag( Object^ sender, System::Windows::Forms::QueryContinueDragEventArgs^ e )
{
   // Cancel the drag if the mouse moves off the form.
   ListBox^ lb = dynamic_cast<ListBox^>(sender);
   if ( lb != nullptr )
   {
      Form^ f = lb->FindForm();

      // Cancel the drag if the mouse moves off the form. The screenOffset
      // takes into account any desktop bands that may be at the top or left
      // side of the screen.
      if ( ((Control::MousePosition.X - screenOffset.X) < f->DesktopBounds.Left) || ((Control::MousePosition.X - screenOffset.X) > f->DesktopBounds.Right) || ((Control::MousePosition.Y - screenOffset.Y) < f->DesktopBounds.Top) || ((Control::MousePosition.Y - screenOffset.Y) > f->DesktopBounds.Bottom) )
      {
         e->Action = DragAction::Cancel;
      }
   }
}
private void ListDragSource_QueryContinueDrag(object sender, System.Windows.Forms.QueryContinueDragEventArgs e) {
    // Cancel the drag if the mouse moves off the form.
    ListBox lb = sender as ListBox;

    if (lb != null) {

        Form f = lb.FindForm();

        // Cancel the drag if the mouse moves off the form. The screenOffset
        // takes into account any desktop bands that may be at the top or left
        // side of the screen.
        if (((Control.MousePosition.X - screenOffset.X) < f.DesktopBounds.Left) ||
            ((Control.MousePosition.X - screenOffset.X) > f.DesktopBounds.Right) ||
            ((Control.MousePosition.Y - screenOffset.Y) < f.DesktopBounds.Top) ||
            ((Control.MousePosition.Y - screenOffset.Y) > f.DesktopBounds.Bottom)) {

            e.Action = DragAction.Cancel;
        }
    }
}
Private Sub ListDragSource_QueryContinueDrag(ByVal sender As Object, ByVal e As QueryContinueDragEventArgs) Handles ListDragSource.QueryContinueDrag
    ' Cancel the drag if the mouse moves off the form.
    Dim lb as ListBox = CType(sender, System.Windows.Forms.ListBox)

    If (lb isNot nothing) Then

        Dim f as Form = lb.FindForm()

        ' Cancel the drag if the mouse moves off the form. The screenOffset
        ' takes into account any desktop bands that may be at the top or left
        ' side of the screen.
        If (((Control.MousePosition.X - screenOffset.X) < f.DesktopBounds.Left) Or _
            ((Control.MousePosition.X - screenOffset.X) > f.DesktopBounds.Right) Or _
            ((Control.MousePosition.Y - screenOffset.Y) < f.DesktopBounds.Top) Or _
            ((Control.MousePosition.Y - screenOffset.Y) > f.DesktopBounds.Bottom)) Then

            e.Action = DragAction.Cancel
        End If
    End if
End Sub

注釈

QueryContinueDragEventHandler デリゲートを作成する場合は、イベントを処理するメソッドを指定します。When you create a QueryContinueDragEventHandler delegate, you identify the method that will handle the event. イベントをイベント ハンドラーに関連付けるには、デリゲートのインスタンスをイベントに追加します。To associate the event with your event handler, add an instance of the delegate to the event. デリゲートを削除しない限り、そのイベントが発生すると常にイベント ハンドラーが呼び出されます。The event handler is called whenever the event occurs, unless you remove the delegate. デリゲートとイベントの処理についての詳細については、次を参照してください。処理とイベントの発生します。For more information about handling events with delegates, see Handling and Raising Events.

拡張メソッド

GetMethodInfo(Delegate) GetMethodInfo(Delegate) GetMethodInfo(Delegate) GetMethodInfo(Delegate)

指定したデリゲートによって表されるメソッドを表すオブジェクトを取得します。Gets an object that represents the method represented by the specified delegate.

適用対象

こちらもご覧ください