成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Windows Phone開發(18):變形金剛第九季—變換

移動開發
相信各位如果玩過Photoshop,或者其它的繪圖軟件,應該知道什么叫做旋轉,什么叫做傾斜,什么叫做平移……是的,這些就是我們今天要聊的變換,好了,現在你是不是可以坐下來喝一杯珍珠奶茶來放松一下呢?哦,對了,珍珠奶茶盡量少喝哦。

變換不是一個好理解的概念,不是嚇你,它涉及很多有關代數,幾何,以及線性代數的知識。怎么?被我的話嚇怕了?不用怕,盡管我們未必能夠理解這些概念,只要我們知道怎么使用它們就是了。
其實,變換就是平面上一種坐標變化,聽起來很抽象,但,只要我把它說具體了,你就會覺得不抽象了。
相信各位如果玩過Photoshop,或者其它的繪圖軟件,應該知道什么叫做旋轉,什么叫做傾斜,什么叫做平移……
是的,這些就是我們今天要聊的變換,好了,現在你是不是可以坐下來喝一杯珍珠奶茶來放松一下呢?哦,對了,珍珠奶茶盡量少喝哦。

好,閑話少吹,開始今天的表演。

一、TranslateTransform。

這個應該算是***理解了,就是平移嘛,相信大家不會陌生的,學習解析幾何的時候是不是經常玩啊?它無非就兩個參數——X和Y,分別是平面上兩個方向的位移。

上圖中的三個矩形,它們的位置是一樣的,但經過平移后,看起來它們好像不在同一個位置了。

  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)


上圖中的三個圖象,旋轉中心都在底部居中,只是旋轉的角度不同而已。

  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> 

 別走開,下頁繼續深入介紹

 

 #p#

 

三、ScaleTransform。

與上面的旋轉變換相似,但這個是用于放大和縮小的,它也有一個中心點,就是縮放中心,同樣,它的默認值是目標元素的左上角,至于以哪個點為縮放中心,你就自己調整中心坐標了。

上圖中為了能清楚看到縮放的效果,后面兩個圖象都設置透明度。

  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.     <Image Source="/TransFormSample;component/1.jpg" Stretch="Uniform" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="130" 
  9.            Canvas.ZIndex="1" Opacity="0.2"
  10.         <Image.RenderTransform> 
  11.             <ScaleTransform CenterX="120" CenterY="150" ScaleX="1.6" ScaleY="1.6"/> 
  12.         </Image.RenderTransform> 
  13.     </Image> 
  14.     <Image Source="/TransFormSample;component/1.jpg" Stretch="Uniform" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="130" 
  15.            Canvas.ZIndex="2"/> 
  16. </Grid> 

四、SkewTransform。

扭曲變換,可以說是傾斜,它的確實現了傾斜的效果。

同樣它也有一個中心點,與上面的相似,AngleX是沿X軸扭曲的角度,AngleY就是沿Y軸扭曲。

  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. </Grid> 

五、TransformGroup。

嚴格上說,這個不算是一種變換,但它可以實現把N個變換疊加在一起。

  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. </Grid> 

六、CompositeTransform。

這與上面的TransformGroup有點像,但你也看到,它不是把多個變換疊加,而是同時應用多種變換方式,但它是有順序的。
縮放 ->扭曲->旋轉->位移

  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. </Grid>

 別走開,下頁繼續深入介紹

 #p#

七、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軸上的位移

  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> 

如何學習有關變換的知識呢?個人推薦一種方法,很有效,那就是——亂來。
真的,亂來的學習效果很好的,呵呵。

你可以寫好代碼,然后不斷地改變數值,看看有什么變化,多試幾次你就會找到規律。

責任編輯:閆佳明 來源: oschina
相關推薦

2011-08-09 15:20:38

2011-07-22 09:03:20

FTTHPONEPON

2009-07-13 18:11:53

2012-02-23 00:22:55

2009-07-24 16:52:47

2015-08-04 09:22:37

2009-07-09 19:01:23

2021-04-12 09:47:08

機器人人工智能編程

2011-12-16 15:34:15

IaaS云計算變形金剛

2011-07-06 09:13:55

服務器Watson變形金剛

2009-06-25 08:57:15

木馬網絡安全金山毒霸

2012-05-21 15:41:40

2017-07-25 08:21:05

2011-06-09 17:51:29

聯想一體機

2012-12-10 11:32:12

打印機

2011-07-25 10:50:02

水晶石CG

2014-05-20 10:59:32

2019-08-13 16:40:14

2022-03-11 13:33:50

人工智能神經網絡計算機視覺

2013-07-30 12:37:56

Windows PhoWindows Pho
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美精品v | 超碰操 | 黑人一级片视频 | 欧美jizzhd精品欧美巨大免费 | 日本黄色大片免费 | 一区二区三区日本 | 91精品国产91久久综合桃花 | a在线视频观看 | 国产精品久久久久久久久久久免费看 | 人操人人干人 | 97超碰免费| 中文字幕日韩欧美 | av中文字幕在线播放 | 日韩一区和二区 | 91国内精品久久 | 精品无码久久久久久国产 | 日韩免费电影 | 日韩精品在线观看免费 | 一级黄色片美国 | 国产精品久久久久久久久久久久久 | 成人福利在线观看 | 狠狠久 | 97伦理| 成人免费视频网站在线看 | 日韩视频―中文字幕 | 国产精品久久久久久久久久久久 | 综合婷婷 | 成人黄色av网址 | 秋霞国产 | 成人在线观看免费观看 | 日韩一区在线播放 | 鲁一鲁资源影视 | 一区二区三区国产好 | 久精品视频 | 中文字幕视频在线观看免费 | 成人在线免费电影 | 成年人在线观看视频 | 国产精品xxxx | 毛片久久久 | 成年人黄色免费视频 | 欧美中文字幕 |