Работа похожа на ту, что делалась в реализации свойства
Height
: тем не менее, предыдущий фрагмент кода регистрирует свойство непосредственно в теле, а не в статическом конструкторе (что хорошо). Также обратите внимание, что объект
UIPropertyMetadata
используется для определения стандартного целочисленного значения (
0
) вместо более сложного объекта
FrameworkPropertyMetadata
.
В итоге получается простейшая версия
CurrentNumber
как свойства зависимости.
Добавление процедуры проверки достоверности данных
Хотя у вас есть свойство зависимости по имени
CurrentNumber
(и исключение больше не генерируется), анимация пока еще не наблюдается. Следующей корректировкой будет указание функции, вызываемой для выполнения проверки достоверности данных. В данном примере предполагается, что нужно обеспечить нахождение значения свойства
CurrentNumber
в диапазоне между 0 и 500.
Добавьте в метод
DependencyProperty.Register
последний аргумент типа
ValidateValueCallback
, указывающий на метод по имени
ValidateCurrentNumber
.
Здесь
ValidateValueCallback
является делегатом, который может указывать только на методы, возвращающие тип
bool
и принимающие единственный аргумент типа
object
. Экземпляр
object
представляет присваиваемое новое значение. Реализация
ValidateCurrentNumber
должна возвращать
true
, если входное значение находится в ожидаемом диапазоне, и
false
в противном случае:
public static readonly DependencyProperty CurrentNumberProperty =
DependencyProperty.Register("CurrentNumber",
typeof(int),
typeof(ShowNumberControl),
new UIPropertyMetadata(100),
new ValidateValueCallback(ValidateCurrentNumber));
// Простое бизнес-правило: значение должно находиться
// в диапазоне между 0 и 500.
public static bool ValidateCurrentNumber(object value) =>
Итак, допустимое число уже есть, но анимация по-прежнему отсутствует. Последнее изменение, которое потребуется внести — передать во втором аргументе конструктора
UIPropertyMrtadata
объект
PropertyChangedCallback
. Данный делегат может указывать на любой метод, принимающий
DependencyObject
в первом параметре и
DependencyPropertyChangeEventArgs
во втором. Модифицируйте код следующим образом:
// Обратите внимание на второй параметр конструктора UIPropertyMetadata.
public static readonly DependencyProperty CurrentNumberProperty =
// Получить элемент управления Label в ShowNumberControl.
Label theLabel = c.numberDisplay;
// Установить для Label новое значение.
theLabel.Content = args.NewValue.ToString;
}
Видите, насколько долгий путь пришлось пройти, чтобы всего лишь изменить содержимое метки! Преимущество заключается в том, что теперь свойство зависимости
CurrentNumber
может быть целью для стиля WPF, объекта анимации, операции привязки данных и т.д. Снова запустив приложение, вы легко заметите, что значение изменяется во время выполнения.
На этом обзор свойств зависимости WPF завершен. Хотя теперь вы должны гораздо лучше понимать, что они позволяют делать, и как создавать собственные свойства подобного рода, имейте в виду, что многие детали здесь не были раскрыты.
Если вам однажды понадобится создавать множество собственных элементов управления, поддерживающих специальные свойства, тогда загляните в подраздел "Properties" ("Свойства") раздела "Systems" ("Системы") документации по WPF
).Там вы найдете намного больше примеров построения свойств зависимости, присоединяемых свойств, разнообразных способов конфигурирования метаданных и массу других подробных сведений.