KeyBinding Класс

Определение

Связывает KeyGesture с RoutedCommand (или другой реализацией ICommand).Binds a KeyGesture to a RoutedCommand (or another ICommand implementation).

public ref class KeyBinding : System::Windows::Input::InputBinding
public class KeyBinding : System.Windows.Input.InputBinding
type KeyBinding = class
    inherit InputBinding
Public Class KeyBinding
Inherits InputBinding
Наследование
Наследование

Примеры

В следующем примере создается KeyBinding и добавляется в InputBindingCollection корневого окна.The following example creates a KeyBinding and adds it to the InputBindingCollection of the root window.

<Window.InputBindings>
  <KeyBinding Command="ApplicationCommands.Open"
              Gesture="CTRL+R" />
</Window.InputBindings>
// Creating a KeyBinding between the Open command and Ctrl-R
KeyBinding OpenCmdKeyBinding = new KeyBinding(
    ApplicationCommands.Open, 
    Key.R, 
    ModifierKeys.Control);

this.InputBindings.Add(OpenCmdKeyBinding);
' Creating a KeyBinding between the Open command and Ctrl-R
Dim OpenCmdKeyBinding As New KeyBinding(ApplicationCommands.Open, Key.R, ModifierKeys.Control)

Me.InputBindings.Add(OpenCmdKeyBinding)

Комментарии

KeyBinding связывает KeyGesture с ICommand, например RoutedCommand.A KeyBinding associates a KeyGesture with a ICommand, such as a RoutedCommand. RoutedCommand является основной реализацией интерфейса ICommand для WPFWPF системы команд.RoutedCommand is the primary implementation of the ICommand interface for the WPFWPF commanding system . Как правило, при выполнении KeyGesture вызывается команда, хотя поведение команды в дальнейшем зависит от факторов, относящихся к конкретной команде, таких как CanExecute значение.In general, when the KeyGesture is executed the command is invoked, although the command behavior is further influenced by command-specific factors such as the CanExecute value. Дополнительные сведения о командах см. в разделе Общие сведения о командах.For more information on commanding, see the Commanding Overview.

За исключением функциональных клавиш и клавиш цифровой клавиатуры, допустимый KeyGesture должен содержать ровно один Key и один или несколько ModifierKeys.With the exception of the function keys and the numeric keypad keys, a valid KeyGesture must contain exactly one Key and one or more ModifierKeys. Функциональные клавиши и цифровые клавиши клавиатуры не нуждаются в ключе модификатора, чтобы быть допустимым KeyGesture.Function keys and numeric keypad keys do not require a modifier key in order to be a valid KeyGesture. Можно указать недопустимый KeyGesture и KeyBinding с недопустимым связанным жестом, используя XAMLXAML или код.It is possible to specify an invalid KeyGesture and a KeyBinding with an invalid associated gesture, either through XAMLXAML or code. Например, отсутствует проверка, которая предотвращает создание и привязку KeyGesture, содержащей только нефункциональную клавишу, или только модификаторы, но не ключ.For instance, there is no validation that prevents creating and binding a KeyGesture that contains only a nonfunction key, or only modifiers but no key. Такой KeyBinding никогда не будет пытаться вызвать связанную с ней команду.Such a KeyBinding will never attempt to invoke its associated command.

При определении KeyBinding в Язык XAMLExtensible Application Markup Language (XAML) существует два способа указания KeyGesture.When defining a KeyBinding in Язык XAMLExtensible Application Markup Language (XAML) there are two ways to specify the KeyGesture. Первым способом установки KeyBinding в XAMLXAML является определение атрибута Gesture элемента KeyBinding, который позволяет использовать синтаксис для указания ключей и модификаторов в виде одной строки, например "CTRL + P".The first way to establish a KeyBinding in XAMLXAML is to define the Gesture attribute of the KeyBinding element, which enables a syntax to specify keys and modifiers as a single string, for example "CTRL+P". Второй способ — определить атрибут Key и атрибуты Modifiers элемента KeyBinding.The second way is to define the Key attribute and the Modifiers attributes of the KeyBinding element. Оба способа настройки KeyGesture эквивалентны и изменяют один и тот же базовый объект, но при этом возникает конфликт, если оба используются.Both ways of setting the KeyGesture are equivalent and modify the same underlying object, but there will be a conflict if both are used. В случае, если заданы все атрибуты Key, Modifiersи Gesture, для KeyGestureбудет использоваться атрибут, определенный последним.In the case when the Key, Modifiers, and the Gesture attributes are all set, the attribute which is defined last will be used for the KeyGesture. Возможны ситуации, когда, например, Key Set Last будет перезаписывать только ключевой компонент предыдущего жеста, но не оставить модификаторы жеста одинаковыми.You can potentially have situations where for example a Key set last will overwrite just the Key component of a preceding Gesture but leave the Gesture's modifiers the same. Как правило, рекомендуется использовать только атрибут Gesture из XAMLXAML; Это позволит избежать неоднозначности, предоставляет самый упрощенный синтаксис и предоставляет наиболее простое представление для сериализации.In general, it is recommended that you use only the Gesture attribute from XAMLXAML; this will avoid ambiguity, provides the most streamlined syntax, and provides the most straightforward representation for serialization.

KeyBinding можно определить на определенном объекте или на уровне класса путем регистрации RegisterClassInputBinding в классе CommandManager.A KeyBinding can be defined on a specific object or at the class level by registering a RegisterClassInputBinding on the CommandManager class. Наиболее типичный способ определения KeyBinding находится в шаблоне элемента управления, устанавливая свойство InputBindings в XAMLXAML путем объявления одного или нескольких элементов MouseBinding или KeyBinding.The most typical way to define a KeyBinding is within the control template, setting the InputBindings property in XAMLXAML by declaring one or more MouseBinding or KeyBinding elements.

Конструкторы

KeyBinding()

Инициализирует новый экземпляр класса KeyBinding.Initializes a new instance of the KeyBinding class.

KeyBinding(ICommand, Key, ModifierKeys)

Инициализирует новый экземпляр класса KeyBinding, используя указанный ICommand и заданные Key и ModifierKeys, которые будут преобразованы в KeyGesture.Initializes a new instance of the KeyBinding class using the specified ICommand and the specified Key and ModifierKeys which will be converted into a KeyGesture.

KeyBinding(ICommand, KeyGesture)

Инициализирует новый экземпляр класса KeyBinding с использованием указанных объектов ICommand и KeyGesture.Initializes a new instance of the KeyBinding class using the specified ICommand and KeyGesture.

Поля

KeyProperty

Идентифицирует свойство зависимостей Key.Identifies the Key dependency property.

ModifiersProperty

Идентифицирует свойство зависимостей Modifiers.Identifies the Modifiers dependency property.

Свойства

CanFreeze

Возвращает значение, которое указывает, можно ли сделать объект неизменяемым.Gets a value that indicates whether the object can be made unmodifiable.

(Унаследовано от Freezable)
Command

Возвращает или задает объект ICommand, связанный с этой входной привязкой.Gets or sets the ICommand associated with this input binding.

(Унаследовано от InputBinding)
CommandParameter

Получает или задает специфические для команды данные для конкретной команды.Gets or sets the command-specific data for a particular command.

(Унаследовано от InputBinding)
CommandTarget

Получает или задает для команды целевой элемент.Gets or sets the target element of the command.

(Унаследовано от InputBinding)
DependencyObjectType

Возвращает DependencyObjectType, который создает обертку для типа CLRCLR данного экземпляра.Gets the DependencyObjectType that wraps the CLRCLR type of this instance.

(Унаследовано от DependencyObject)
Dispatcher

Возвращает объект Dispatcher, с которым связан этот объект DispatcherObject.Gets the Dispatcher this DispatcherObject is associated with.

(Унаследовано от DispatcherObject)
Gesture

Получает или задает жест, связанный с данным KeyBinding.Gets or sets the gesture associated with this KeyBinding.

IsFrozen

Получает значение, указывающее, доступен ли объект для изменения в настоящее время.Gets a value that indicates whether the object is currently modifiable.

(Унаследовано от Freezable)
IsSealed

Получает значение, указывающее, является ли этот экземпляр в данный момент запечатанным (доступным только для чтения).Gets a value that indicates whether this instance is currently sealed (read-only).

(Унаследовано от DependencyObject)
Key

Получает или задает Key объекта KeyGesture, связанного с данным KeyBinding.Gets or sets the Key of the KeyGesture associated with this KeyBinding.

Modifiers

Получает или задает ModifierKeys объекта KeyGesture, связанного с данным KeyBinding.Gets or sets the ModifierKeys of the KeyGesture associated with this KeyBinding.

Методы

CheckAccess()

Определяет, имеет ли вызывающий поток доступ к этому DispatcherObject.Determines whether the calling thread has access to this DispatcherObject.

(Унаследовано от DispatcherObject)
ClearValue(DependencyProperty)

Очищает локальное значение свойства.Clears the local value of a property. Очищаемое свойство задается идентификатором DependencyProperty.The property to be cleared is specified by a DependencyProperty identifier.

(Унаследовано от DependencyObject)
ClearValue(DependencyPropertyKey)

Очищает локальное значение доступного только для чтения свойства.Clears the local value of a read-only property. Очищаемое свойство задается ключом DependencyPropertyKey.The property to be cleared is specified by a DependencyPropertyKey.

(Унаследовано от DependencyObject)
Clone()

Создает изменяемый клон данного объекта Freezable, делая глубокие копии значений этого объекта.Creates a modifiable clone of the Freezable, making deep copies of the object's values. При копировании свойств зависимостей объекта этот метод копирует выражения (которые могут уже не быть разрешимыми), но не копирует анимации и их текущие значения.When copying the object's dependency properties, this method copies expressions (which might no longer resolve) but not animations or their current values.

(Унаследовано от Freezable)
CloneCore(Freezable)

Копирует базовые (не анимационные) значения свойств заданного объекта.Copies the base (non-animated) values of the properties of the specified object.

(Унаследовано от InputBinding)
CloneCurrentValue()

Создает редактируемую копию (глубокую копию) объекта Freezable с использованием его текущих значений.Creates a modifiable clone (deep copy) of the Freezable using its current values.

(Унаследовано от Freezable)
CloneCurrentValueCore(Freezable)

Копирует текущие значения свойств заданного объекта.Copies the current values of the properties of the specified object.

(Унаследовано от InputBinding)
CoerceValue(DependencyProperty)

Приводит значение указанного свойства зависимостей.Coerces the value of the specified dependency property. Это осуществляется путем вызова какой-либо функции CoerceValueCallback, указанной в метаданных свойства зависимостей, которое существует в вызывающем объекте DependencyObject.This is accomplished by invoking any CoerceValueCallback function specified in property metadata for the dependency property as it exists on the calling DependencyObject.

(Унаследовано от DependencyObject)
CreateInstance()

Инициализирует новый экземпляр класса Freezable.Initializes a new instance of the Freezable class.

(Унаследовано от Freezable)
CreateInstanceCore()

Создает экземпляр класса KeyBinding.Creates an instance of a KeyBinding.

CreateInstanceCore()

Создает экземпляр класса InputBinding.Creates an instance of an InputBinding.

(Унаследовано от InputBinding)
Equals(Object)

Определяет, является ли указанный DependencyObject эквивалентом текущего DependencyObject.Determines whether a provided DependencyObject is equivalent to the current DependencyObject.

(Унаследовано от DependencyObject)
Freeze()

Делает текущий объект неизменяемым и присваивает его свойству IsFrozen значение true.Makes the current object unmodifiable and sets its IsFrozen property to true.

(Унаследовано от Freezable)
FreezeCore(Boolean)

Делает объект Freezable нередактируемым или проверяет, можно ли его сделать нередактируемым.Makes the Freezable object unmodifiable or tests whether it can be made unmodifiable.

(Унаследовано от Freezable)
GetAsFrozen()

Создает фиксированную копию объекта Freezable, используя базовые (не анимационные) значения свойств.Creates a frozen copy of the Freezable, using base (non-animated) property values. Так как копия является фиксированной, копируются только ссылки на фиксированные вложенные объекты.Because the copy is frozen, any frozen sub-objects are copied by reference.

(Унаследовано от Freezable)
GetAsFrozenCore(Freezable)

Создает экземпляр замороженной копии заданного объекта Freezable, используя базовые (не анимационные) значения свойства.Makes the instance a frozen clone of the specified Freezable by using base (non-animated) property values.

(Унаследовано от InputBinding)
GetCurrentValueAsFrozen()

Создает фиксированную копию объекта Freezable с использованием текущих значений свойств.Creates a frozen copy of the Freezable using current property values. Так как копия является фиксированной, копируются только ссылки на фиксированные вложенные объекты.Because the copy is frozen, any frozen sub-objects are copied by reference.

(Унаследовано от Freezable)
GetCurrentValueAsFrozenCore(Freezable)

Создает текущий экземпляр замороженной копии указанного объекта Freezable.Makes the current instance a frozen clone of the specified Freezable. Если объект имеет анимированные свойства зависимостей, копируются их текущие анимированные значения.If the object has animated dependency properties, their current animated values are copied.

(Унаследовано от InputBinding)
GetHashCode()

Возвращает хэш-код для данного объекта DependencyObject.Gets a hash code for this DependencyObject.

(Унаследовано от DependencyObject)
GetLocalValueEnumerator()

Создает специализированный перечислитель для определения свойств зависимостей, которые локально установили значения для данного DependencyObject.Creates a specialized enumerator for determining which dependency properties have locally set values on this DependencyObject.

(Унаследовано от DependencyObject)
GetType()

Возвращает объект Type для текущего экземпляра.Gets the Type of the current instance.

(Унаследовано от Object)
GetValue(DependencyProperty)

Возвращает текущее действующее значение свойства зависимостей в этом экземпляре DependencyObject.Returns the current effective value of a dependency property on this instance of a DependencyObject.

(Унаследовано от DependencyObject)
InvalidateProperty(DependencyProperty)

Повторно вычисляет действующее значение для указанного свойства зависимостей.Re-evaluates the effective value for the specified dependency property.

(Унаследовано от DependencyObject)
MemberwiseClone()

Создает неполную копию текущего объекта Object.Creates a shallow copy of the current Object.

(Унаследовано от Object)
OnChanged()

Вызывается при изменении текущего объекта Freezable.Called when the current Freezable object is modified.

(Унаследовано от Freezable)
OnFreezablePropertyChanged(DependencyObject, DependencyObject)

Обеспечивает создание соответствующих указателей контекста для элемента данных типа DependencyObjectType, который был только что задан.Ensures that appropriate context pointers are established for a DependencyObjectType data member that has just been set.

(Унаследовано от Freezable)
OnFreezablePropertyChanged(DependencyObject, DependencyObject, DependencyProperty)

Этот член поддерживает инфраструктуру Windows Presentation Foundation (WPF)Windows Presentation Foundation (WPF) и не предназначен для непосредственного использования из кода.This member supports the Windows Presentation Foundation (WPF)Windows Presentation Foundation (WPF) infrastructure and is not intended to be used directly from your code.

(Унаследовано от Freezable)
OnPropertyChanged(DependencyPropertyChangedEventArgs)

Переопределяет реализацию DependencyObject для OnPropertyChanged(DependencyPropertyChangedEventArgs), чтобы также вызвать любой обработчик Changed в ответ на изменение свойства зависимостей типа Freezable.Overrides the DependencyObject implementation of OnPropertyChanged(DependencyPropertyChangedEventArgs) to also invoke any Changed handlers in response to a changing dependency property of type Freezable.

(Унаследовано от Freezable)
OnPropertyChanged(DependencyPropertyChangedEventArgs)

Вызывается каждый раз, когда обновляется действительное значение любого свойства зависимостей для данного DependencyObject.Invoked whenever the effective value of any dependency property on this DependencyObject has been updated. Конкретное измененное свойство зависимостей сообщается в данных события.The specific dependency property that changed is reported in the event data.

(Унаследовано от DependencyObject)
ReadLocalValue(DependencyProperty)

Возвращает локальное значение свойства зависимостей, если оно существует.Returns the local value of a dependency property, if it exists.

(Унаследовано от DependencyObject)
ReadPreamble()

Обеспечивает доступ к Freezable из допустимого потока.Ensures that the Freezable is being accessed from a valid thread. Наследники объекта Freezable должны вызывать данный метод в начале любого API, который считывает элементы данных, не являющиеся свойствами зависимостей.Inheritors of Freezable must call this method at the beginning of any API that reads data members that are not dependency properties.

(Унаследовано от Freezable)
SetCurrentValue(DependencyProperty, Object)

Задает значение свойства зависимостей, не изменяя источник значения.Sets the value of a dependency property without changing its value source.

(Унаследовано от DependencyObject)
SetValue(DependencyProperty, Object)

Задает локальное значение свойства зависимостей, определяемое идентификатором свойства зависимостей.Sets the local value of a dependency property, specified by its dependency property identifier.

(Унаследовано от DependencyObject)
SetValue(DependencyPropertyKey, Object)

Задает локальное значение свойства зависимости только для чтения, определяемое идентификатором DependencyPropertyKey свойства зависимостей.Sets the local value of a read-only dependency property, specified by the DependencyPropertyKey identifier of the dependency property.

(Унаследовано от DependencyObject)
ShouldSerializeProperty(DependencyProperty)

Возвращает значение, указывающее, должны ли процессы сериализации сериализовать значение предоставленного свойства зависимостей.Returns a value that indicates whether serialization processes should serialize the value for the provided dependency property.

(Унаследовано от DependencyObject)
ToString()

Возвращает строку, представляющую текущий объект.Returns a string that represents the current object.

(Унаследовано от Object)
VerifyAccess()

Обеспечивает наличие у вызывающего потока доступ к этому DispatcherObject.Enforces that the calling thread has access to this DispatcherObject.

(Унаследовано от DispatcherObject)
WritePostscript()

Вызывает событие Changed для объекта Freezable и вызывает его метод OnChanged().Raises the Changed event for the Freezable and invokes its OnChanged() method. Классы, производные от Freezable, должны вызывать этот метод в конце любого API, который изменяет члены класса, не сохраненные в виде свойств зависимостей.Classes that derive from Freezable should call this method at the end of any API that modifies class members that are not stored as dependency properties.

(Унаследовано от Freezable)
WritePreamble()

Проверяет, что объект Freezable не заморожен и доступ к нему осуществляется из допустимого контекста потока.Verifies that the Freezable is not frozen and that it is being accessed from a valid threading context. Наследники объекта Freezable должны вызывать данный метод в начале любого API, который выполняет запись в элементах данных, не являющихся свойствами зависимостей.Freezable inheritors should call this method at the beginning of any API that writes to data members that are not dependency properties.

(Унаследовано от Freezable)

События

Changed

Происходит, когда изменяется класс Freezable или объект, который входит в его состав.Occurs when the Freezable or an object it contains is modified.

(Унаследовано от Freezable)

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

Дополнительно