Windows Phone开发(18):变形金刚第九季——变换 转:http://blog.csdn.net/tcjiaan/article/details/7385056...

变换不是一个好理解的概念,不是吓你,它涉及很多有关代数,几何,以及线性代数的知识。怎么?被我的话吓怕了?不用怕,尽管我们未必能够理解这些概念,只要我们知道怎么使用它们就是了。
其实,变换就是平面上一种坐标变化,听起来很抽象,但,只要我把它说具体了,你就会觉得不抽象了。
相信各位如果玩过Photoshop,或者其它的绘图软件,应该知道什么叫做旋转,什么叫做倾斜,什么叫做平移……
是的,这些就是我们今天要聊的变换,好了,现在你是不是可以坐下来喝一杯珍珠奶茶来放松一下呢?哦,对了,珍珠奶茶尽量少喝哦。

好,闲话少吹,开始今天的表演。

 

一、TranslateTransform。


这个应该算是最好理解了,就是平移嘛,相信大家不会陌生的,学习解析几何的时候是不是经常玩啊?它无非就两个参数——X和Y,分别是平面上两个方向的位移。

上图中的三个矩形,它们的位置是一样的,但经过平移后,看起来它们好像不在同一个位置了。

[html]  view plain copy print ?
  1. <Canvas>  
  2.     <!-- 三个矩形在Canvas中的位置是相同的,但经过平移变换后,  
  3.          看起来,好像并不在同一个位置了。      
  4.     -->  
  5.     <Rectangle Width="120" Height="120"  
  6.                Fill="DarkGreen"  
  7.                Canvas.ZIndex="0"  
  8.                Canvas.Top="15"  
  9.                Canvas.Left="15">  
  10.         <Rectangle.RenderTransform>  
  11.             <TranslateTransform X="20" Y="20"/>  
  12.         </Rectangle.RenderTransform>  
  13.     </Rectangle>  
  14.     <Rectangle Width="120" Height="120"  
  15.                Fill="Yellow"  
  16.                Canvas.ZIndex="1"  
  17.                Canvas.Top="15"  
  18.                Canvas.Left="15">  
  19.         <Rectangle.RenderTransform>  
  20.             <TranslateTransform X="80" Y="80"/>  
  21.         </Rectangle.RenderTransform>  
  22.     </Rectangle>  
  23.     <Rectangle Width="120" Height="120"  
  24.                Fill="Blue"  
  25.                Canvas.ZIndex="2"  
  26.                Canvas.Top="15"  
  27.                Canvas.Left="15">  
  28.         <Rectangle.RenderTransform>  
  29.             <TranslateTransform X="140" Y="140"/>  
  30.         </Rectangle.RenderTransform>  
  31.     </Rectangle>  
  32. </Canvas>  


 

二、RotateTransform。


这个家伙就是用来旋转元素的,Angle属性就是旋转的角度,不用我解释了吧,小学生的知识。另外,有两个属性要注意一下:
CenterX:旋转中心的X坐标,这个坐标是相对于目标的左上角的,例如,你要让一个矩形转旋转,默认的情况,旋转中心就是0,就是矩形的左上角;
CenterY:和上面一样了,只是Y坐标的点。

这两个旋转点不太好把握,如果我们希望比较的相对定位,可以通过UIElement的RenderTransformOrigin属性来改动旋转原点,这个点坐标是相对于元素可视化的边界的,即0到1之间的值,如:
1、左上角:(0,0)
2、左下角:(1,1)
3、顶部居中:(0.5,0)
4、底部居中:(0.5,1)


上图中的三个图象,旋转中心都在底部居中,只是旋转的角度不同而已。

[html]  view plain copy print ?
  1. <Grid>  
  2.     <Image Margin="289,42,241,143" Source="/TransFormSample;component/1.jpg" Stretch="Uniform" Opacity="0.3"  
  3.            RenderTransformOrigin="0.5,1">  
  4.         <Image.RenderTransform>  
  5.             <RotateTransform Angle="-60"/>  
  6.         </Image.RenderTransform>  
  7.     </Image>  
  8.     <Image Margin="289,42,241,143" Source="/TransFormSample;component/1.jpg" Stretch="Uniform" Opacity="0.6"  
  9.            RenderTransformOrigin="0.5,1">  
  10.         <Image.RenderTransform>  
  11.             <RotateTransform Angle="0"/>  
  12.         </Image.RenderTransform>  
  13.     </Image>  
  14.     <Image Margin="289,42,241,143" Source="/TransFormSample;component/1.jpg" Stretch="Uniform"  
  15.            RenderTransformOrigin="0.5,1">  
  16.         <Image.RenderTransform>  
  17.             <RotateTransform  Angle="60"/>  
  18.         </Image.RenderTransform>  
  19.     </Image>  
  20. </Grid>  


 

 

三、ScaleTransform。


与上面的旋转变换相似,但这个是用于放大和缩小的,它也有一个中心点,就是缩放中心,同样,它的默认值是目标元素的左上角,至于以哪个点为缩放中心,你就自己调整中心坐标了。


 

上图中为了能清楚看到缩放的效果,后面两个图象都设置透明度。

[html]  view plain copy print ?
  1. <Grid>  
  2.     <Image Source="/TransFormSample;component/1.jpg" Stretch="Uniform" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="130"  
  3.            Canvas.ZIndex="0" Opacity="0.09">  
  4.         <Image.RenderTransform>  
  5.             <ScaleTransform CenterX="110" CenterY="180" ScaleX="2" ScaleY="2"/>  
  6.         </Image.RenderTransform>  
  7.     </Image>  
  8.   
  9.     <Image Source="/TransFormSample;component/1.jpg" Stretch="Uniform" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="130"  
  10.            Canvas.ZIndex="1" Opacity="0.2">  
  11.         <Image.RenderTransform>  
  12.             <ScaleTransform CenterX="120" CenterY="150" ScaleX="1.6" ScaleY="1.6"/>  
  13.         </Image.RenderTransform>  
  14.     </Image>  
  15.   
  16.     <Image Source="/TransFormSample;component/1.jpg" Stretch="Uniform" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="130"  
  17.            Canvas.ZIndex="2"/>  
  18. </Grid>  


 

 

四、SkewTransform。


扭曲变换,可以说是倾斜,它的确实现了倾斜的效果。
同样它也有一个中心点,与上面的相似,AngleX是沿X轴扭曲的角度,AngleY就是沿Y轴扭曲。

 

[html]  view plain copy print ?
  1. <Grid>  
  2.     <Image Source="/TransFormSample;component/1.jpg" HorizontalAlignment="Center"  
  3.            VerticalAlignment="Center"  
  4.            Margin="100"/>  
  5.     <Image Source="/TransFormSample;component/1.jpg" HorizontalAlignment="Center"  
  6.            VerticalAlignment="Center"  
  7.            Margin="100" Opacity="0.3">  
  8.         <Image.RenderTransform>  
  9.             <SkewTransform CenterX="0" CenterY="-200" AngleX="30" AngleY="0"/>  
  10.         </Image.RenderTransform>  
  11.     </Image>  
  12.     <Image Source="/TransFormSample;component/1.jpg" HorizontalAlignment="Center"  
  13.            VerticalAlignment="Center"  
  14.            Margin="100" Opacity="0.3">  
  15.         <Image.RenderTransform>  
  16.             <SkewTransform CenterX="0" CenterY="-550" AngleX="-15" AngleY="0"/>  
  17.         </Image.RenderTransform>  
  18.     </Image>  
  19.   
  20. </Grid>  


 

 

五、TransformGroup。


严格上说,这个不算是一种变换,但它可以实现把N个变换叠加在一起。

 

[html]  view plain copy print ?
  1. <Grid>  
  2.     <Image Source="/TransFormSample;component/1.jpg"  
  3.            Stretch="Uniform" Margin="65,98,472,92" />  
  4.     <Image Source="/TransFormSample;component/1.jpg"  
  5.            Stretch="Uniform" Margin="65,98,472,92" >  
  6.         <Image.RenderTransform>  
  7.             <TransformGroup>  
  8.                 <TranslateTransform X="270" Y="30"/>  
  9.                 <ScaleTransform ScaleX="1.5" ScaleY="1.5" CenterX="185" CenterY="280"/>  
  10.                 <RotateTransform CenterX="400" CenterY="60" Angle="18"/>  
  11.             </TransformGroup>  
  12.         </Image.RenderTransform>  
  13.     </Image>  
  14.   
  15. </Grid>  


 

 

 

 

六、CompositeTransform。


这与上面的TransformGroup有点像,但你也看到,它不是把多个变换叠加,而是同时应用多种变换方式,但它是有顺序的。
缩放 ->扭曲->旋转->位移

 

 

[html]  view plain copy print ?
  1. <Grid>  
  2.     <Image Source="/TransFormSample;component/1.jpg" Stretch="Uniform" Margin="48,68,492,131" />  
  3.     <Image Source="/TransFormSample;component/1.jpg" Stretch="Uniform" Margin="48,68,492,131"  
  4.            Opacity="0.5">  
  5.         <Image.RenderTransform>  
  6.             <CompositeTransform  
  7.                 CenterX="250" CenterY="185"  
  8.                 Rotation="45"  
  9.                 SkewX="15" SkewY="15"  
  10.                 ScaleX="1.2" ScaleY="1.2"  
  11.                 TranslateX="230" TranslateY="200"/>  
  12.         </Image.RenderTransform>  
  13.     </Image>  
  14.   
  15. </Grid>  


 

 

 

七、MatrixTrasform。


这是最复杂的一种变换,它是一个3乘3的矩阵,但是,由于它第3列为0,0,1,所以,其实我们只需设置6个值就够了。它们分别是:
 m11       m12     0
 m21       m22     0
 offsetX  offsetY  1
可能是offsetX和offsetY比较容易看出来就是位移,那前面几呢?我们可以猜,默认值为1的就是缩放,因为不可能为0倍,剩下两个就是X轴和Y轴方向的倾斜值了。

其实,我也是通过写代码来找规律的,保持其实参数不变单独改变一个参数来观察图形的变化就能找到答案了。

        m11 ——X轴缩放
        m12 ——Y轴上倾斜
        m21 ——X轴上倾斜
        m22——Y轴缩放
        offsetX ——X轴上的位移
        offsetY ——Y轴上的位移

 

 

[html]  view plain copy print ?
  1. <Grid>  
  2.     <Image Height="206" HorizontalAlignment="Left" Margin="73,104,0,0" Name="image1" Stretch="Uniform" VerticalAlignment="Top" Width="139" Source="/TransFormSample;component/1.jpg">  
  3.         <Image.RenderTransform>  
  4.             <MatrixTransform Matrix="2,0,0,1,12,6"/>  
  5.         </Image.RenderTransform>  
  6.     </Image>  
  7.     <Image Height="206" HorizontalAlignment="Left" Margin="122,424,0,0" Name="image2" Source="/TransFormSample;component/1.jpg" Stretch="Uniform" VerticalAlignment="Top" Width="136" >  
  8.         <Image.RenderTransform>  
  9.             <MatrixTransform Matrix="1,-1,0,1,0,137"/>  
  10.         </Image.RenderTransform>  
  11.     </Image>  
  12.     <Image Height="206" HorizontalAlignment="Left" Margin="293,12,0,0" Name="image3" Source="/TransFormSample;component/1.jpg" Stretch="Uniform" VerticalAlignment="Top" Width="139" >  
  13.         <Image.RenderTransform>  
  14.             <MatrixTransform Matrix="1,0.6,0,1,0,0"/>  
  15.         </Image.RenderTransform>  
  16.     </Image>  
  17.     <Image Height="206" HorizontalAlignment="Left" Margin="269,424,0,0" Name="image4" Source="/TransFormSample;component/1.jpg" Stretch="Uniform" VerticalAlignment="Top" Width="139" >  
  18.         <Image.RenderTransform>  
  19.             <MatrixTransform Matrix="1,1,0,1,0,0"/>  
  20.         </Image.RenderTransform>  
  21.     </Image>  
  22. </Grid>  


 

如何学习有关变换的知识呢?个人推荐一种方法,很有效,那就是——乱来。
真的,乱来的学习效果很好的,呵呵。

你可以写好代码,然后不断地改变数值,看看有什么变化,多试几次你就会找到规律。

转载于:https://www.cnblogs.com/songtzu/archive/2012/07/24/2607150.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值