天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

一步一步學Silverlight :使用Transform實現更炫的效果(下)

概述

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是所有變換中功能最強大最靈活也是最復雜的一種變換,如果前面講解的幾種基本變化不能滿足我們在實際開發中的需求,可以使用矩陣變換進行自定義,它允許我們直接對變換矩陣進行操作。

在Silverlight中,變換是提供一個3*3的矩陣,我們通過修改矩陣中成員的值來實現變換,矩陣的定義如下所示:

TerryLee_Silverlight2_0148

如修改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>

運行后效果如下:

TerryLee_Silverlight2_0149  

實現動畫變換

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();}

運行后效果如下:

TerryLee_Silverlight2_0150

當鼠標放上后將開始旋轉:

TerryLee_Silverlight2_0151 

用代碼控制變換

這個話題其實沒什么好講的,在后臺代碼中對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;}

運行后起始界面如下:

TerryLee_Silverlight2_0152

當單擊之后將會旋轉:

TerryLee_Silverlight2_0153 

結束語

本文為使用Transform實現更炫的效果第二部分,介紹了矩陣變換以及如何實現動畫變換、在代碼中控制變換,接下來我將會運用前面幾篇關于圖形圖像處理的知識寫一個綜合實例。

NET技術一步一步學Silverlight :使用Transform實現更炫的效果(下),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线观看亚洲AV无码每日更新 | 中文字幕一区在线观看视频 | 99久久免费只有精品 | 添加一点爱与你电视剧免费观看 | 宝贝你骚死哥了好爽 | 么公在浴室了我的奶 | 久久久精品免费视频 | 色网址在线观看 | 98久久无码一区人妻A片蜜 | 国产久久re6免费热在线 | 国产精品爽爽久久久久久蜜桃 | 老湿机一区午夜精品免费福利 | 最近更新2019中文字幕免费 | 二级毛片免费观看全程 | 免费视频网站嗯啊轻点 | 日本妞欧洲 | 欧美在线看费视频在线 | 久久视频这只精品99re6 | 狼群资源网中文字幕 | 女人爽得直叫免费视频 | 久久国产乱子伦精品免费不卡 | 亚洲 欧美 国产 综合久久 | 国产欧美精品一区二区色综合 | 日韩欧美一区二区三区在线视频 | 中文字幕国产在线观看 | 抽插妇女疯狂视频 | 国产色婷亚洲99精品AV | 国产h视频在线观看免费 | 国产成人高清精品免费观看 | 人成片在线观看亚洲无遮拦 | 久久国产乱子伦免费精品 | 中文字幕亚洲无线码一区 | 曰本xxⅹ孕妇性xxx | 日日噜噜噜夜夜爽爽狠狠图片 | 亚洲色噜噜狠狠网站 | 国产精品ⅴ视频免费观看 | 捆绑白丝粉色JK震动捧喷白浆 | 看全色黄大色大片免费久黄久 | 无人区尖叫之夜美女姐姐视频 | 美女脱了内裤张开腿让男人桶到爽 | 欧美深深色噜噜狠狠yyy |