В текущий момент ваш шаблон внедрен в специфический элемент управления Button
Button на уровень приложения, вырезав определение шаблона из разметки Button и вставив его в дескриптор Application.Resources внутри файла Арр.xaml. Добавьте атрибуты Key и TargetType:
HorizontalAlignment="Center"
FontWeight="Bold" FontSize="20" Content="OK!"/>
Модифицируйте разметку для Button
Click="myButton_Click"
Template="{StaticResource RoundButtonTemplate}">
Из-за того, что этот ресурс доступен всему приложению, можно определять любое количество круглых кнопок, просто применяя имеющийся шаблон. В целях тестирования создайте два дополнительных элемента управления Button
Click для них не нужно):
Click="myButton_Click"
Template="{StaticResource RoundButtonTemplate}">
Template="{StaticResource RoundButtonTemplate}">
Template="{StaticResource RoundButtonTemplate}">
Встраивание визуальных подсказок с использованием триггеров
При определении специального шаблона также удаляются все визуальные подсказки стандартного шаблона. Например, стандартный шаблон кнопки содержит разметку,которая задает внешний вид элемента управления при возникновении определенных событий пользовательского интерфейса, таких как получение фокуса, щелчок кнопкой мыши, включение (или отключение) и т.д. Пользователи довольно хорошо приучены к визуальным подсказкам подобного рода, т.к. они придают элементу управления некоторую осязаемую реакцию. Тем не менее, в шаблоне RoundButtonTemplate
Задачу можно решить с применением триггеров, как вы только что узнали. Для простых операций триггеры работают просто великолепно. Существуют дополнительные способы достижения цели, которые выходят за рамки настоящей книги, но больше информации доступно по адресу https://docs.microsoft.com/ru-ru/dotnet/desktop/wpf/controls/how-to-create-apply-template
В качестве примера обновите шаблон RoundButtonTemplate
Grid (а также его дочерних элементов) при нажатии кнопки мыши, когда курсор расположен в пределах элемента.
FontSize="20" FontWeight="Bold"
HorizontalAlignment="Center"
VerticalAlignment="Center" />
Value="Blue"/>
Property="Foreground" Value="Yellow"/>
Property="RenderTransformOrigin" Value="0.5,0.5"/>
Property="RenderTransform">
Роль расширения разметки {TemplateBinding}
Проблема с шаблоном элемента управления связана с тем, что каждая кнопка выглядит и содержит тот же самый текст. Следующее обновление разметки не оказывает никакого влияния:
Background="Red" Content="Howdy!" Click="myButton_Click"
Template="{StaticResource RoundButtonTemplate}" />
Background="LightGreen" Content="Cancel!"
Template="{StaticResource RoundButtonTemplate}" />
Background="Yellow" Content="Format"
Template="{StaticResource RoundButtonTemplate}" />
Бьёрн Страуструп , Ирина Сергеевна Козлова , Бьерн Страуструп , Валерий Федорович Альмухаметов
Программирование, программы, базы данных / Базы данных / Программирование / Учебная и научная литература / Образование и наука / Книги по IT