




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、WPF 省略号动画省略号动画可以用于加载数据,等待等多个场景使用,在wpf中要实现省略号动画方式多种多样,但是要通用起来目前笔者还没有看到一个好的结局方案。现在我们一起来做一个通用的省略号动画类,达到像拖控件一样简单。思路,有一个类,我只要实例化它后,传入一个UI元素比如Border或Panel。调用某个方法比如Run,就可以让小圆点跑起来。首先建立一个用来调用的类,取名为:EllipsisRun调用类创建完成。省略号。是6个小圆点。那么我就需要在类里面来创建6个小圆点。小圆点创建好了,那么怎么让小圆点看起来似乎在动呢?通过设置小圆点的样式来实现,比如:先定义三个个样式字段:1. Ellips
2、eStyleBase用来设置小圆点的Height,Width,Margin;2. EllipseStyleNormal继承EllipseStyleBase追加Stroke(设置边框颜色)和StrokeThickness(设置边框显示大小);3. EllipseStyleHilight继承EllipseStyleBase追加Fill(设置填充颜色)所以我们需要一个方法来设置这三个样式:我们想设置个默认值怎么样,同时又想自己定义下值,那么我可以用一个方法来设置。我这里使用构造方法来实现。小圆点样式已经完成了,那么我们现在需要让小圆点“动起来”,我们需要创建一个Run方法,传入我们指定的容器,让校园
3、的在这个容器中“动起来”。开来我们还需要添加一些关键性的字段和属性现在小圆点可以跑起来了。在情景中,我们数据加载完了。还需要关闭动画。所以我们还需要一个退出动画的方法来调用,这里我们用End()方法来实现。好的大功告我们来调用下我们的小圆点动画XAMLCS:运行起来看上去还不错哦。下面是完整代码:/ <summary> / 省略号动画 / 用法: / var er = new EllipsisRun(); / er.Run(参数:Border或Panel); / </summary> public class EllipsisRun private Style Elli
4、pseStyleBase; private Style EllipseStyleNormal; private Style EllipseStyleHilight; private UIElement _Content; / <summary> / 要插入动画的UI元素 Border或Panel / </summary> public UIElement TargetParent get; private set; / <summary> / true动画正在进行中 false动画未开始或者已经结束 / </summary> public boo
5、l IsRun get; private set; / <summary> / 实例化 省略号动画动画对象 / </summary> public EllipsisRun() double hw = 8, m = 2, s = 1; init(hw, hw, m, s, Brushes.BlueViolet); / <summary> / 实例化 省略号动画动画对象 / height省略号元素高 / width省略号元素宽 / margion省略号元素边距 / strokeThickness省略号元素裱框 / brush省略号元素填充色 / </sum
6、mary> / <param name="height">省略号元素高</param> / <param name="width">省略号元素宽</param> / <param name="margion">省略号元素边距</param> / <param name="strokeThickness">省略号元素裱框</param> / <param name="brush">省略
7、号元素裱框</param> public EllipsisRun(double height, double width, double margion, double strokeThickness, Brush brush) init(height, width, margion, strokeThickness, brush); private void init(double h, double w, double m, double s, Brush brush) EllipseStyleBase = new Style(typeof(Ellipse); var s_he
8、ight = new Setter(Ellipse.HeightProperty, h); var s_width = new Setter(Ellipse.WidthProperty, w); var s_margin = new Setter(Ellipse.MarginProperty, new Thickness(m); EllipseStyleBase.Setters.Add(s_height); EllipseStyleBase.Setters.Add(s_width); EllipseStyleBase.Setters.Add(s_margin); EllipseStyleNor
9、mal = new Style(typeof(Ellipse), EllipseStyleBase); var s_stroke = new Setter(Ellipse.StrokeProperty, brush); var s_stroke_thickness = new Setter(Ellipse.StrokeThicknessProperty, s); EllipseStyleNormal.Setters.Add(s_stroke); EllipseStyleNormal.Setters.Add(s_stroke_thickness); EllipseStyleHilight = n
10、ew Style(typeof(Ellipse), EllipseStyleBase); var s_fill = new Setter(Ellipse.FillProperty, brush); EllipseStyleHilight.Setters.Add(s_fill); / <summary> / 开始动画 / targetUI 指定要进行动画UI元素(Border或Panel) / 异常: / 1.动画进行中 / 2.targetUI为null或非Border、Panel元素 / </summary> / <param name="target
11、UI">指定要进行动画UI元素(Border或Panel)</param> / <returns></returns> public EllipsisRun Run(UIElement targetUI) if (IsRun) throw new Exception("目标正在使用中"); List<Ellipse> items = null; var parent = createEllipseItems(out items); if (targetUI is Border) (targetUI as Bor
12、der).Child = parent; else if (targetUI is Panel) (targetUI as Panel).Children.Add(parent); else throw new Exception("目标ui只能是Panel或Border类型"); TargetParent = targetUI; _Content = parent; IsRun = true; var task = Task.Factory.StartNew() => int index = 0; while (IsRun) if (index >= item
13、s.Count) index = 0; var index_last = index - 1; if (index_last < 0) index_last = items.Count - 1; var item_last = itemsindex_last; var item_next = itemsindex; targetUI.Dispatcher.Invoke() => item_last.Style = EllipseStyleNormal; item_next.Style = EllipseStyleHilight; ); index+; Thread.Sleep(12
14、0); ); return this; / <summary> / 结束正在进行的动画 / 异常: / 1.动画未进行 / 2.动画已经结束 / </summary> / <returns></returns> public EllipsisRun End() if (IsRun) IsRun = false; Thread.Sleep(200); if (TargetParent is Border) (TargetParent as Border).Child = null; else if (TargetParent is Panel) (TargetParent as Panel).Children.Remove(_Content); return this; else throw new Exception("目标已经停止使用或未开始"); private WrapPanel createEllipseItems(out List<Ellipse> list) list = new List<Ellipse>(); var parent = new Wrap
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 社区与医院签订合同协议
- 汽油发电机购买合同范本
- 浙江网上申请就业协议书
- 终止车辆承包合同协议书
- 高校县中托管帮扶协议书
- 法律合同解除协议书范本
- 私人财产转移协议书范本
- 瓷砖店铺转让合同协议书
- 社区矫正基地服务协议书
- 洁净室车间出租合同范本
- 高职大学生心里健康教育(第2版)-课程思政案例(结合知识点)
- 2025年大学食堂食材采购协议
- Drager呼吸机使用指南
- 办公用品、易耗品供货服务方案投标方案文件
- 餐厨垃圾处理可行性研究报告
- 2025年度链家租赁合同电子版(含房屋设施维修责任)
- 静脉导管常见并发症临床护理实践指南(上)
- 《妇产科学绪论》课件
- 酒店考勤培训
- 非煤矿山矿石运输车辆安全协议书
- 东北林业大学20-21高数A2期末考试含答案
评论
0/150
提交评论