Partilhar via


Como: Distorcer um elemento

Este exemplo mostra como usar um SkewTransform para distorcer um elemento. Uma distorção, também conhecida como corte, é uma transformação que estende o espaço de coordenadas de 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 inclinação dos eixos x e y e para inclinar o sistema de coordenadas atual ao longo desses eixos.

Para prever o efeito de uma transformação de inclinação, considere que AngleX distorce os valores do eixo x em relação ao sistema de coordenadas original. Portanto, para uma AngleX de 30, o eixo y gira 30 graus através da origem e distorce os valores em x- em 30 graus a partir dessa origem. Da mesma forma, um AngleY de 30 inclina os valores y da forma num ângulo de 30 graus a partir da origem. Note que este 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 Rectangle a partir de um ponto central de (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 inclinação horizontal de 45 graus a uma Rectangle de um ponto central de (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 inclinação vertical de 45 graus a um Rectangle a partir 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.

Ver também