freeCodeCamp/guide/portuguese/css/css3-2d-transforms/index.md

6.6 KiB

title localeTitle
CSS3 2d Transforms Transformações CSS3 2d

Transformações CSS3 2d

As transformações CSS3 permitem que você traduza, gire, dimensione e incline elementos.

Uma transformação é um efeito que permite que um elemento mude de forma, tamanho e posição.

O CSS3 suporta transformações 2D e 3D.

Suporte de Navegador para Transformações 2D

Os números na tabela especificam a primeira versão do navegador que suporta totalmente a propriedade.

Números seguidos por -ms-, -webkit-, -moz- ou -o- especificam a primeira versão que trabalhou com um prefixo.

| Propriedade | Chrome | IE | Firefox | Safari | Ópera | | --------------------------------------- | ---------------------- | ------------------ | ------------------- | -------------------- | -------------------------------------------- | | transformar | 36,0 4,0 -webkit- | 10,0 9,0 -ms- | 16,0 3,5 -moz- | 9,0 3,2 -Webkit- | 23,0 15,0 -webkit- 12,1 10,5 -o- | | transformação-origem (sintaxe de dois valores) | 36,0 4,0 -webkit- | 10,0 9,0 -ms- | 16,0 3,5 -moz- | 9,0 3,2 -webkit- | 23,0 15,0 -webkit- 12,1 10,5 -o- |

Transformações 2D CSS3

Métodos:

  • translate()
  • rotate()
  • scale()
  • skewX()
  • skewY()
  • matrix()

O método translate ()

O método translate() move um elemento de sua posição atual (de acordo aos parâmetros dados para o eixo X e o eixo Y).

O exemplo a seguir move o elemento <div> 50 pixels para a direita e 100 pixels abaixo de sua posição atual:

Exemplo:

div { 
  -ms-transform: translate(50px, 100px); /* IE 9 */ 
  -webkit-transform: translate(50px, 100px); /* Safari */ 
  transform: translate(50px, 100px); 
 } 

O método rotate ()

O método rotate() rotaciona um elemento no sentido horário ou anti-horário de acordo com um determinado grau.

O exemplo a seguir gira o elemento <div> no sentido horário com 20 graus:

Exemplo:

div { 
  -ms-transform: rotate(20deg); /* IE 9 */ 
  -webkit-transform: rotate(20deg); /* Safari */ 
  transform: rotate(20deg); 
 } 

Usando valores negativos irá girar o elemento no sentido anti-horário.

O exemplo a seguir gira o elemento <div> no sentido anti-horário com 20 graus:

Exemplo:

div { 
  -ms-transform: rotate(-20deg); /* IE 9 */ 
  -webkit-transform: rotate(-20deg); /* Safari */ 
  transform: rotate(-20deg); 
 } 

O método de escala ()

O método scale() aumenta ou diminui o tamanho de um elemento (de acordo com os parâmetros fornecidos para a largura e altura).

O exemplo a seguir aumenta o elemento <div> para duas vezes largura original e três vezes a sua altura original:

Exemplo:

div { 
  -ms-transform: scale(2, 3); /* IE 9 */ 
  -webkit-transform: scale(2, 3); /* Safari */ 
  transform: scale(2, 3); 
 } 

O exemplo a seguir diminui o elemento <div> para metade do original largura e altura:

Exemplo:

div { 
  -ms-transform: scale(0.5, 0.5); /* IE 9 */ 
  -webkit-transform: scale(0.5, 0.5); /* Safari */ 
  transform: scale(0.5, 0.5); 
 } 

O método skewX ()

O método skewX() inclina um elemento ao longo do eixo X pelo ângulo dado.

O exemplo a seguir inclina o elemento <div> 20 graus ao longo do eixo X:

Exemplo:

div { 
  -ms-transform: skewX(20deg); /* IE 9 */ 
  -webkit-transform: skewX(20deg); /* Safari */ 
  transform: skewX(20deg); 
 } 

O método skewY ()

O método skewY() inclina um elemento ao longo do eixo Y pelo ângulo dado.

O exemplo a seguir inclina o elemento <div> 20 graus ao longo do eixo Y:

Exemplo:

div { 
  -ms-transform: skewY(20deg); /* IE 9 */ 
  -webkit-transform: skewY(20deg); /* Safari */ 
  transform: skewY(20deg); 
 } 

O método skew ()

O método skew() inclina um elemento ao longo dos eixos X e Y pelos ângulos dados.

O exemplo a seguir inclina o elemento <div> 20 graus ao longo do eixo X e 10 graus ao longo do eixo Y:

Exemplo:

div { 
  -ms-transform: skew(20deg, 10deg); /* IE 9 */ 
  -webkit-transform: skew(20deg, 10deg); /* Safari */ 
  transform: skew(20deg, 10deg); 
 } 

Se o segundo parâmetro não for especificado, ele terá um valor zero. Então, o seguinte exemplo inclina o elemento <div> 20 graus ao longo do eixo X:

Exemplo:

div { 
  -ms-transform: skew(20deg); /* IE 9 */ 
  -webkit-transform: skew(20deg); /* Safari */ 
  transform: skew(20deg); 
 } 

O método matrix ()

O método matrix() combina todos os métodos de transformação 2D em um.

O método matrix () utiliza seis parâmetros, contendo funções matemáticas, que permite girar, dimensionar, mover (transladar) e inclinar elementos.

Os parâmetros são os seguintes: matriz (scaleX (), skewY (), skewX (), escalaY (), translateX (), translateY ())

Exemplo:

div { 
  -ms-transform: matrix(1, -0.3, 0, 1, 0, 0); /* IE 9 */ 
  -webkit-transform: matrix(1, -0.3, 0, 1, 0, 0); /* Safari */ 
  transform: matrix(1, -0.3, 0, 1, 0, 0); 
 } 

Propriedades de Transformação CSS3

A tabela a seguir lista todas as propriedades de transformação 2D:

| Propriedade | Descrição | | ---------------- | -------------------------------------------------- ------- | | transformar | Aplica uma transformação 2D ou 3D a um elemento | | transformação-origem | Permite que você mude a posição nos elementos transformados |

Métodos de transformação 2D

| Função | Descrição | | --------------------- | -------------------------------------------------- ----------------------- | | matriz (n, n, n, n, n) | Define uma transformação 2D, usando uma matriz de seis valores | | translate (x, y) | Define uma tradução 2D, movendo o elemento ao longo dos eixos X e Y | | translateX (n) | Define uma tradução 2D, movendo o elemento ao longo do eixo X | | translateY (n) | Define uma tradução 2D, movendo o elemento ao longo do eixo Y | | escala (x, y) | Define uma transformação em escala 2D, alterando os elementos width e height | | escalaX (n) | Define uma transformação em escala 2D, alterando a largura do elemento | | escalaY (n) | Define uma transformação em escala 2D, alterando a altura do elemento | | rodar (ângulo) | Define uma rotação 2D, o ângulo é especificado no parâmetro | | inclinação (ângulo x, ângulo y) | Define uma transformação de inclinação 2D ao longo dos eixos X e Y | | skewX (ângulo) | Define uma transformação de inclinação 2D ao longo do eixo X | | skewY (ângulo) | Define uma transformação de inclinação 2D ao longo do eixo Y |

Mais Informações: