一步一步学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°角:
 
如果我们想指定旋转点的话,可以通过属性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°:
 

缩放变换(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>
运行后效果如下所示:
 

倾斜变换(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>
运行后的效果如下:
 

移动变换(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>
运行后效果如下所示:
 

变换组(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>
运行后效果如下所示:
 

结束语

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
















本文转自lihuijun51CTO博客,原文链接: http://blog.51cto.com/terrylee/67281 ,如需转载请自行联系原作者

相关文章
|
存储 缓存 安全
一文讲透认证授权的那些事
权限管理一直都是初级程序员学习的一大重点,也是一大难点,有单点登录,有联合登录,有session有Token,有各种权限框架,还有什么是RBAC,以及分布式下如何做权限管理。
1146 0
|
传感器 人工智能 安全
人工智能与物联网:智能家居的新时代
【10月更文挑战第31天】随着科技的发展,人工智能(AI)和物联网(IoT)的融合正引领我们进入全新的智能家居时代。本文探讨了这一技术趋势如何改变生活方式,提升家居的便捷性、高效性和安全性,并展望了未来的挑战和前景。
|
11月前
|
存储 Linux API
深入探索Android系统架构:从内核到应用层的全面解析
本文旨在为读者提供一份详尽的Android系统架构分析,从底层的Linux内核到顶层的应用程序框架。我们将探讨Android系统的模块化设计、各层之间的交互机制以及它们如何共同协作以支持丰富多样的应用生态。通过本篇文章,开发者和爱好者可以更深入理解Android平台的工作原理,从而优化开发流程和提升应用性能。
|
SQL 分布式计算 Hadoop
|
人工智能
AIGC的出现对社会有啥影响
AIGC的出现对社会有啥影响
867 39
|
存储 SQL Java
规则引擎深度对比,LiteFlow vs Drools! 下
规则引擎深度对比,LiteFlow vs Drools! 下
|
缓存 Docker 容器
Docker build 命令详解
Docker build 命令详解
533 0
|
弹性计算 负载均衡 小程序
阿里云免费云服务器,新用户免费体验三个月
阿里云免费云服务器,新用户免费体验三个月,阿里云服务器免费试用申请链接入口 ,阿里云个人用户和企业用户均可申请免费试用,最高可以免费使用3个月,阿里云服务器网分享阿里云服务器免费试用申请入口链接及云服务器配置
1094 0
|
算法 安全 Unix
翁恺C语言程序设计网课笔记合集
学习自翁恺C语言程序设计网课。
765 0
翁恺C语言程序设计网课笔记合集