チュートリアル : Windows フォームにおけるドラッグ アンド ドロップ操作の実行

更新 : 2007 年 11 月

Windows ベースのアプリケーション内でドラッグ アンド ドロップ操作を実行するには、DragEnterDragLeaveDragDrop などの一連のイベントを処理する必要があります。これらのイベントのイベント引数で提供される情報を使用することにより、ドラッグ アンド ドロップ操作を簡単に実現できます。

データのドラッグ

すべてのドラッグ アンド ドロップ操作は、ドラッグから始まります。ドラッグが開始されたときにデータを収集できるようにする機能は、DoDragDrop メソッドに実装されています。

次の例では、最も直観的な MouseDown イベントを使用してドラッグ操作を開始しています。これは、ほとんどのドラッグ アンド ドロップ操作は、マウス ボタンが押されることによって開始されるためです。ただし、ドラッグ アンド ドロップの手順は任意のイベントを使用して開始できます。

za0zx9y0.alert_note(ja-jp,VS.90).gifメモ :

ドラッグに関するカスタム イベントのあるコントロールもあります。たとえば、ListView コントロールと TreeView コントロールには、ItemDrag イベントがあります。

ドラッグ操作を開始するには

  • ドラッグが開始されるコントロールの MouseDown イベントで、DoDragDrop メソッドを使用して、ドラッグされるデータおよびドラッグによって実行できる処理を設定します。詳細については、「Data」および「AllowedEffect」を参照してください。

    ドラッグ操作を開始する方法の例を次に示します。ドラッグが開始されるコントロールは Button コントロール、ドラッグされるデータは、Button コントロールの Text プロパティを表す文字列、実行できる処理はコピーまたは移動のいずれかです。

    Private Sub Button1_MouseDown(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles Button1.MouseDown
       Button1.DoDragDrop(Button1.Text, DragDropEffects.Copy Or DragDropEffects.Move)
    End Sub
    
    private void button1_MouseDown(object sender, 
    System.Windows.Forms.MouseEventArgs e)
    {
       button1.DoDragDrop(button1.Text, DragDropEffects.Copy | 
          DragDropEffects.Move);
    }
    
    private void button1_MouseDown(Object sender,
    System.Windows.Forms.MouseEventArgs e)
    {
       button1.DoDragDrop(button1.get_Text(), DragDropEffects.Copy |
          DragDropEffects.Move);
    }
    
    za0zx9y0.alert_note(ja-jp,VS.90).gifメモ :

    DoDragDrop メソッドでは、任意のデータをパラメータとして使用できます。上の例では、Button コントロールの Text プロパティがドラッグの開始位置 (Button コントロール) に関連するため、値をハードコーディングしたり、データセットからデータを取得したりせずに、このプロパティを使用しています。Windows ベースのアプリケーションにドラッグ アンド ドロップ操作を組み込む場合には、この点を考慮してください。

ドラッグ操作が行われている間、QueryContinueDrag イベントを処理できます。これは、ドラッグ操作を続けてよいかどうかシステムの "許可を得る" イベントです。このメソッドを処理するときは、たとえば、カーソルが置かれたときに TreeView コントロールの TreeNode を展開するなど、ドラッグ操作に影響するメソッドを呼び出すのにも適しています。

データのドロップ

Windows フォームまたはコントロール上の場所からデータのドラッグを開始したら、それをどこかにドロップする必要があります。データをドロップできるように正しく設定されているフォームまたはコントロールの領域をカーソルが横切ると、カーソルの形が変わります。AllowDrop プロパティを設定し、DragEnter イベントと DragDrop イベントを処理することにより、Windows フォームまたはコントロール内の任意の領域で、ドロップされたデータを受け入れることができます。

ドロップを実行するには

  1. AllowDrop プロパティを true に設定します。

  2. ドロップ先のコントロールの DragEnter イベントで、ドラッグされるデータが適切な型 (この場合、Text) であることを確認します。次に、コードでは、ドロップしたときの効果を DragDropEffects 列挙定数の値に設定します。詳細については、「Effect」を参照してください。

    Private Sub TextBox1_DragEnter(ByVal sender As Object, ByVal e As System.Windows.Forms.DragEventArgs) Handles TextBox1.DragEnter
       If (e.Data.GetDataPresent(DataFormats.Text)) Then
         e.Effect = DragDropEffects.Copy
       Else
         e.Effect = DragDropEffects.None
       End If
    End Sub
    
    private void textBox1_DragEnter(object sender, 
    System.Windows.Forms.DragEventArgs e)
    {
       if (e.Data.GetDataPresent(DataFormats.Text)) 
          e.Effect = DragDropEffects.Copy;
       else
          e.Effect = DragDropEffects.None;
    }
    
    private void textBox1_DragEnter(Object sender,
    System.Windows.Forms.DragEventArgs e)
    {
       if (e.get_Data().GetDataPresent(DataFormats.Text))
          e.set_Effect(DragDropEffects.Copy);
       else
          e.set_Effect(DragDropEffects.None);
    }
    
    za0zx9y0.alert_note(ja-jp,VS.90).gifメモ :

    SetData メソッドの Object パラメータとして独自のオブジェクトを指定することで、固有の DataFormats を定義できます。その場合は、指定するオブジェクトがシリアル化できるオブジェクトであることを確認してください。詳細については、「ISerializable インターフェイス」を参照してください。

  3. ドロップ先のコントロールの DragDrop イベントで、GetData メソッドを使用して、ドラッグされるデータを取得します。詳細については、「DtaObject.Data プロパティ」を参照してください。

    次の例では、データがドロップされるドラッグ先のコントロールは TextBox コントロールです。コードでは、TextBox コントロールの Text プロパティをドラッグされたデータと同じ内容に設定します。

    Private Sub TextBox1_DragDrop(ByVal sender As Object, ByVal e As System.Windows.Forms.DragEventArgs) Handles TextBox1.DragDrop
       TextBox1.Text = e.Data.GetData(DataFormats.Text).ToString
    End Sub
    
    private void textBox1_DragDrop(object sender, 
    System.Windows.Forms.DragEventArgs e)
    {
       textBox1.Text = e.Data.GetData(DataFormats.Text).ToString();
    }
    
    private void textBox1_DragDrop(Object sender,
    System.Windows.Forms.DragEventArgs e)
    {
       textBox1.set_Text
    (e.get_Data().GetData(DataFormats.Text).ToString());
    }
    
    za0zx9y0.alert_note(ja-jp,VS.90).gifメモ :

    さらに、KeyState プロパティを使用して、ドラッグ アンド ドロップ操作中に押されたキーに応じて特定の効果が得られるようにできます。たとえば一般的に、Ctrl キーを押しながらドラッグしたデータはコピーされます。

参照

処理手順

方法 : クリップボードにデータを追加する

方法 : クリップボードからデータを取得する

その他の技術情報

ドラッグ アンド ドロップ操作とクリップボードのサポート