QueryContinueDragEventArgs.KeyState QueryContinueDragEventArgs.KeyState QueryContinueDragEventArgs.KeyState QueryContinueDragEventArgs.KeyState Property


Shift、Ctrl、Alt の各キーの現在の状態を取得します。Gets the current state of the SHIFT, CTRL, and ALT keys.

 property int KeyState { int get(); };
public int KeyState { get; }
member this.KeyState : int
Public ReadOnly Property KeyState As Integer


Shift、Ctrl、Alt の各キーの現在の状態。The current state of the SHIFT, CTRL, and ALT keys.

次のコード例では、このメンバーの使用を示します。The following code example demonstrates the use of this member. 例では、イベント ハンドラーが発生するときに報告、Control.QueryContinueDragイベント。In the example, an event handler reports on the occurrence of the Control.QueryContinueDrag event. このレポートでは、イベントが発生してデバッグに役立つについて説明します。This report helps you to learn when the event occurs and can assist you in debugging. 複数のイベントまたは頻繁に発生するイベントを報告する、交換を検討MessageBox.ShowConsole.WriteLineまたはメッセージを複数行に追加TextBoxします。To report on multiple events or on events that occur frequently, consider replacing MessageBox.Show with Console.WriteLine or appending the message to a multiline TextBox.

コード例を実行するから継承する型のインスタンスを含むプロジェクトに貼り付けることControlなどをButtonまたはComboBoxします。To run the example code, paste it into a project that contains an instance of a type that inherits from Control, such as a Button or ComboBox. インスタンスの名前をControl1イベント ハンドラーに関連付けられていることを確認してください、Control.QueryContinueDragイベント。Then name the instance Control1 and ensure that the event handler is associated with the Control.QueryContinueDrag event.

private void Control1_QueryContinueDrag(Object sender, QueryContinueDragEventArgs e) {

System.Text.StringBuilder messageBoxCS = new System.Text.StringBuilder();
messageBoxCS.AppendFormat("{0} = {1}", "KeyState", e.KeyState );
messageBoxCS.AppendFormat("{0} = {1}", "EscapePressed", e.EscapePressed );
messageBoxCS.AppendFormat("{0} = {1}", "Action", e.Action );
MessageBox.Show(messageBoxCS.ToString(), "QueryContinueDrag Event" );
Private Sub Control1_QueryContinueDrag(sender as Object, e as QueryContinueDragEventArgs) _ 
     Handles Control1.QueryContinueDrag

    Dim messageBoxVB as New System.Text.StringBuilder()
    messageBoxVB.AppendFormat("{0} = {1}", "KeyState", e.KeyState)
    messageBoxVB.AppendFormat("{0} = {1}", "EscapePressed", e.EscapePressed)
    messageBoxVB.AppendFormat("{0} = {1}", "Action", e.Action)
    MessageBox.Show(messageBoxVB.ToString(),"QueryContinueDrag Event")

End Sub


設定されているビット、KeyStateプロパティは、キーまたは操作中に押されたマウス ボタンを識別します。The bits that are set in the KeyState property identify the keys or mouse buttons that were pressed during the operation. たとえば、マウスの左ボタンが押された場合、最初のビット、KeyStateプロパティを設定します。For example, if the left mouse button is pressed, the first bit in the KeyState property is set. 演算子を使用することができますAND任意のキー状態をテストする演算子です。You can use the bitwise AND operator to test for a given key state.

特定のイベントに対して設定されたビットを次の表に一覧します。The following table lists the bits that are set for a specified event.

ビットBit キーKey
11 マウスの左ボタン。The left mouse button.
22 マウスの右ボタン。The right mouse button.
44 SHIFT キー。The SHIFT key.
88 CTL キーです。The CTL key.
1616 マウスの中央ボタン。The middle mouse button.
3232 ALT キー。The ALT key.

既定で、QueryContinueDragイベント セットActionDragAction.Drop場合KeyState左、中央、または右のマウス ボタンが押されたことを示します。By default, the QueryContinueDrag event sets Action to DragAction.Drop if KeyState indicates that the left, middle, or right mouse button is pressed.