Control.ProcessCmdKey(Message, Keys) Control.ProcessCmdKey(Message, Keys) Control.ProcessCmdKey(Message, Keys) Control.ProcessCmdKey(Message, Keys) Method

Определение

Обрабатывает клавишу для команд.Processes a command key.

protected:
 virtual bool ProcessCmdKey(System::Windows::Forms::Message % msg, System::Windows::Forms::Keys keyData);
protected virtual bool ProcessCmdKey (ref System.Windows.Forms.Message msg, System.Windows.Forms.Keys keyData);
abstract member ProcessCmdKey :  * System.Windows.Forms.Keys -> bool
override this.ProcessCmdKey :  * System.Windows.Forms.Keys -> bool
Protected Overridable Function ProcessCmdKey (ByRef msg As Message, keyData As Keys) As Boolean

Параметры

msg
Message Message Message Message

Передаваемый по ссылке объект Message, который представляет сообщение окна для обработки.A Message, passed by reference, that represents the window message to process.

keyData
Keys Keys Keys Keys

Одно из значений Keys, представляющее обрабатываемую клавишу.One of the Keys values that represents the key to process.

Возвраты

Значение true, если знак был обработан элементом управления; в противном случае — значение false.true if the character was processed by the control; otherwise, false.

Комментарии

Этот метод вызывается во время предварительной обработки сообщения для обработки клавиши для команд.This method is called during message preprocessing to handle command keys. Сочетания клавиш являются ключами, всегда имеют приоритет над обычными клавишами ввода.Command keys are keys that always take precedence over regular input keys. Сочетания клавиш примеры ускорители и меню быстрого вызова.Examples of command keys include accelerators and menu shortcuts. Метод должен возвращать true для указания, что он обработал командную клавишу, или false для указания, что ключ не клавишу для команд.The method must return true to indicate that it has processed the command key, or false to indicate that the key is not a command key. Этот метод вызывается только в том случае, если элемент управления размещен в приложении Windows Forms или как элемент управления ActiveX.This method is only called when the control is hosted in a Windows Forms application or as an ActiveX control.

ProcessCmdKey Метод сначала определяет, имеет ли элемент управления ContextMenuи если да, позволяет ContextMenu для обработки ключ команд.The ProcessCmdKey method first determines whether the control has a ContextMenu, and if so, enables the ContextMenu to process the command key. Если ключ команд не контекстное меню и элемент управления имеет родительский элемент, ключ передается родительского элемента ProcessCmdKey метод.If the command key is not a menu shortcut and the control has a parent, the key is passed to the parent's ProcessCmdKey method. В итоге получается этой команды, ключи, «всплывают» иерархии элементов управления.The net effect is that command keys are "bubbled" up the control hierarchy. В дополнение к нажатой клавише данных ключа также указывается, если таковые имеются, в нажатые клавиши-модификаторы в то же время ключ.In addition to the key the user pressed, the key data also indicates which, if any, modifier keys were pressed at the same time as the key. Клавиши-модификаторы включают клавиш SHIFT, CTRL и ALT.Modifier keys include the SHIFT, CTRL, and ALT keys.

Примечания для тех, кто наследует этот метод

При переопределении метода ProcessCmdKey(Message, Keys) метод в производном классе, элемент управления должен возвращать true для указания, что клавиша обработана.When overriding the ProcessCmdKey(Message, Keys) method in a derived class, a control should return true to indicate that it has processed the key. Для ключей, которые не обрабатываются элементом управления, результат вызова метода базового класса ProcessCmdKey(Message, Keys) метода должны быть возвращены.For keys that are not processed by the control, the result of calling the base class's ProcessCmdKey(Message, Keys) method should be returned. Элементы управления будут редко, если когда-нибудь, должны переопределить этот метод.Controls will seldom, if ever, need to override this method.

Безопасность

SecurityPermission
для непосредственного вызывающего объекта и наследования классов для вызова этого метода.for the immediate caller and inheriting classes to call this method. Связанное перечисление: UnmanagedCode.Associated enumeration: UnmanagedCode.

Применяется к