【WPF编程宝典】第10讲:简单动画

2024-06-21 00:12
文章标签 简单 编程 动画 wpf 宝典

本文主要是介绍【WPF编程宝典】第10讲:简单动画,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.基本动画

  • 这些基本动画都应用与C#代码
  • 动画是WPF模型的核心部分,让动画动起来不需要使用计时器以及事件处理代码,可使用声明的方式创建动画。
  • WPF动画第一条规则,每个动画都依赖于一个依赖项属性。
  • WPF动画第二条规则,属性的动态化需要有支持相应数据类型的动画类。比如按钮的宽度是双精度类型,需要DoubleAnimation,按钮的Padding是Thickness结构,需要ThicknessAnimation类。
  • 枚举类型通常不能应用动画,引用类型通常不能应用动画。
  • 基于路径的动画,比使用插值或关键帧的动画更加专业。通常使用类型名+AnimationUsingPath形式进行命名。如DoubleAnimationUsingPath。
  • WPF提供三种方法:线性插值,关键帧,以及路径。
  • WPF提供了42个类提供动画支持。
BooleanAnimationUsingKeyFrames,ByteAnimationUsingKeyFrames,ColorAnimation
DecimalAnimation,DoubleAnimation,DoubleAnimationUsingPath
Int16AnimationUsingKeyFrames,Int32AnimationUsingKeyFrames,Int64AnimationUsingKeyFrames
MatrixAnimationUsingPath,PointAnimation,PointAnimationUsingPath
Point3DAnimationUsingKeyFrames,ByteAnimation,CharAnimationUsingKeyFrames
ColorAnimationUsingKeyFrames,DecimalAnimationUsingKeyFrames,DoubleAnimationUsingKeyFrames
Int16Animation,Int32Animation,Int64Animation
MatrixAnimationUsingKeyFrames,ObjectAnimationUsingKeyFrames,PointAnimationUsingKeyFrames
Point3DAnimation,QuarternionAnimation,QuarternionAnimationUsingKeyFrames
RectAnimation,RectAnimationUsingKeyFrames,Rotation3DAnimation
Rotation3DAnimationUsingKeyFrames,SingleAnimation,SingleAnimationUsingKeyFrames
SizeAnimationUsingKeyFrames,ThicknessAnimation,VectorAnimation
Vector3DAnimation,SizeAnimation,StringAnimationUsingKeyFrames
ThicknessAnimationUsingKeyFrames,VectorAnimationUsingKeyFrames,Vector3DAnimationUsingKeyFrames

        一个示例

private void btn1_Click(object sender, RoutedEventArgs e)
{DoubleAnimation widthAnimation = new DoubleAnimation();widthAnimation.From = 160;widthAnimation.To = this.Width - 60;widthAnimation.Duration = TimeSpan.FromSeconds(1);btn1.BeginAnimation(Button.WidthProperty, widthAnimation);
}

2.故事板

  • 故事板(Storyboard)是BeginAnimation()方法的Xaml等价物。通过故事板将动画指定到合适的元素和属性上。
  • 事件触发:Styles.Triggers,DataTemplate.Triggers,ControlTemplate.Triggers,FrameworkElement.Triggers。
  • 重叠动画:默认HandoffBehavior属性为SnapshotAndReplace,也就是快照并替换。可使用HandoffBehavior的另一个枚举值Compose实现第二个动画融合到第一个动画的时间线中。
  • 动画同步:也就是多个动画为一组,时间线相同。只需将多个动画写到一个<Storyboard>中,并指定相同的时间。
  • 可使用SpeedRatio对动画进行调速,使用BeginTime属性对动画开始时间进行偏移。
  • 控制播放:继承自ControllableStoryboardAction类的动作类可以控制播放的状态。
    • PauseStoryBoard:停止播放动画并且保持其当前位置
    • ResumeStoryboard:恢复播放暂停的动画
    • StopStoryboard:停止播放动画,并将动画时钟重新设置到开始位置
    • SeekStoryboard:跳到动画时间线中的特定位置。如果动画当前正在播放,就继续从新位置播放。如果动画当前是暂停的,就继续保持暂停
    • SetStoryboardSpeedRatio:改变整个故事板(而不仅是改变某个内部动画)的 SpeedRatio 属性值
    • SkipStoryboardToFill:将故事板移到时间线的终点。从技术角度看,这个时期就是所谓的填充区域(6llregion)。对于标准动画,FiBchavior属性设置为HoldEnd,动画继续保持最后的值
    • RemoveStoryboard:移除故事板,停止所有正在运行的动画并将属性返回为原来的、最后一次设置的数值。这和对适当的元素使用nul动画对象调用BeginAnimation()方法的效果相同
  • button缩放简单示例
<Style x:Key="ButtonStyle"><Style.Triggers><Trigger Property="Button.IsPressed" Value="True"><Trigger.EnterActions><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="Width" To="250" Duration="0:0:5"/></Storyboard></BeginStoryboard></Trigger.EnterActions></Trigger></Style.Triggers>
</Style>
  • 检索当前动画的时间可以使用GetCurrentTime()和GetCurrentProgress。

这篇关于【WPF编程宝典】第10讲:简单动画的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1079661

相关文章

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

Kotlin Compose Button 实现长按监听并实现动画效果(完整代码)

《KotlinComposeButton实现长按监听并实现动画效果(完整代码)》想要实现长按按钮开始录音,松开发送的功能,因此为了实现这些功能就需要自己写一个Button来解决问题,下面小编给大... 目录Button 实现原理1. Surface 的作用(关键)2. InteractionSource3.

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的