一步一步学Silverlight 2系列(29):使用Transform实现更炫的效果(上)

概述

Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, Ironpython,对JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章将从Silverlight 2基础知识、数据与通信、自定义控件、动画、图形图像等几个方面带您快速进入Silverlight 2开发。

本文为理解Silverlight中的变换(Transformations)第一部分,在Silverlight中提供了四种基本变换:旋转变换(RotateTransform )、缩放变换(ScaleTransform)、倾斜变换(SkewTransform)、移动变换(TranslateTransform)和两种复杂的变换:变换组(TransformGroup)、矩阵变换(MatrixTransform ),这些变换可以运用到任何控件或者图形图像。

旋转变换(RotateTransform )

RotateTransform允许我们对元素围绕一个点对元素进行一个给定角度的旋转,默认情况下,将围绕左上角点(0,0)处进行旋转。可以通过元素的RenderTransform属性来指定Transform,如下面的例子,我们在同一位置放置两张图片,对其中一张进行旋转:

<Canvas Background="#CDFCAE">
    <Image Source="a1.png" Canvas.Left="160" Canvas.Top="20" Opacity="0.5">
    </Image>
    <Image Source="a1.png" Canvas.Left="160" Canvas.Top="20">
        <Image.RenderTransform>
            <RotateTransform Angle="45"></RotateTransform>
        </Image.RenderTransform>
    </Image>
</Canvas>

运行后将围绕(0,0)旋转45°角:

TerryLee_Silverlight2_0142 

如果我们想指定旋转点的话,可以通过属性CenterX和CenterY两个属性进行控制,如下代码所示:

<Canvas Background="#CDFCAE">
    <Image Source="a1.png" Canvas.Left="160" Canvas.Top="80" Opacity="0.5">
    </Image>
    <Image Source="a1.png" Canvas.Left="160" Canvas.Top="80">
        <Image.RenderTransform>
            <RotateTransform Angle="45" CenterX="120" CenterY="68"></RotateTransform>
        </Image.RenderTransform>
    </Image>
</Canvas>

运行后可以看到,将围绕图片的中心旋转45°:

TerryLee_Silverlight2_0143 

缩放变换(ScaleTransform)

缩放变换ScaleTransform允许我们对元素进行缩放,通过属性ScaleX和ScaleY来分别指定在X轴和Y轴上的缩放比例,同样也可以使用属性CenterX和CenterY来指定缩放中心。如下面的示例:

<Canvas Background="#CDFCAE">
    <Image Source="a1.png" Canvas.Left="40" Canvas.Top="80" Opacity="0.5">
    </Image>
    <Image Source="a1.png" Canvas.Left="40" Canvas.Top="80">
        <Image.RenderTransform>
            <ScaleTransform ScaleX="0.5" ScaleY="0.5"></ScaleTransform>
        </Image.RenderTransform>
    </Image>
    
    <Image Source="a1.png" Canvas.Left="320" Canvas.Top="80" Opacity="0.5">
    </Image>
    <Image Source="a1.png" Canvas.Left="320" Canvas.Top="80">
        <Image.RenderTransform>
            <ScaleTransform ScaleX="0.5" ScaleY="0.5"
                            CenterX="120" CenterY="68"></ScaleTransform>
        </Image.RenderTransform>
    </Image>
</Canvas>

运行后效果如下所示:

TerryLee_Silverlight2_0144 

倾斜变换(SkewTransform)

倾斜变换SkewTransform允许我们对元素围绕一点进行一定角度的倾斜,可以通过属性AngleX和AngleY分别设置在X轴和Y轴上倾斜角度,以及CenterX和CenterY来指定一个变换中心点。如下面的例子:

<Canvas Background="#CDFCAE">
    <Image Source="a1.png" Canvas.Left="80" Canvas.Top="20" Opacity="0.5">
    </Image>
    <Image Source="a1.png" Canvas.Left="80" Canvas.Top="20">
        <Image.RenderTransform>
            <SkewTransform AngleX="30" AngleY="30"></SkewTransform>
        </Image.RenderTransform>
    </Image>
</Canvas>

运行后的效果如下:

TerryLee_Silverlight2_0145 

移动变换(TranslateTransform)

移动变换TranslateTransform允许我们对元素在X轴和Y轴上做一定位置的移动,通过属性X和Y两个属性来指定,如下面的例子,对图片和文字做一些移动变换,使其显示出阴影效果:

<Canvas Background="#CDFCAE">
    <Image Source="a1.png" Canvas.Left="80" Canvas.Top="80" Opacity="0.5">
    </Image>
    <Image Source="a1.png" Canvas.Left="80" Canvas.Top="80">
        <Image.RenderTransform>
            <TranslateTransform X="-10" Y="-10"></TranslateTransform>
        </Image.RenderTransform>
    </Image>
    
    <TextBlock Canvas.Top="80" Canvas.Left="360" FontWeight="Bold" 
               Text="博客园" FontSize="60" Foreground="#C1C1C1">
        <TextBlock.RenderTransform>
            <TranslateTransform X="5" Y="5"></TranslateTransform>
        </TextBlock.RenderTransform>
    </TextBlock>
    <TextBlock Canvas.Top="80" Canvas.Left="360" FontWeight="Bold"
               Text="博客园" FontSize="60" Foreground="#FF0000"></TextBlock>
</Canvas>

运行后效果如下所示:

TerryLee_Silverlight2_0146

变换组(TransformGroup)

变换组TransformGroup其实就把几种变换组合在一起,使用起来比较简单,最终实现的效果如何就看各人的审美观了:),如下面的例子:

<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>
            <TransformGroup>
                <RotateTransform Angle="5"></RotateTransform>
                <SkewTransform AngleX="5" AngleY="5"></SkewTransform>
            </TransformGroup>
        </Image.RenderTransform>
    </Image>
    <Image Source="a1.png" Canvas.Left="120" Canvas.Top="50">
        <Image.RenderTransform>
            <TransformGroup>
                <RotateTransform Angle="10"></RotateTransform>
                <SkewTransform AngleX="10" AngleY="10"></SkewTransform>
            </TransformGroup>
        </Image.RenderTransform>
    </Image>
</Canvas>

运行后效果如下所示:

TerryLee_Silverlight2_0147

结束语

本文介绍了Silverlight中四种基本变换和变换组。

作者:TerryLee
出处:http://terrylee.cnblogs.com
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。
Tag标签: Silverlight

posted on 2008-03-19 18:43 TerryLee 阅读(6200) 评论(19)  编辑 收藏 所属分类: Silverlight

评论

#1楼  2008-03-19 18:51 里奥特      

学习   回复  引用  查看    

#2楼 [楼主] 2008-03-19 19:04 TerryLee      

:)   回复  引用  查看    

#3楼  2008-03-19 19:23 jillzhang      

李兄效率真高   回复  引用  查看    

#4楼  2008-03-19 19:27 侯垒      

速度之快.   回复  引用  查看    

#5楼 [楼主] 2008-03-19 19:28 TerryLee      

@jillzhang
@侯垒
呵呵,谢谢两位:)   回复  引用  查看    

#6楼  2008-03-19 20:16 生鱼片      

支持   回复  引用  查看    

#7楼  2008-03-19 20:27 seyon      

又出现两篇,想这种UI倒是挺容易让人产生兴趣的   回复  引用  查看    

#8楼  2008-03-19 21:08 chegan      

好快,好好快   回复  引用  查看    

#9楼 [楼主] 2008-03-19 21:20 TerryLee      

@生鱼片
谢谢:)   回复  引用  查看    

#10楼 [楼主] 2008-03-19 21:21 TerryLee      

@seyon
呵呵,效果是比较酷,结合前面所讲的这些东西,可以做出非常炫的效果:)   回复  引用  查看    

#11楼 [楼主] 2008-03-19 21:21 TerryLee      

@chegan
呵呵,谢谢支持:)   回复  引用  查看    

#12楼  2008-03-21 16:35 niube' son [未注册用户]

看了搂住的介绍,说实在,这些东西真没十么好学的. 一点技术含量也没有.

你看看创建这些东西, 除了写一些XML,其他还有啥? 学这些东西,真还不如学photoshop好一点。   回复  引用    

#13楼 [楼主] 2008-03-21 22:19 TerryLee      

@niube' son
感觉到有些悲哀,如果认为Silverlight仅仅是为了实现一点很酷的效果,那就大错特错了。两个完全不是同一类型的东西放在一起比较,有点。。。

注意是xaml,不是xml,尽管格式上是。。。   回复  引用  查看    

#14楼  2008-03-24 17:39 zero.one      

怎样用程序控制图片不停的旋转呢?   回复  引用  查看    

#15楼 [楼主] 2008-03-24 21:13 TerryLee      

@zero.one
继续看下篇啊,下一篇里面有讲到!   回复  引用  查看    


标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-03-19 18:45 编辑过
 
另存  打印
 


导航

公告

  • 网名:TerryLee
  • 本名:李会军
  • 位置:中国北京 Ethos
  • 联系方式:
  • 访问我的个人主页

 MVP配置

 版权声明

  • 本站采用创作共用许可 署名,非商业

绿色通道

IT新闻

统计

与我联系

留言簿(322)

我的标签

随笔分类

随笔档案

个人站点

关注项目

好的网站

我的好友

搜索

积分与排名

阅读排行榜

评论排行榜