Затем создается объект RotateTransform
, который подключается к свойству RenderTransform
элемента управления Button
(btnSpinner
). Наконец, объект RenderTransform
информируется о начале анимации его свойства Angle
с использованием объекта DoubleAnimation
. Реализация анимации в коде обычно осуществляется путем вызова метода BeginAnimation()
и передачи ему лежащего в основе
Добавьте в программу еще одну анимацию, которая заставит кнопку после щелчка плавно становиться невидимой. Для начала создайте обработчик события Click
кнопки btnSpinner
с приведенным ниже кодом:
private void btnSpinner_OnClick(
object sender, RoutedEventArgs e)
{
var dblAnim=new DoubleAnimation
{
From=1.0,
To=0.0
};
btnSpinner.BeginAnimation(Button.OpacityProperty, dblAnim);
}
В коде обработчика события btnSpinner_Click()
изменяется свойство Opacity
, чтобы постепенно скрыть кнопку из виду. Однако в настоящий момент это затруднительно, потому что кнопка вращается слишком быстро. Как можно управлять ходом анимации? Ответ на вопрос ищите ниже.
Управление темпом анимации
По умолчанию анимация будет занимать приблизительно одну секунду для перехода между значениями, которые присвоены свойствам From
и То
. Следовательно, кнопка располагает одной секундой, чтобы повернуться на 360 градусов, и в то же время в течение одной секунды она постепенно скроется из виду (после щелчка на ней).
Определить другой период времени для перехода анимации можно посредством свойства Duration
объекта анимации, которому присваивается объект Duration
. Обычно промежуток времени устанавливается путем передачи объекта TimeSpan
конструктору класса Duration
. Взгляните на показанное далее изменение, в результате которого кнопке будет выделено четыре секунды на вращение:
private void btnSpinner_MouseEnter(
object sender, MouseEventArgs e)
{
if (!_isSpinning)
{
_isSpinning=true;
// Создать объект DoubleAnimation и зарегистрировать
// его с событием Completed.
var dblAnim=new DoubleAnimation();
dblAnim.Completed +=(o, s)=> { _isSpinning=false; };
// На завершение поворота кнопке отводится четыре секунды.
dblAnim.Duration=new Duration(TimeSpan.FromSeconds(4));
...
}
}
Благодаря такой модификации у вас должен появиться шанс щелкнуть на кнопке во время ее вращения, после чего она плавно исчезнет.
На заметку! Свойство BeginTime
класса Animation
также принимает объект TimeSpan
. Вспомните, что данное свойство можно устанавливать для указания времени ожидания перед запуском анимационной последовательности.
Запуск в обратном порядке и циклическое выполнение анимации
За счет установки в true
свойства AutoReverse
объектам Animation
указывается о необходимости запуска анимации в обратном порядке по ее завершении. Например, если необходимо, чтобы кнопка снова стала видимой после исчезновения, можно написать следующий код:
private void btnSpinner_OnClick(object sender, RoutedEventArgs e)
{
DoubleAnimation dblAnim=new DoubleAnimation
{
From=1.0,
To=0.0
};
// После завершения запустить в обратном порядке.
dblAnim.AutoReverse=true;
btnSpinner.BeginAnimation(Button.OpacityProperty, dblAnim);
}