零基础学通Silverlight45:动画

5.1 动画特性

通过动画可以创建动态的用户界面,可以不使用事件处理代码,而用声明的方式创建动画,使画面动起来不用编写任何C#代码,并将它无缝地集成到普通的页面中。动画由静态图像快速连续的变换的一种幻觉,各图形间轻微的不同,连串起来,就以为是产生了一个变化,通过快速播放一系列图像而产生的错觉。人脑将这一系列图像看作是一个不断变化的场景。在电影中,摄影机通过每秒记录大量照片(即,帧)来产生这种错觉。当放映机播放这些帧时,观众看到的是运动的图片。
创建逐帧动画意味着每一帧都可以包含不同的图像(或对象)。所生成的动画可能会非常大,并且在运行时要占用大量资源。出于上述原因,Expression Blend 动画将基于记录属性更改的关键帧,并在运行时动态显示属性更改之间的过渡效果。此外,在 Expression Blend 中,所有需要在动画时间线期间显示或消失的对象在整个时间线期间均存在。但可以使用关键帧来更改对象的可见性属性,使其显示或消失。
动画类型分为两类:
基本动画:可称为From/To/By动画,通过指定一个起始和终止值,或属性的一个偏移来定义动画,如上面的演示一样。动画类型有:DoubleAnimationColorAnimationPointAnimation
关键帧动画:通过一系列关键帧指定的值之间运动。动画类型有:DoubleAnimationUsingKeyFramesColorAnimationUsingKeyFramesPointAnimationUsingKeyFrames
动画具有相似的属性,基本属性有:
Duration:指定动画执行一次所需要的时间。默认值1秒。
AutoReverse:动画播放结束时,是否向后播放。
RepeatBehavior:动画播放的次数。默认情况下,只会播放一次。该属性有三种可能:持续时间、重复次数、永远。
Storyboard.TargetName:指定为哪个图形对象设置动画。
Storyboard.TargetProperty:指定的图形元素的哪个属性应用动画。
FillBehavior:回归到起始位,如设置为Stop自动回归到起始位,默认值是HoldEnd,保持动画的位置于末尾不变。
EventTrigger对象:具有一系列行为的触发器。
BeginStoryboard对象:开始一个故事板中的动画。

 

基本操作步骤:
1Expression Blend 中,打开或新建一个项目。
2)按 F6 切换到"动画"工作区。(按 F6 可在可用的工作区之间切换。在"动画"工作区中,"对象和时间线"面板位于美工板的下方。)创建要动态显示的任何对象。对象是指 Expression Blend 中的美工板上的项目。例如,如果您从"工具"面板中选择"矩形",并在美工板上绘制矩形,则会创建一个矩形对象。
3)在"对象和时间线"面板中,单击"新建"。此时,将显示"创建情节提要资源"对话框。
4)在"资源名(关键字)"字段中,键入时间线的名称,然后单击"确定"Expression Blend 将进入时间线录制模式,并且播放指针  位于 0 秒标记处。当处于录制模式中时,所设置的任何属性都将在该时间线上自动记录一个关键帧。
5)在"对象和时间线"面板中,选择要动态显示的对象。
6)如果希望选定的对象从其当前位置和外观开始运行,请单击"记录关键帧",以在 0 秒标记处记录该对象。将在与选定对象对应的行中的时间线上显示一个关键帧
7)在"对象和时间线"面板中,将播放指针拖动到动画的结束时间点处。
8)如果希望对象在动画结束和开始时的外观相同,请单击"记录关键帧"按钮。
9)将播放指针移到时间线上希望属性发生改变的位置处。
更改选定对象的属性,例如对象的位置、颜色或大小。时间线上将自动显示一个用于记录属性更改的关键帧。
10)若要查看刚才创建的动画,可单击"对象和时间线"顶部的"播放"按钮。

范例 滚动的球

创建一个来回滚动的球。
1 )启动 Microsoft Expression Blend ,建 Silverlight 项目,并将其打开以供编辑。您现在即可在项目的主页 (MainPage.xaml) 中创建内容。
2 )在 " 工具 " 面板中,选择其中椭圆形工具,如图图 11.3-1

11.3-1
3 )美工板上,通过拖动鼠标在 MainPage.xaml 的设计界面中绘制一个椭圆,并在“属性面板”的布局中设置其下列属性,如图 11.3-2
    Height=90 Width=300 StrokeThickness=0

                如图 11.3-2
在按住 Shift 的同时进行拖动,可使高度和宽度保持相同。这样做可在绘制矩形时生成正方形,在绘制椭圆时生成圆形。
在按住 Alt 的同时进行拖动,可将点击的第一个点作为中心点,而不是以该点作为所绘形状的左上角。
4 )在“属性面板”的画笔下单击 Fill ,再单击“渐变画笔”标签,接着单击“径向渐变”画笔,见如图 11.3-3

              如图 11.3-3
5 )单击“工具箱”中的“渐变工具” ,将会看到一个渐变箭头,如图 11.3-6

                  11.3-6
6 )鼠标调整渐变画笔的中心点,完成后效果如下图 11.3-7

 

                 11.3-7

 

7 )重复 8 )、 9 ),再绘制一个椭圆,并设置其下列属性,完成后效果如图 11.3-8
  Height=70 Width=240 StrokeThickness=0

                 11.3-8
8 )按住 Shift ,单击“工具箱”中的“选择”工具,选中两个椭圆。
9 )在“对象”菜单上,单击合并、排斥。
若要将所有形状或路径均合并到单一对象中,请单击 " 相并 "
若要根据相交部分剪切形状或路径,但保留所有未相交部分,请单击 " 相割 "
若要保留对象的重叠区域并删除不重叠区域,请单击 " 相交 "
若要保留非重叠区域并删除重叠区域,请单击 " 相斥 "
若要删除最后选定的形状以外的其他所有选定形状,请单击 " 相减 " ,如图图 11.3-9

 

               
11.3-9
10 )在 " 工具 " 面板中,选择其中椭圆形工具,在美工板上,通过拖动鼠标绘制一个圆,并设置其下列属性。
    Height=30 Width=30 StrokeThickness=0
11 )“属性面板”的画笔下单击 Fill ,再单击“渐变画笔”标签,接着单击“线性渐变”画笔,在下面的调色板中选择颜色,设置渐变颜色为黑到淡红。效果如图 11.3-10

                 11.3-10
12 F6 切换到 " 动画 " 工作区,准备创建脚本( Storyboard )实现动画。
F6 可在可用的工作区之间切换。在 " 动画 " 工作区中, " 对象和时间线 " 面板位于美工板的下方。
13 " 对象和时间线 " 面板中,单击 " 新建 " ,此时,将显示 " 创建 Storyboard 资源 " 对话框,如图图 11.3-11

   
                     
11.3-11
14 )在 " 名称 ( 关键字 )" 字段中,键入资源的名称,然后单击 " 确定 "
15 " 对象和时间线 " 面板中,选择圆。
16 )击 " 记录关键帧 " ,以便记录在 0 秒播放点标记上的对象的当前位置处外观,如图图 11.3-12

        
11.3-12
17 " 对象和时间线 " 面板中,将播放点拖到 1s 的时间点上,移动圆到新的位置,
18 )播放点拖到下一时间点上,不断重复,让圆绕一圈。
19 )击 " 对象和时间线 " 顶部的 " 播放 " 按钮,可查看刚才创建的动画效果
20 )击“对象和时间线”中打开的名称,此时属性面板会显示该脚本可供设置的属性,选中 AutoReverse RepeatBehavior 次数设为 2x
AutoReverse 属性设置为 True 时,动画播放结束时,会循着原来的轨迹逆向播放。
RepeatBehavior 属性用来决定动画播放的次数,如设置为 Forever 则为不断地重复播放
21 )现已完成了动画的设计操作,会保存为 UserControl 的资源,可切换至 XAML 视图来查看,如下为自动产生的动画资源 XAML 代码。
<UserControl.Resources>
<Storyboard x:Name="Storyboard1" AutoReverse="True" RepeatBehavior="2x">
<DoubleAnimationUsingKeyFrames BeginTime="00:00:00" Storyboard.TargetName="ellipse" Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[3].(TranslateTransform.X)">
                         <EasingDoubleKeyFrame KeyTime="00:00:00" Value="0"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:01" Value="-37"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:02" Value="-70"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:03" Value="-97"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:04" Value="-43"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:05" Value="-4"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:06" Value="36"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:07" Value="67"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:08" Value="105"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:09" Value="73"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:10" Value="45"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:11" Value="13"/>
                  </DoubleAnimationUsingKeyFrames>
                  <DoubleAnimationUsingKeyFrames BeginTime="00:00:00" Storyboard.TargetName="ellipse" Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[3].(TranslateTransform.Y)">
                         <EasingDoubleKeyFrame KeyTime="00:00:00" Value="0"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:01" Value="-3"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:02" Value="-9"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:03" Value="-17"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:04" Value="-29"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:05" Value="-31"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:06" Value="-31"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:07" Value="-27"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:08" Value="-16"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:09" Value="-6"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:10" Value="-3"/>
                         <EasingDoubleKeyFrame KeyTime="00:00:11" Value="-1"/>
                  </DoubleAnimationUsingKeyFrames>
           </Storyboard>      
    </UserControl.Resources>
22 )启动动画:
      Storyboard1.Begin ();
 
更详细内容及源代码下载:
http://www.amazon.cn/mn/detailApp/ref=sr_1_1?_encoding=UTF8&s=books&qid=1287058088&asin=B0043RT7I2&sr=8-1

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

相关推荐


如何在Silverlight4(XAML)中绑定IsEnabled属性?我试过简单的IsEnabled=“{BindingABC}”,但这不起作用–MenuItem总是启用.提前感谢您的线索!干杯编辑:有趣的是,当设置Mode=TwoWay时,绑定似乎有效.但是,在菜单项上移动鼠标后,将更新上下文菜单的外观.这是异步工作吗?右键
我正在编写我的第一个vb.net应用程序(但我也会在这里标记c#,因为我确信即使是一个c#人也可以使用类似的.net实现来回答这个问题).我申请的简短说明:我的桌面应用程序将仅在win平台上运行,使用vb.net,它是一个简单的网吧管理软件,在服务器上运行服务器gui,在工作站上运行客户端gui,
ProcessFile()是在UIThread上运行还是在单独的线程上运行.如果它在UIThread上,如何将文件请求和ProcessFile()移动到单独的线程?varxClient=newServiceReference1.Service1SoapClient();xClient.Retrieve_File_Completed+=newEventHandler<ServiceReference1.Retrieve_Fi
我从同行那里听说,对sharepoint的了解对职业生涯有益.我们不在办公室使用sharepoint.所以不知道如何开始.这些是我的新手问题>学习共享点值得努力吗?>学习sharepoint的资源在哪里?>我是否应该考虑开发哪些参考项目?感谢您的意见.解决方法:SharePoint以如此积极的方式改变了我的职业
我正在尝试保存一个类我的类对象的集合.我收到一个错误说明:Thecollectiondatacontracttype‘System.Collections.Generic.Listcannotbedeserializedbecauseitdoesnothaveapublicparameterlessconstructor.Addingapublicparameterlessconstructorwillf
我需要根据Silverlight中的某些配置值设置给定控件的Style.我想有可能从两种可用的样式(静态资源)中选择一个控件样式.我试图做一些像:<TextBoxStyle="{BindingABC}"/>哪里publicstringABC{get{return"{StaticResourceMyStyle}";}}不幸的是,这不起作用.你有
我刚买了第一台Android设备,我喜欢它…我也很喜欢你可以创建自己的应用程序并随意分发它们.我已经阅读了一些关于Monodroid的内容,而且显然微软希望将Silverlight放在这些设备上,尽管没有太多关于它们的信息……但是Moonlight呢?如果Monodroid就像Mono……为什么我们需要它呢?相反
我们的ASP.NET网站允许用户执行各种查询,并根据从数据库查询的结果显示网络图(如UML图).目前,我们正在生成一个位图并显示它.但由于我们需要支持允许用户以交互方式显示/隐藏某些块的功能,因此我们计划使用Silverlight来渲染图形.我们还计划在未来添加更多互动.我有两个问题:>ASP
我正在开发一个Silverlight4应用程序,我已经创建了一个自定义的启动画面.乍一看,自定义启动画面运行良好–非常好.几天后,我开始注意到闪屏不再显示,屏幕仍然是空白.这似乎只发生在我打开多个指向同一个应用程序的IE选项卡/窗口时.前几个将加载正常,而以下选项卡/窗口将保持“白
这是我的XAML:<ImageVerticalAlignment="Center"HorizontalAlignment="Center"Source="{BindingInput,Converter={StaticResourceByteArrayToBitmapConverter}}"><Image.Rend
问候,我有一个ItemsControl,我更改了模板,为绑定的ItemsSource中的每个对象显示一个RadioButton.但是ItemsSource可以为空,当它为空时我想显示默认值.像“绑定列表中没有可供您选择的项目”……我想到的一种方法是将ItemsControl.Visibility设置为Collapsed,并将TextBlock.Vsibi
堆栈溢出的第一个问题……我是C#的新手,但在学习它时却非常直接.几分钟前我才看到这个tutorial.通过各种c#技术阅读WCF,WPF,Silverlight,c#和asp.net,这是很多技术都可以用c#来实现.我将创建一个Web应用程序c#.我认为SilverLight似乎是我最好的选择.该应用程序将拥有一个数
我正在使用MVVM(Model-View-ViewModel)模式编写应用程序,并利用MicrosoftP&P团队的Prism和Unity位.我有一个包含项目列表的视图.这些项包含在ViewModel中的ObservableCollection中,View中的列表框是数据绑定的(ViewModel设置为View的DataContext).在ViewModel中,我有一个运行的
我有一个应用程序,它在首次运行时显示免责声明页面.选择“接受”或“拒绝”后,您再也看不到该页面了.但是,当您在第一次运行后按后退键尝试关闭应用程序时,您将返回免责声明页面,然后再次点击该页面,返回主页面,然后再次退出.这仅在应用程序第一次运行时发生,但我希望应用程序在
我正在尝试在SilverlightforWindowsPhone中使用异步HttpWebRequest.一切都很完美,直到我到达我应该打电话的地方privatestaticManualResetEventallDone=newManualResetEvent(false);...request.BeginGetResponse(newAsyncCallback(GetResponseCallback),request);a
嗨,我有两个Writablebitmap,一个来自jpg,另一个来自png,并使用此方法在循环中混合颜色:privatestaticColorMix(Colorfrom,Colorto,floatpercent){floatamountFrom=1.0f-percent;returnColor.FromArgb((byte)(from.A*amountFrom+to.A*perc
我需要开发一个程序,它包含一个图像(png),中心有一个洞.在这个图像下将有一个框架,我想点击图像的透明孔我可以点击框架内的按钮.我不知道是否有一种方法可以通过图像或其他方式传播点击.谢谢你的帮助解决方法:你在图像上将IsHitTestVisible设置为false,然后点击浏览.
我正在研究一个silverlight应用程序,我发现List没有Find扩展方法说,List<Something>list=newList<Something>(something);list.Remove(list.Find(e=>e.id==10));没有查找扩展方法我错过了什么?解决方法:它不包括在内以减小运行时的大小.建议您使用LINQ扩展,例如First
我试图弄清楚如何设置Path元素的Data属性来获得此类型的软角:alttexthttp://i42.tinypic.com/1rzu6w.jpg现在我只有这样的尖角:alttexthttp://i42.tinypic.com/2eeleah.jpg我尝试用椭圆玩,但我无法得到我想要的东西.谢谢最佳答案:路径的段具有IsSmoothJoin属性,默认为false.
问题我有一个在远程服务器上运行的restfulWeb服务.我已经制作了一个使用它的WP7应用程序,所以我知道它有效.我正在将应用程序移植到SilverlightWeb应用程序并遇到问题.我已经包含了代码的简化版本以及引发的错误.EndGetResponse方法抛出错误.随意询问更多信息.我一直在寻找解