Compartilhar via


Como distorcer um elemento

Este exemplo mostra como usar um SkewTransform para distorcer um elemento. Uma distorção, também conhecida como cisalhamento, é uma transformação que alonga o espaço de coordenadas de uma maneira não uniforme. Um uso típico de um SkewTransform é para simular profundidade 3D em objetos 2D.

Use as propriedades CenterX e CenterY para especificar o ponto central do SkewTransform.

Use as propriedades AngleX e AngleY para especificar o ângulo de distorção do eixo x e do eixo y e distorcer o sistema de coordenadas atual ao longo desses eixos.

Para prever o efeito de uma distorção, considere que AngleX distorce os valores do eixo x relativos ao sistema original de coordenadas. Portanto, para um AngleX de 30, o eixo y gira 30 graus pela origem e inclina os valores em x em 30 graus a partir dessa origem. Da mesma forma, um AngleY de 30 inclina os valores y da figura em 30 graus a partir da origem. Observe que esse não é o mesmo efeito que traduzir (mover) o sistema de coordenadas em 30 graus em x ou y-.

O exemplo a seguir aplica uma inclinação horizontal de 45 graus a um Rectangle a partir de um ponto central em (0,0).

Exemplo

<Rectangle 
  Height="50" Width="50" Fill="#CCCCCCFF" 
  Stroke="Blue" StrokeThickness="2"
  Canvas.Left="100" Canvas.Top="100">
  <Rectangle.RenderTransform>

     <!-- Applies a horizontal skew of 45 degrees 
          from a center point of (0,0). -->             
    <SkewTransform CenterX="0" CenterY="0" AngleX="45" AngleY="0" />
  </Rectangle.RenderTransform>
</Rectangle>

O exemplo a seguir aplica uma distorção horizontal de 45 graus a um Rectangle de um ponto central (25,25).

<Rectangle Height="50" Width="50" Fill="#CCCCCCFF"
  Canvas.Left="100" Canvas.Top="100" 
  Stroke="Blue" StrokeThickness="2">
  <Rectangle.RenderTransform>
  
     <!-- Applies a horizontal skew of 45 degrees 
          from a center point of (25,25). -->  
    <SkewTransform CenterX="25" CenterY="25" AngleX="45" AngleY="0" />
  </Rectangle.RenderTransform>
</Rectangle>

O exemplo a seguir aplica uma distorção vertical de 45 graus a um Rectangle de um ponto central de (25,25).

<Rectangle Height="50" Width="50" Fill="#CCCCCCFF" 
  Stroke="Blue" StrokeThickness="2"
  Canvas.Left="100" Canvas.Top="100">
  <Rectangle.RenderTransform>
  
     <!-- Applies a vertical skew of 45 degrees 
          from a center point of (25,25). -->             
    <SkewTransform CenterX="25" CenterY="25" AngleX="0" AngleY="45" />
  </Rectangle.RenderTransform>
</Rectangle> 

A ilustração a seguir mostra as diferentes distorções usadas neste exemplo.

exemplos de SkewTransform
Os três exemplos de SkewTransform ilustrados

Para obter o exemplo completo, consulte exemplo de transformações 2D.

Consulte também