手把手教你 用 wpf 制作metro ProgressRing (Windows8 等待动画)
效果图:

还在羡慕metro的ProgressRing吗?
wpf 也可以拥有
首先说下思路,
一共6个点围绕一直圆转,所以需要使用rotation动画 并且一直转下去。
那么下面的问题就好解决了。
首先是xaml 部分
我们需要实现旋转动画:
所以要用到这个:
- <DoubleAnimationUsingKeyFrames
- Storyboard.TargetProperty="(Ellipse.RenderTransform).(TransformGroup.Children)[2].(RotateTransform.Angle)">
- <LinearDoubleKeyFrame Value="0" KeyTime="0:0:0"/>
- <EasingDoubleKeyFrame Value="90" KeyTime="0:0:0.2">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="270" KeyTime="0:0:1.6">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="450" KeyTime="0:0:1.8">
- </EasingDoubleKeyFrame>
- <LinearDoubleKeyFrame Value="630" KeyTime="0:0:3.2"/>
- <EasingDoubleKeyFrame Value="720" KeyTime="0:0:3.4">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="720" KeyTime="0:0:5.0">
- </EasingDoubleKeyFrame>
- </DoubleAnimationUsingKeyFrames>
上面这一段是单个ellipse的运动轨迹,当然你需要在属性中设置他的中心点值
代码如下:
- <Ellipse x:Name="el" Width="10" Height="10" Fill="White" Canvas.Left="73" Canvas.Top="57" >
- <Ellipse.RenderTransform>
- <TransformGroup>
- <ScaleTransform/>
- <SkewTransform/>
- <RotateTransform CenterX="-20" CenterY="-40"/>
- <TranslateTransform/>
- </TransformGroup>
- </Ellipse.RenderTransform>
- </Ellipse>
接下来的事情就好办了,我们需要他转1圈就消失 结束后也消失,所以需要控制透明度,
- <DoubleAnimationUsingKeyFrames
- Storyboard.TargetProperty="Opacity">
- <LinearDoubleKeyFrame Value="0" KeyTime="0:0:0"/>
- <EasingDoubleKeyFrame Value="1" KeyTime="0:0:0.2">
- <EasingDoubleKeyFrame.EasingFunction>
- <BackEase EasingMode="EaseInOut"/>
- </EasingDoubleKeyFrame.EasingFunction>
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="1" KeyTime="0:0:1.6">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="1" KeyTime="0:0:1.8">
- </EasingDoubleKeyFrame>
- <LinearDoubleKeyFrame Value="1" KeyTime="0:0:3.2"/>
- <EasingDoubleKeyFrame Value="0" KeyTime="0:0:3.5">
- <EasingDoubleKeyFrame.EasingFunction>
- <BackEase EasingMode="EaseOut"/>
- </EasingDoubleKeyFrame.EasingFunction>
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="0" KeyTime="0:0:5.0">
- </EasingDoubleKeyFrame>
- </DoubleAnimationUsingKeyFrames>
最终把一个圆变成多个圆的工作 就交给代码了,需要一点点小技巧 以下使用.net 4.5实现 其他版本可以吧Task.Delay 替换成Thread.Sleep
- <UserControl
- xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
- xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
- xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
- xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
- xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity"
- xmlns:local="clr-namespace:Transvalue.MetroStyleBusyIndicator"
- x:Class="Transvalue.MetroStyleBusyIndicator.MetroRotaionIndicator"
- mc:Ignorable="d"
- d:DesignHeight="300" d:DesignWidth="300">
- <UserControl.Resources>
- <Storyboard x:Key="Trans" RepeatBehavior="Forever">
- <DoubleAnimationUsingKeyFrames
- Storyboard.TargetProperty="(Ellipse.RenderTransform).(TransformGroup.Children)[2].(RotateTransform.Angle)">
- <LinearDoubleKeyFrame Value="0" KeyTime="0:0:0"/>
- <EasingDoubleKeyFrame Value="90" KeyTime="0:0:0.2">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="270" KeyTime="0:0:1.6">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="450" KeyTime="0:0:1.8">
- </EasingDoubleKeyFrame>
- <LinearDoubleKeyFrame Value="630" KeyTime="0:0:3.2"/>
- <EasingDoubleKeyFrame Value="720" KeyTime="0:0:3.4">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="720" KeyTime="0:0:5.0">
- </EasingDoubleKeyFrame>
- </DoubleAnimationUsingKeyFrames>
- <DoubleAnimationUsingKeyFrames
- Storyboard.TargetProperty="Opacity">
- <LinearDoubleKeyFrame Value="0" KeyTime="0:0:0"/>
- <EasingDoubleKeyFrame Value="1" KeyTime="0:0:0.2">
- <EasingDoubleKeyFrame.EasingFunction>
- <BackEase EasingMode="EaseInOut"/>
- </EasingDoubleKeyFrame.EasingFunction>
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="1" KeyTime="0:0:1.6">
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="1" KeyTime="0:0:1.8">
- </EasingDoubleKeyFrame>
- <LinearDoubleKeyFrame Value="1" KeyTime="0:0:3.2"/>
- <EasingDoubleKeyFrame Value="0" KeyTime="0:0:3.5">
- <EasingDoubleKeyFrame.EasingFunction>
- <BackEase EasingMode="EaseOut"/>
- </EasingDoubleKeyFrame.EasingFunction>
- </EasingDoubleKeyFrame>
- <EasingDoubleKeyFrame Value="0" KeyTime="0:0:5.0">
- </EasingDoubleKeyFrame>
- </DoubleAnimationUsingKeyFrames>
- </Storyboard>
- </UserControl.Resources>
- <Canvas>
- <Ellipse x:Name="el" Width="10" Height="10" Fill="White" Canvas.Left="73" Canvas.Top="57" >
- <Ellipse.RenderTransform>
- <TransformGroup>
- <ScaleTransform/>
- <SkewTransform/>
- <RotateTransform CenterX="-20" CenterY="-40"/>
- <TranslateTransform/>
- </TransformGroup>
- </Ellipse.RenderTransform>
- </Ellipse>
- <Ellipse x:Name="el2" Width="10" Height="10" Fill="White" Canvas.Left="73" Canvas.Top="57" Opacity="0" >
- <Ellipse.RenderTransform>
- <TransformGroup>
- <ScaleTransform/>
- <SkewTransform/>
- <RotateTransform CenterX="-20" CenterY="-40"/>
- <TranslateTransform/>
- </TransformGroup>
- </Ellipse.RenderTransform>
- </Ellipse>
- <Ellipse x:Name="el3" Width="10" Height="10" Fill="White" Canvas.Left="73" Canvas.Top="57" Opacity="0">
- <Ellipse.RenderTransform>
- <TransformGroup>
- <ScaleTransform/>
- <SkewTransform/>
- <RotateTransform CenterX="-20" CenterY="-40"/>
- <TranslateTransform/>
- </TransformGroup>
- </Ellipse.RenderTransform>
- </Ellipse>
- <Ellipse x:Name="el4" Width="10" Height="10" Fill="White" Canvas.Left="73" Canvas.Top="57" Opacity="0">
- <Ellipse.RenderTransform>
- <TransformGroup>
- <ScaleTransform/>
- <SkewTransform/>
- <RotateTransform CenterX="-20" CenterY="-40"/>
- <TranslateTransform/>
- </TransformGroup>
- </Ellipse.RenderTransform>
- </Ellipse>
- <Ellipse x:Name="el5" Width="10" Height="10" Fill="White" Canvas.Left="73" Canvas.Top="57" Opacity="0">
- <Ellipse.RenderTransform>
- <TransformGroup>
- <ScaleTransform/>
- <SkewTransform/>
- <RotateTransform CenterX="-20" CenterY="-40"/>
- <TranslateTransform/>
- </TransformGroup>
- </Ellipse.RenderTransform>
- </Ellipse>
- <Ellipse x:Name="el6" Width="10" Height="10" Fill="White" Canvas.Left="73" Canvas.Top="57" Opacity="0">
- <Ellipse.RenderTransform>
- <TransformGroup>
- <ScaleTransform/>
- <SkewTransform/>
- <RotateTransform CenterX="-20" CenterY="-40"/>
- <TranslateTransform/>
- </TransformGroup>
- </Ellipse.RenderTransform>
- </Ellipse>
- </Canvas>
- </UserControl>
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading;
- using System.Threading.Tasks;
- using System.Windows;
- using System.Windows.Controls;
- using System.Windows.Data;
- using System.Windows.Documents;
- using System.Windows.Input;
- using System.Windows.Media;
- using System.Windows.Media.Animation;
- using System.Windows.Media.Imaging;
- using System.Windows.Navigation;
- using System.Windows.Shapes;
- namespace Transvalue.MetroStyleBusyIndicator
- {
- /// <summary>
- /// MetroRotaionIndicator.xaml 的交互逻辑
- /// </summary>
- public partial class MetroRotaionIndicator : UserControl
- {
- Storyboard trans;
- public MetroRotaionIndicator()
- {
- InitializeComponent();
- trans = Resources["Trans"] as Storyboard;
- this.Loaded += ((sender, e) =>
- {
- Active();
- });
- }
- public async void Active()
- {
- el.BeginStoryboard(trans);
- await Task.Delay(170);
- el2.BeginStoryboard(trans);
- await Task.Delay(170);
- el3.BeginStoryboard(trans);
- await Task.Delay(170);
- el4.BeginStoryboard(trans);
- await Task.Delay(170);
- el5.BeginStoryboard(trans);
- await Task.Delay(170);
- el6.BeginStoryboard(trans);
- }
- public void Stop()
- {
- trans.Stop(el);
- trans.Stop(el2);
- trans.Stop(el3);
- trans.Stop(el4);
- trans.Stop(el5);
- trans.Stop(el6);
- }
- }
- }
将以上内容编译成用户控件即可使用。
xmlns:MetroStyleBusyIndicator="clr-namespace:Transvalue.MetroStyleBusyIndicator;assembly=Transvalue.MetroStyleBusyIndicator"
<MetroStyleBusyIndicator:MetroRotaionIndicator HorizontalAlignment="Left" Height="187" Margin="924,534,0,0" VerticalAlignment="Top" Width="217"/>
手把手教你 用 wpf 制作metro ProgressRing (Windows8 等待动画)的更多相关文章
- [Swift通天遁地]一、超级工具-(11)使用EZLoadingActivity制作Loading加载等待动画
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- 详解用CSS3制作圆形滚动进度条动画效果
主 题 今天手把手教大家用CSS3制作圆形滚动进度条动画,想不会都难!那么,到底是什么东东呢?先不急,之前我分享了一个css实现进度条效果的博客<CSS实现进度条和订单进度条>,但是呢, ...
- 手把手教你制作AppPreview视频并上传到appStore进行审核
手把手教你制作AppPreview视频并上传到appStore进行审核 注意,你需要使用iMovie才能够制作AppPreview视频文件,用QuickTime录制的无效! 最终效果 1. 新建一个事 ...
- PWA入门:手把手教你制作一个PWA应用
摘要: PWA图文教程 原文:PWA入门:手把手教你制作一个PWA应用 作者:MudOnTire Fundebug经授权转载,版权归原作者所有. 简介 Web前端的同学是否想过学习app开发,以弥补自 ...
- 手把手教你去ECSHOP版权 powered by ecshop
各位朋友大家好,欢迎来到ecshop开发中心系列视频教程:ecshop去版权.去版权是一种很常见的问题,有很多客户提到ECSHOP如何去版权?怎样去得干净.去得彻底?今天,ECSHOP开发中心手把 ...
- 手把手教你ranorex_android自动化测试第一个示例
要说android的自动化,那真是折腾死我了,从早期的monkeyrunner,到后来的robotium,再到最新的uiautomator,各有各的问题,总之性价比都不够高,不太适合我的使用场景.于是 ...
- C#:手把手教你用C#打包应用程序(安装程序卸载程序)
摘要:本文介绍在C#中手把手教你用C#打包应用程序(安装程序卸载程序) 1:新建安装部署项目 打开VS,点击新建项目,选择:其他项目类型->安装与部署->安装向导(安装项目也一样),然后点 ...
- 手把手教你玩转CSS3 3D技术
手把手教你玩转 CSS3 3D 技术 要玩转css3的3d,就必须了解几个词汇,便是透视(perspective).旋转(rotate)和移动(translate).透视即是以现实的视角来看屏幕上 ...
- 手把手教你DIY尼康ML-L3红外遥控器
项目介绍 ML-L3是用于尼康部分型号相机的无线红外遥控器,可以通过红外方式来控制快门的释放,支持B门拍摄.官方售价100RMB左右,山寨版售价10RMB左右.虽然也能实现基本的遥控功能,但是功能还是 ...
随机推荐
- 见招拆招:绕过WAF继续SQL注入常用方法
Web Hacker总是生存在与WAF的不断抗争之中的,厂商不断过滤,Hacker不断绕过.WAF bypass是一个永恒的话题,不少基友也总结了很多奇技怪招.那今天我在这里做个小小的扫盲吧.先来说说 ...
- ZeroMQ之Publish/Subscribe (Java)
前面的文章介绍了比较简单的Request/Subscribe模式, 这篇文章介绍更为经典的Publish/Subscribe通信模式用来ZeroMQ的实现,其通信方式如下图: 客户端(subscrib ...
- openstack 前期准备工作
OS 是 centos6.5_X86_64 一.vmware 虚拟机 准备两台机虚拟机即可 二.导入第三方安装源 [root@openstack ~]# rpm -Uvh http://dl.fedo ...
- php自定义函数call_user_func和call_user_func_array详解
看UCenter的时候有一个函数call_user_func,百思不得其解,因为我以为是自己定义的函数,结果到处都找不到,后来百度了一下才知道call_user_func是内置函 call_user_ ...
- 【转】maven仓库快速镜像
本文转自:http://blog.csdn.net/zuoluoboy/article/details/20007819 国内连接maven官方的仓库更新依赖库,网速一般很慢,收集一些国内快速的mav ...
- iOS 和Android中的基本日期处理
提到日期处理,主要有2个参数,一个是所在的时区,一个是所用的日历方法. 主要涉及2大类问题,一类是日期类型和字符串之间的转化,另一类是日期的计算问题.ios和android都提供了相应的类来处理问题. ...
- ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib
今天在linux里安装mysql,运行时遇到这样的错误 ERROR 2002 (HY000): Can't connect to local MySQL server through socket ' ...
- Java for LeetCode 168 Excel Sheet Column Title
Given a positive integer, return its corresponding column title as appear in an Excel sheet. For exa ...
- 手把手教你学会 Emacs 定制
Table of Contents 1 前言 2 配置Emacs 2.1 设置界面 2.2 全屏以及最大化 2.3 设置周边 2.4 显示时间设置 2.5 设置日历 2.6 设置符合个人的操作习惯 2 ...
- CodeForces - 417A(思维题)
Elimination Time Limit: 1000MS Memory Limit: 262144KB 64bit IO Format: %I64d & %I64u Submit ...