wpf滑动动画_旋转平移矩阵

wpf滑动动画_旋转平移矩阵在WPF动画中常见的动画就平移、缩放以及旋转,一般会用到故事板(Storyboard)和浮点动画(DoubleAnimation),下面我们先对这两个进行具体的介绍,因为本次我们主要利用故事板来添加动画:一.Storyboard:俗称故事板,在VS中意思是,一个容器的时间线,该时间线为子动画提供对象和属性确定信息:其重要的两个方法`Storyboard.SetTarget();`绑定动画和`Storyboard.SetTargetProperty();`依赖的属性一般用法有:Storyboard

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

在WPF动画中常见的动画就平移、缩放以及旋转,一般会用到故事板(Storyboard)和浮点动画( DoubleAnimation),下面我们先对这两个进行具体的介绍,因为本次我们主要利用故事板来添加动画:

一.Storyboard:俗称故事板,在VS中意思是,一个容器的时间线,该时间线为子动画提供对象和属性确定信息:

其重要的两个方法`Storyboard.SetTarget();`绑定动画和`Storyboard.SetTargetProperty();`依赖的属性

一般用法有:

Storyboard sb = new Storyboard();//首先实例化一个故事板
Storyboard.SetTarget();//绑定动画为这个按钮执行的浮点动画
Storyboard.SetTargetProperty();//依赖的属性
sb.Begin();//开始动画
sb.Children.Add(***);//向故事板中添加动画
sb.Children.Remove(***);//移除指定的动画

Jetbrains全家桶1年46,售后保障稳定

当然在下面的逐步介绍中,我们还会用到故事板绑定动画,和依赖的属性

二.DoubleAnimation:浮点动画,在VS中的意思是,对插入的两个目标值之间的double属性值进行动画处理:

一般常用的属性运用:

1.先进行实例化;

2.设置动画的起始值和结束值;

3.设置动画是否进行循环播放;

4.设置播放时间;

5.设置是否可以进行反转;

下面是举例代码逐步实现:

DoubleAnimation doubleanimation = new DoubleAnimation();//先进行实例化
doubleanimation.Form=100;//设置起始值
doubleanimation.To=200;//设置结束值
doubleanimation.RepeatBehavior = RepeatBehavior.Forever;//设置动画循环播放
doubleanimation.AutoReverse = true;//设置可以进行反转
doubleanimation.Duration=new Duration(TimeSpan.FromSeconds(3));//设置动画播放时间

一.平移:

TranslateTransform:在二维x-y坐标系统内平移(移动)对象:

在故事板中依赖的属性为RenderTransform.X;就是沿X轴进行平移;
用法:

Button btn2 = new Button();
DoubleAnimation yd5 = new DoubleAnimation(100, 200, new Duration(TimeSpan.FromSeconds(3)));//浮点动画定义了开始值和起始值
            btn2.RenderTransform = new TranslateTransform();//在二维x-y坐标系统内平移(移动)对象
            yd5.RepeatBehavior = RepeatBehavior.Forever;//设置循环播放
            yd5.AutoReverse = true;//设置可以进行反转
            Storyboard.SetTarget(yd5, btn2);//绑定动画为这个按钮执行的浮点动画
            Storyboard.SetTargetProperty(yd5, new PropertyPath("RenderTransform.X"));//依赖的属性
            sb.Children.Add(yd5);//向故事板中加入此浮点动画
            sb.Begin();//播放此动画

二.旋转:

RotateTransform:在二维x-y坐标系统内围绕指定点顺时针旋转某个对象:

在故事板中依赖属性为:RenderTransform.Angle就是要进行旋转的角度;
用法:

Button btn3 = new Button();
            DoubleAnimation yd1 = new DoubleAnimation();//实例化浮点动画
            btn3.RenderTransform = new RotateTransform();//设置为旋转动画
            btn3.RenderTransformOrigin = new Point(0.5, 0.5);//设置旋转的中心
            yd1.From = 0;//动画的起始值
            yd1.To = 3600;//动画的结束值
            yd1.Duration = TimeSpan.FromSeconds(3);//动画的播放时间
            yd1.RepeatBehavior = RepeatBehavior.Forever;//设置动画循环播放
            yd1.AutoReverse = true;//设置动画可以进行反转
            Storyboard.SetTarget(yd1, btn3);//给故事板绑定动画
            Storyboard.SetTargetProperty(yd1, new PropertyPath("RenderTransform.Angle"));//动画的依赖属性
            sb.Children.Add(yd1);//故事板添加动画
             sb.Begin();//播放动画

三.缩放:

ScaleTransform:在二维x-y坐标系统内缩放对象;

在故事板中依赖的属性为RenderTransform.ScaleXRenderTransform.ScaleY,这要根据你要沿哪个轴进行缩放,X代表x轴,Y代表y轴;
用法:

Button btn1 = new Button();
 DoubleAnimation yd4 = new DoubleAnimation(1.0,0.5,new Duration(TimeSpan.FromSeconds(3)));//实例化浮点动画,分别包含了缩放的倍数和动画的时间
            btn1.RenderTransform = new ScaleTransform();//设置动画为缩放
            yd4.RepeatBehavior = RepeatBehavior.Forever;//设置循环播放
            yd4.AutoReverse = true;//设置可以反转
            btn1.RenderTransformOrigin = new Point(0.5,0.5);//设置缩放为中心点
            Storyboard.SetTarget(yd4,btn1);//绑定动画
            Storyboard.SetTargetProperty(yd4,new PropertyPath("RenderTransform.ScaleX"));//动画依赖的属性
            sb.Children.Add(yd4);//添加动画
            sb.Begin();//播放动画

四.颜色动画:

ColorAnimation:对插入的两个目标值之间的color属性值进行动画处理:
一般依赖的属性为:(控件名称.Background).(SolidColorBrush.Color)也就是设置了其背景色
用法:

Button btn4 = new Button();
ColorAnimation color = new ColorAnimation(Colors.Red,Colors.Blue,new Duration(TimeSpan.FromSeconds(0.05)));//实例化颜色动画
            color.RepeatBehavior = RepeatBehavior.Forever;//设置循环播放
            color.AutoReverse = true;//设置可以反转
            Storyboard.SetTarget(color, btn4);//绑定动画
            Storyboard.SetTargetProperty(color, new PropertyPath("(Button.Background).(SolidColorBrush.Color)"));//设置动画依赖的属性
            sb.Children.Add(color);//增加动画
            sb.Begin();//播放动画

另一篇文章对这几种动画也有具体的介绍,如果喜欢请进传送门

WPF中实现动画的几种效果(最基础方式)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/198332.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 易百教程wxpython_WxPython教程

    易百教程wxpython_WxPython教程wxPython是一个Python包装wxWidgets(这是用C++编写),一个流行的跨平台GUI工具包。由RobinDunn以及HarriPasanen开发,wxPython是作为一个Python扩展模块。就像wxWidgets,wxPython也是一个免费的软件。它可以从官方网站下载:http://wxpython.org.在本网站上可下载wxPython对应操作系统平台二进…

    2022年5月22日
    37
  • Mac PHPStorm清除SVN配置缓存

    Mac PHPStorm清除SVN配置缓存

    2021年10月21日
    37
  • python中for循环加速_如何提高python 中for循环的效率[通俗易懂]

    python中for循环加速_如何提高python 中for循环的效率[通俗易懂]对于某个城市的出租车数据,一天就有33210000条记录,如何将每辆车的数据单独拎出来放到一个专属的文件中呢?思路很简单:就是循环33210000条记录,将每辆车的数据搬运到它该去的文件中。但是对于3000多万条数据,一个一个循环太消耗时间,我花了2个小时才搬运了60万数据,算算3000万我需要花费100个小时,也就需要4-5天。并且还需要保证这五天全天开机,不能出现卡机的事故。因此,需要使用并行…

    2022年8月12日
    7
  • 小波去噪程序c语言,小波去噪c语言程序

    小波去噪程序c语言,小波去噪c语言程序小波去噪c语言程序1、小波阈值去噪理论小波阈值去噪就是对信号进行分解,然后对分解后的系数进行阈值处理,最后重构得到去噪信号。该算法其主要理论依据是:小波变换具有很强的去数据相关性,它能够使信号的能量在小波域集中在一些大的小波系数中;而噪声的能量却分布于整个小波域内。因此,经小波分解后,信号的小波系数幅值要大于噪声的系数幅值。可以认为,幅值比较大的小波系数一般以信号为主,而幅值比较小的系数在很大程度…

    2022年6月17日
    33
  • Gradle 15分钟入门教程

    1-Gradle入门介绍在阅读或实践本文中的实例前,必须首先确保已将Gradle插件安装到Eclipse中。如果没有,可以点击下面的链接查看Gradle安装说明: – http://www.yiibai.com/gradle/how-install-gradle-windows.html本教程的目标:这是项目完成后的代码结构图: 2-创建Gradle

    2022年4月4日
    43
  • java递归无限层级树_最小生成树和最短路径的区别

    java递归无限层级树_最小生成树和最短路径的区别给定一棵 N 个节点的树,要求增加若干条边,把这棵树扩充为完全图,并满足图的唯一最小生成树仍然是这棵树。求增加的边的权值总和最小是多少。注意: 树中的所有边权均为整数,且新加的所有边权也必须为整数。输入格式第一行包含整数 t,表示共有 t 组测试数据。对于每组测试数据,第一行包含整数 N。接下来 N−1 行,每行三个整数 X,Y,Z,表示 X 节点与 Y 节点之间存在一条边,长度为 Z。输出格式每组数据输出一个整数,表示权值总和最小值。每个结果占一行。数据范围1≤N≤60001≤Z≤

    2022年8月9日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号