DragEventArgs.KeyState プロパティ
アセンブリ: System.Windows.Forms (system.windows.forms.dll 内)


ドラッグ アンド ドロップ操作の効果を特定のキーの状態に依存させることができます。たとえば、ドラッグ アンド ドロップ操作中に Ctrl キーまたは Shift キーが押されたとき、データをコピーまたは移動するかどうかを決定できます。
KeyState プロパティで設定されたビットは、操作中に押されたキーまたはマウス ボタンを識別します。たとえば、マウスの左ボタンが押された場合は、KeyState プロパティの最初のビットが設定されます。ビットごとの AND 演算子を使用して任意のキー状態を調べることができます。

2 つの ListBox コントロールの間でドラッグ アンド ドロップ操作を実行する例を次に示します。この例では、ドラッグ アクションが開始したときに DoDragDrop メソッドが呼び出されます。ドラッグ操作は、MouseDown イベント実行中のマウス位置から SystemInformation.DragSize を超えてマウスが移動したときに開始されます。IndexFromPoint メソッドは、MouseDown イベントで、ドラッグする項目のインデックスを判別するために使用します。
この例では、ドラッグ アンド ドロップ操作でカスタム カーソルを使用する方法についても示します。この例では、2 つのカーソル ファイル (3dwarro.cur と 3dwno.cur) がアプリケーション ディレクトリ内に存在していることを想定しています。なお、それぞれのファイルはドラッグ用のカスタム カーソルとドロップなしのカスタム カーソルを表します。カスタム カーソルは、UseCustomCursorsCheckCheckBox がオンになっている場合に使用されます。カスタム カーソルは、GiveFeedback イベント ハンドラで設定されます。
キーボードの状態は、右側の ListBox の DragOver イベント ハンドラで評価されます。ドラッグ操作の内容は、Shift キー、Ctrl キー、Alt キー、または Ctrl + Alt キーの状態によって決まります。ドロップが発生する ListBox 内の位置は、DragOver イベント時にも判定されます。ドロップするデータが String でない場合は、DragEventArgs.Effect が DragDropEffects.None に設定されます。最後に、ドロップのステータスが DropLocationLabelLabel に表示されます。
右側の ListBox にドロップするデータは、DragDrop イベント ハンドラで判定されます。また、String 値が ListBox の該当する場所に追加されます。ドラッグ操作がフォームの範囲を超えて移動した場合、ドラッグ アンド ドロップ操作は QueryContinueDrag イベント ハンドラでキャンセルされます。
DragEventArgs クラスの使用方法を次のコード例に示します。コード例全体については、DoDragDrop メソッドのトピックを参照してください。
Private Sub ListDragTarget_DragOver(ByVal sender As Object, ByVal e As DragEventArgs) Handles ListDragTarget.DragOver ' Determine whether string data exists in the drop data. If not, then ' the drop effect reflects that the drop cannot occur. If Not (e.Data.GetDataPresent(GetType(System.String))) Then e.Effect = DragDropEffects.None DropLocationLabel.Text = "None - no string data." Return End If ' Set the effect based upon the KeyState. If ((e.KeyState And (8 + 32)) = (8 + 32) And _ (e.AllowedEffect And DragDropEffects.Link) = DragDropEffects.Link) Then ' KeyState 8 + 32 = CTL + ALT ' Link drag-and-drop effect. e.Effect = DragDropEffects.Link ElseIf ((e.KeyState And 32) = 32 And _ (e.AllowedEffect And DragDropEffects.Link) = DragDropEffects.Link) Then ' ALT KeyState for link. e.Effect = DragDropEffects.Link ElseIf ((e.KeyState And 4) = 4 And _ (e.AllowedEffect And DragDropEffects.Move) = DragDropEffects.Move) Then ' SHIFT KeyState for move. e.Effect = DragDropEffects.Move ElseIf ((e.KeyState And 8) = 8 And _ (e.AllowedEffect And DragDropEffects.Copy) = DragDropEffects.Copy) Then ' CTL KeyState for copy. e.Effect = DragDropEffects.Copy ElseIf ((e.AllowedEffect And DragDropEffects.Move) = DragDropEffects.Move) Then ' By default, the drop action should be move, if allowed. e.Effect = DragDropEffects.Move Else e.Effect = DragDropEffects.None End If ' Gets the index of the item the mouse is below. ' The mouse locations are relative to the screen, so they must be ' converted to client coordinates. indexOfItemUnderMouseToDrop = _ ListDragTarget.IndexFromPoint(ListDragTarget.PointToClient(New Point(e.X, e.Y))) ' Updates the label text. If (indexOfItemUnderMouseToDrop <> ListBox.NoMatches) Then DropLocationLabel.Text = "Drops before item #" & (indexOfItemUnderMouseToDrop + 1) Else DropLocationLabel.Text = "Drops at the end." End If End Sub
private void ListDragTarget_DragOver(object sender, System.Windows.Forms.DragEventArgs e) { // Determine whether string data exists in the drop data. If not, then // the drop effect reflects that the drop cannot occur. if (!e.Data.GetDataPresent(typeof(System.String))) { e.Effect = DragDropEffects.None; DropLocationLabel.Text = "None - no string data."; return; } // Set the effect based upon the KeyState. if ((e.KeyState & (8+32)) == (8+32) && (e.AllowedEffect & DragDropEffects.Link) == DragDropEffects.Link) { // KeyState 8 + 32 = CTL + ALT // Link drag-and-drop effect. e.Effect = DragDropEffects.Link; } else if ((e.KeyState & 32) == 32 && (e.AllowedEffect & DragDropEffects.Link) == DragDropEffects.Link) { // ALT KeyState for link. e.Effect = DragDropEffects.Link; } else if ((e.KeyState & 4) == 4 && (e.AllowedEffect & DragDropEffects.Move) == DragDropEffects.Move) { // SHIFT KeyState for move. e.Effect = DragDropEffects.Move; } else if ((e.KeyState & 8) == 8 && (e.AllowedEffect & DragDropEffects.Copy) == DragDropEffects.Copy) { // CTL KeyState for copy. e.Effect = DragDropEffects.Copy; } else if ((e.AllowedEffect & DragDropEffects.Move) == DragDropEffects.Move) { // By default, the drop action should be move, if allowed. e.Effect = DragDropEffects.Move; } else e.Effect = DragDropEffects.None; // Get the index of the item the mouse is below. // The mouse locations are relative to the screen, so they must be // converted to client coordinates. indexOfItemUnderMouseToDrop = ListDragTarget.IndexFromPoint(ListDragTarget.PointToClient(new Point(e.X, e.Y))); // Updates the label text. if (indexOfItemUnderMouseToDrop != ListBox.NoMatches){ DropLocationLabel.Text = "Drops before item #" + (indexOfItemUnderMouseToDrop + 1); } else DropLocationLabel.Text = "Drops at the end."; }
void ListDragTarget_DragOver( Object^ /*sender*/, System::Windows::Forms::DragEventArgs^ e ) { // Determine whether string data exists in the drop data. If not, then // the drop effect reflects that the drop cannot occur. if ( !e->Data->GetDataPresent( System::String::typeid ) ) { e->Effect = DragDropEffects::None; DropLocationLabel->Text = "None - no string data."; return; } // Set the effect based upon the KeyState. if ( (e->KeyState & (8 + 32)) == (8 + 32) && ((e->AllowedEffect & DragDropEffects::Link) == DragDropEffects::Link) ) { // KeyState 8 + 32 = CTL + ALT // Link drag-and-drop effect. e->Effect = DragDropEffects::Link; } else if ( (e->KeyState & 32) == 32 && ((e->AllowedEffect & DragDropEffects::Link) == DragDropEffects::Link) ) { // ALT KeyState for link. e->Effect = DragDropEffects::Link; } else if ( (e->KeyState & 4) == 4 && ((e->AllowedEffect & DragDropEffects::Move) == DragDropEffects::Move) ) { // SHIFT KeyState for move. e->Effect = DragDropEffects::Move; } else if ( (e->KeyState & 8) == 8 && ((e->AllowedEffect & DragDropEffects::Copy) == DragDropEffects::Copy) ) { // CTL KeyState for copy. e->Effect = DragDropEffects::Copy; } else if ( (e->AllowedEffect & DragDropEffects::Move) == DragDropEffects::Move ) { // By default, the drop action should be move, if allowed. e->Effect = DragDropEffects::Move; } else e->Effect = DragDropEffects::None; // Get the index of the item the mouse is below. // The mouse locations are relative to the screen, so they must be // converted to client coordinates. indexOfItemUnderMouseToDrop = ListDragTarget->IndexFromPoint( ListDragTarget->PointToClient( Point(e->X,e->Y) ) ); // Updates the label text. if ( indexOfItemUnderMouseToDrop != ListBox::NoMatches ) { DropLocationLabel->Text = String::Concat( "Drops before item # ", (indexOfItemUnderMouseToDrop + 1) ); } else DropLocationLabel->Text = "Drops at the end."; }
private void listDragTarget_DragOver(Object sender, System.Windows.Forms.DragEventArgs e) { // Determine whether string data exists in the drop data. If not, then // the drop effect reflects that the drop cannot occur. if (!(e.get_Data().GetDataPresent(String.class.ToType()))) { e.set_Effect(DragDropEffects.None); dropLocationLabel.set_Text("None - no string data."); return; } // Set the effect based upon the KeyState. if ((e.get_KeyState() & 8 + 32) == 8 + 32 && (e.get_AllowedEffect() & DragDropEffects.Link) == DragDropEffects.Link) { // KeyState 8 + 32 = CTL + ALT // Link drag-and-drop effect. e.set_Effect(DragDropEffects.Link); } else { if ((e.get_KeyState() & 32) == 32 && (e.get_AllowedEffect() & DragDropEffects.Link) == DragDropEffects.Link) { // ALT KeyState for link. e.set_Effect(DragDropEffects.Link); } else { if ((e.get_KeyState() & 4) == 4 && (e.get_AllowedEffect() & DragDropEffects.Move) == DragDropEffects.Move) { // SHIFT KeyState for move. e.set_Effect(DragDropEffects.Move); } else { if ((e.get_KeyState() & 8) == 8 && (e.get_AllowedEffect() & DragDropEffects.Copy) == DragDropEffects.Copy) { // CTL KeyState for copy. e.set_Effect(DragDropEffects.Copy); } else { if ((e.get_AllowedEffect() & DragDropEffects.Move) == DragDropEffects.Move) { // By default, the drop action should be move, //if allowed. e.set_Effect(DragDropEffects.Move); } else { e.set_Effect(DragDropEffects.None); } } // Get the index of the item the mouse is below. } } // The mouse locations are relative to the screen, so they // must be converted to client coordinates. } indexOfItemUnderMouseToDrop = listDragTarget.IndexFromPoint( listDragTarget.PointToClient(new Point(e.get_X(), e.get_Y()))); // Updates the label text. if (indexOfItemUnderMouseToDrop != ListBox.NoMatches) { dropLocationLabel.set_Text("Drops before item #" + (indexOfItemUnderMouseToDrop + 1)); } else { dropLocationLabel.set_Text("Drops at the end."); } } //listDragTarget_DragOver

Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


Weblioに収録されているすべての辞書からDragEventArgs.KeyState プロパティを検索する場合は、下記のリンクをクリックしてください。

- DragEventArgs.KeyState プロパティのページへのリンク