uwp 图片切换动画
最近在学习安卓,LOL自定义战绩项目近乎停工,而且腾旭把界面全改了,好烦。刚好学习到安卓中的图片切换动画,我就想在LOL项目中实现一个。首先上百度查看一下,妈的,资料少的可怜。
还是自己来吧。自定义控件走一波
效果图
新建自定义控件
直接改模板文件 把里面换成一个image source绑定到依赖属性上
<Style TargetType="control:ImageDisplayer">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="control:ImageDisplayer">
<Image x:Name="image" Width="" Height="" Source="{TemplateBinding ImageSourceNormal}"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
在cs文件里添加字段
//这个定时器用来控制图片切换
DispatcherTimer time = new DispatcherTimer();
//静态字段 image指模板中的image控件
private static Image image;
int i = 1;
添加依赖属性
#region dependencyProperty
/// <summary>
/// 用于显示的Image绑定的Source属性
/// </summary>
public ImageSource ImageSourceNormal
{
get { return (ImageSource)GetValue(ImageSourceNormalProperty); }
set { SetValue(ImageSourceNormalProperty, value); }
}
public static readonly DependencyProperty ImageSourceNormalProperty = DependencyProperty.Register("ImageSourceNormal", typeof(ImageSource), typeof(ImageDisplayer), new PropertyMetadata(null));
#endregion
添加属性
#region property
/// <summary>
/// 是否在显示动画
/// </summary>
public bool IsShow { get; private set; }
/// <summary>
/// List<BitmapImage> Images循环显示的集合
/// </summary>
public List<BitmapImage> Images { get; set; }
#endregion
重写OnApplyTemplate()方法
/// <summary>
/// 重用模板时启用
/// </summary>
protected override void OnApplyTemplate()
{
base.OnApplyTemplate();
//在这里将image指向模板中的iamge控件
image = GetTemplateChild("image") as Image;
//注册time的Tick事件 忽略timer少的那个r 写错了 不想改了 就是这么任性
time.Tick += Time_Tick;
time.Interval = TimeSpan.FromMilliseconds(100);
}
在tick事件里处理图片切换
/// <summary>
/// 计时器操作
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private async void Time_Tick(object sender, object e)
{
if (image == null||Images==null)
{
time.Stop();
IsShow = false;
return;
}
if (i >= Images.Count)
{
i = ;
}
await Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
{
ImageSourceNormal = Images[i];
});
i++;
}
写控件的使用与停止方法
/// <summary>
/// 开始计时器
/// </summary>
public void Show()
{
time.Start();
IsShow = true;
}
/// <summary>
/// 停止计时器
/// </summary>
public void Stop()
{
time.Stop();
}
现在,这个控件就可以使用了
在页面上添加一个引用
<local2:ImageDisplayer x:Name="display"/>
当你想显示动画的时候这样做
//这个list就是图片的集合 图片的命名要规范点 像teemo_1.jpg teemo_2.jpg
List<BitmapImage> list = new List<BitmapImage>();
for (int i = ; i < ; i++)
{
//初始化图片集合
BitmapImage image = new BitmapImage(new Uri(string.Format("ms-appx:///Resources/teemo_{0}.png", i)));
list.Add(image);
}
display.Images = list;
display.Show();
//停止动画的时候调用这个方法
display.Stop();
完成;
写的不好,请多理解
gayhub地址:https://github.com/hei12138/LOL-/tree/master/Mycontrols
这是一个类库项目,里面也有我自定义的一些其他控件
新手,欢迎交流 1329698854@qq.com
uwp 图片切换动画的更多相关文章
- uwp 图片切换动画 使用帧动画
上一篇博客使用了Timer来实现图片的切换,@lindexi_gd讨论了一下性能,我本人其实对性能这一方面不太熟,但我觉得还是有必要考虑一下,那么今天我们使用帧动画开实现以下 新建项目,添加一个But ...
- JQuery图片切换动画效果
由于博主我懒,所以页面画的比较粗糙,但是没关系,因为我主要讲的是如何实现图片动画切换. 思路:想必大家都逛过淘宝或者其他的一些网站,一般都会有图片动画切换的效果,那是怎样实现的呢?博主我呢,技术不是很 ...
- 这个图片切换动画只用CSS3实现
体验效果:http://hovertree.com/texiao/css3/39/ 这是一个使用纯CSS3实现的图文切换效果,没使用js脚本.点击左右箭头或者索圆点引按钮可以切换内容. 本特效中使用到 ...
- 3D立方体图片切换动画
在线演示 本地下载
- HTML5移动端图片左右切换动画
插件描述:HTML5移动端图片左右切换动画 小海今天要给大家分享一款很不错的图片左右切换焦点图动画,并且支持移动端触摸滑动.功能上,这款HTML5图片播放器支持鼠标滑动.手机端触摸滑动以及自动播放.外 ...
- 10个超赞的jQuery图片滑块动画
在网站开发过程中,特别是前端开发这块,经常会使用到很多图片滑块动画,也就是一些基于jQuery和HTML5的焦点图插件.本文将为大家收集10个超赞的jQuery图片滑块动画,这些现成的jQuery插件 ...
- Qt编写自定义控件33-图片切换动画
一.前言 在很多看图软件中,切换图片的时候可以带上动画过渡或者切换效果,显得更人性化,其实主要还是炫一些,比如百叶窗.透明度变化.左下角飞入等,无论多少种效果,核心都是围绕QPainter来进行,将各 ...
- app引导页(背景图片切换加各个页面动画效果)
前言:不知不觉中又加班到了10点半,整个启动页面做了一天多的时间,一共有三个页面,每个页面都有动画效果,动画效果调试起来麻烦,既要跟ios统一,又要匹配各种不同的手机,然后产品经理还有可能在中途改需求 ...
- jQuery演示10种不同的切换图片列表动画效果
经常用到的图片插件演示jQuery十种不同的切换图片列表动画效果 在线演示 下载地址 实例代码 <!DOCTYPE html> <html lang="en" c ...
随机推荐
- 如何在EF中实现left join(左联接)查询
在EF中,当在dbset使用join关联多表查询时,连接查询的表如果没有建立相应的外键关系时,EF生成的SQL语句是inner join(内联),对于inner join,有所了解的同学都知道,很多时 ...
- 【NuGet】打包上传一条龙服务
昨天写了搭建自己的NuGet程序源,但是领导不满意之前的打包上传~~,无奈只能去爬点思路了,这里参考的其他博文,但是还是想写下来. 第一步.建立一个批处理文件 在文件里,有三条命令: nuget pa ...
- Logback配置连接
logback 简介 logback 常用配置详解(一)<configuration> and <logger> logback 常用配置详解(二)<appender&g ...
- java 通过jdbc连接MySQL数据库
先了解下JDBC的常用接口 1.驱动程序接口Driver 每种数据库的驱动程序都应该提供一个实现java.sql.Driver接口的类,简称Driver类.通常情况下,通过java.lang.Clas ...
- 页面加载完成后,触发事件——trigger()
<button id="btn">点击我</button> <div id="test"></div> 如果页面 ...
- 关于使用iframe嵌套页面的跳转方式
一.背景A,B,C,D都是jsp,D是C的iframe,C是B的iframe,B是A的iframe,在D中跳转页面的写法区别如下. 二.JS跳转window.location.href.locatio ...
- HDU 1907 Nim博弈变形
1.HDU 1907 2.题意:n堆糖,两人轮流,每次从任意一堆中至少取一个,最后取光者输. 3.总结:有点变形的Nim,还是不太明白,盗用一下学长的分析吧 传送门 分析:经典的Nim博弈的一点变形. ...
- AngularJS中的route可以控制页面元素的改变,使多页面变成一个单页面。。。
SPA(Single Page Application)指的是通单一页面展示所有功能,通过Ajax动态获取数据然后进行实时渲染,结合CSS3动画模仿原生App交互,然后再进行打包(使用工具把Web应用 ...
- chrome浏览器js 导出excel
<table id="table"> <tr> <th>ID</th> <th>姓名</th> <th ...
- 【安装mysql】windows安装压缩版mysql5.7.15
160915.1459 综述 中午安装成功,但是启动失败,很可能是压缩包有问题(从别人拷的),解决了近一个小时,没搞定,于是换条方案,重新去官网下载压缩包,这次看准了windows架构,且64-b ...