wp之切换图片动画

  由于早前买了一部windows phone手机,也想借着手机开发一些关于windows phone的软件,先前有尝试做了一款简易备忘软件,最近在学习的过程中,竟然遇到了Canvas,Html5的Canvas跟安卓版本的比较相似,但是跟windows phone的Canvas就有点不同了,今天就试着利用canvas来做一个图片切换的程序。

  效果如下:

  图片切换的原理就是简单的2张重叠的图片,第一张被剪裁的区域逐渐变大,第二章图片逐渐显现出来。

  首先需要一个较大的Canvas容器,用于装载这些需要的图片,XAML代码如下:

1 <Canvas x:Name="DisplayCanvas" Width="400" Height="600" HorizontalAlignment="Center" VerticalAlignment="Center">
2 </Canvas>

  对图片进行裁剪,需要用到Canvas、PathGeometry(表示一个可能由弧、曲线、椭圆、直线和矩形组成的复杂形状)、LineSegmen(在PathFigure中的两个点之间创建一条直线。),如:当我们设置3个点的时候,会裁剪出一个三角形。

复制代码
1 private List<Canvas> m_images = new List<Canvas>();
2 
3 private PathGeometry m_displayClip = null;
4 
5 private LineSegment m_displayPoint1 = null;
6 
7 private LineSegment m_displayPoint2 = null;
8 
9 private Storyboard m_timer = null;
复制代码

  以Canvas为容器来存放Image对象,并让赋予Canvas点击事件来触发切换图片的效果,代码如下:

复制代码
 1 //添加Image对象
 2 var canvas = new Canvas
 3 {
 4     Width = MAX_WIDTH,
 5     Height = MAX_HEIGHT,
 6     Background = new SolidColorBrush { Color = Colors.White }
 7 };
 8 
 9 canvas.MouseLeftButtonDown += new MouseButtonEventHandler(DisplayImage);
10 
11 var uri = new Uri(imgPath, UriKind.Relative);
12 var imgSurce = new BitmapImage(uri);
13 
14 var img = new Image
15 {
16     Source = imgSurce,
17     Width = 384,
18     Margin = new Thickness(8, 8, 0, 0)
19 };
20 
21 canvas.Children.Add(img);
复制代码

  然后利用PathGeometry、LineSegmen裁剪出剩下的部分,由于我们需要在每一次时间内实现动画的效果,这时就需要Storyboard了,它可以实现我们需要的动画效果。代码大致如下:

复制代码
 1 if (m_movedHeight < MAX_HEIGHT)
 2 {
 3     m_movedHeight += MOVE_STEP;
 4     m_displayPoint1.Point = new Point(MAX_WIDTH, m_movedHeight);
 5     m_displayPoint2.Point = new Point(0, m_movedHeight);
 6     m_timer.Begin();
 7 }
 8 else
 9 {
10     m_displaying = false;
11     m_images[m_index++].Clip = null;
12     InitCanvasOrder();
13 }
复制代码

  如果需要连续切换好几张图片,那么将Canvas.Clip设为NULL是必须的,不然会出现错误。

  这是一个简单的wp动画,如有错误,请告诉我,谢谢!

  源码在此

posted @   ahl5esoft  阅读(2497)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示