(30):Silverlight 2 使用Transform实现更炫的效果(下)

(30):Silverlight 2 使用Transform实现更炫的效果(下),第1张

概述概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, Ironpython,对JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章将从Silverlight 2基础知识、数据 概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic,Visual C#,IronRuby,Ironpython,对JsON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章将从Silverlight 2基础知识、数据与通信、自定义控件、动画、图形图像等几个方面带您快速进入Silverlight 2开发。 本文为使用transform实现更炫的效果第二部分,在Silverlight中提供了四种基本变换:旋转变换(Rotatetransform )、缩放变换(Scaletransform)、倾斜变换(Skewtransform)、移动变换(Translatetransform)和两种复杂的变换:变换组(transformGroup)、矩阵变换(Matrixtransform ),这些变换可以运用到任何控件或者图形图像。 矩阵变换(Matrixtransform ) 矩阵变换Matrixtransform是所有变换中功能最强大最灵活也是最复杂的一种变换,如果前面讲解的几种基本变化不能满足我们在实际开发中的需螅梢允褂镁卣蟊浠唤凶远ㄒ澹市砦颐侵苯佣员浠痪卣蠼胁僮鳌?/div> 在Silverlight中,变换是提供一个3*3的矩阵,我们通过修改矩阵中成员的值来实现变换,矩阵的定义如下所示:  

如修改OffsetX,元素将会在X轴上进行移动;修改OffsetY,元素将在Y轴上移动;修改M22为2,元素的高度将会拉伸2倍,通过该矩阵,我们能实现前面提到的几种基本变换的所有功能。更详细的解释大家可以参考SDK。如下面的例子,我们使用矩阵变换,仍然能实现前面示例中的变换效果:
<Canvas Background="#CdfcAE">    <Image Source="a1.png" Canvas.left="120" Canvas.top="50" Opacity="0.3">    </Image>    <Image Source="a1.png" Canvas.left="120" Canvas.top="50" Opacity="0.5">        <Image.Rendertransform>            <Matrixtransform>                <Matrixtransform.Matrix>                    <Matrix OffsetX="0" OffsetY="0" M12="0.2"></Matrix>                </Matrixtransform.Matrix>            </Matrixtransform>        </Image.Rendertransform>    </Image>        <Image Source="a1.png" Canvas.left="120" Canvas.top="50">        <Image.Rendertransform>            <Matrixtransform>                <Matrixtransform.Matrix>                    <Matrix OffsetX="0" OffsetY="0" M12="0.4"></Matrix>                </Matrixtransform.Matrix>            </Matrixtransform>        </Image.Rendertransform>    </Image></Canvas>
运行后效果如下:

   实现动画变换 transform与Silverlight中的Storyboard结合,可以很容易的实现出动画变换的效果,如下面的例子,当鼠标放在上去的时候,图片开始旋转;鼠标离开时停止旋转:
<Canvas Background="#CdfcAE">    <Canvas.Resources>        <Storyboard x:name="myStoryboard">            <DoubleAnimation          Storyboard.Targetname="mytransform"          Storyboard.TargetProperty="Angle"          From="0" To="180" Duration="0:0:5" RepeatBehavior="Forever" />        </Storyboard>    </Canvas.Resources>    <Image x:name="imgTarget" Source="a1.png" Canvas.left="180" Canvas.top="80"           MouseEnter="imgTarget_MouseEnter" MouseLeave="imgTarget_MouseLeave">        <Image.Rendertransform>            <Rotatetransform x:name="mytransform" Angle="15" CenterX="120" CenterY="68" />        </Image.Rendertransform>    </Image></Canvas>
在代码中控制Storyboard:
private voID imgTarget_MouseEnter(object sender,MouseEventArgs e){    myStoryboard.Begin();}private voID imgTarget_MouseLeave(object sender,MouseEventArgs e){    myStoryboard.Stop();}
运行后效果如下:  

当鼠标放上后将开始旋转:

  用代码控制变换 这个话题其实没什么好讲的,在后台代码中对transform进行控制,如下面的例子,每次点击图片时,都让Rotatetransform的角度增加15度:
<Canvas Background="#CdfcAE">    <Image Source="a1.png" Canvas.left="180" Canvas.top="80" Opacity="0.3">    </Image>    <Image x:name="imgTarget" Source="a1.png" Canvas.left="180" Canvas.top="80"           MouseleftbuttonDown="imgTarget_MouseleftbuttonDown">        <Image.Rendertransform>            <Rotatetransform x:name="mytransform" Angle="0" CenterX="120" CenterY="68" />        </Image.Rendertransform>    </Image></Canvas>
后台代码:
private voID imgTarget_MouseleftbuttonDown(object sender,MousebuttonEventArgs e){    mytransform.Angle = mytransform.Angle + 15;}
运行后起始界面如下:  

当单击之后将会旋转:

  结束语 本文为使用transform实现更炫的效果第二部分,介绍了矩阵变换以及如何实现动画变换、在代码中控制变换,接下来我将会运用前面几篇关于图形图像处理的知识写一个综合实例。

本文出自 “TerryLee技术专栏” 博客,请务必保留此出处http://www.voidcn.com/article/p-guhkqphh-wq.html

本文出自 51CTO.COM技术博客 总结

以上是内存溢出为你收集整理的(30):Silverlight 2 使用Transform实现更炫的效果(下)全部内容,希望文章能够帮你解决(30):Silverlight 2 使用Transform实现更炫的效果(下)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1047793.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存