Filtros de imagem com GD – Sépia, brilho, contraste, blur, etc

Atenção! Essa postagem foi escrita há mais de 2 anos. Na informática tudo evolui muito rápido e algumas informações podem estar desatualizadas. Embora o conteúdo possa continuar relevante, lembre-se de levar em conta a data de publicação enquanto estiver lendo. Caso tenha sugestões para atualizá-la, não deixe de comentar!

Prefácio

Sempre gostei de trabalhar com a biblioteca GD. Recentemente, durante algumas pesquisas, descobri que há um jeito de aplicar efeitos nas imagens, e é isso que veremos hoje.

Conceito

A função que utilizaremos é a imagefilter(). Com ela podemos aplicar diversos filtros nas imagens como sépia, inversão de cores, preto e branco, alteração de brilho e contraste, coloração, embaçar (emboss), blur e muitos outros. A seguir veremos alguns exemplos do que pode ser feito com esta função.

Mão na massa

Como eu gosto muito da Alemanha, resolvi pegar essa imagem de um castelo de lá para usar como exemplo.

Todos os códigos vistos abaixo assumem que a imagem já estará aberta, dentro da variável $img, conforme o código abaixo:

[php]<?php
$img = imagecreatefromjpeg(‘imagem.jpg’);
?>[/php]

Negativo

Para aplicar o filtro negativo, você deve utilizar a constante pré-definida chamada IMG_FILTER_NEGATE.

[php]<?php
imagefilter($img, IMG_FILTER_NEGATE);
?>[/php]

Resultado:

Preto e branco – Desaturar (Desaturate)

A constante se chama IMG_FILTER_GRAYSCALE. Com ela você pode desaturar completamente a imagem.

[php]<?php
imagefilter($img, IMG_FILTER_GRAYSCALE);
?>[/php]

Brilho (Brightness)

É possível alterar o brilho da imagem utilizando a constante IMG_FILTER_BRIGHTNESS, mas para tanto será necessário passar mais um parâmetro, que irá indicar o nível na alteração do brilho.

Seguem dois exemplos, o primeiro aumentando o brilho e o segundo diminuindo.

[php]<?php
imagefilter($img, IMG_FILTER_BRIGHTNESS, 80);
// …
imagefilter($img, IMG_FILTER_BRIGHTNESS, -80);
?>[/php]

Contraste

Utilizando a constante IMG_FILTER_CONTRAST você pode alterar o contraste. É possível atingir resultados bastante interessantes utilizando um valor negativo.

[php]<?php
imagefilter($img, IMG_FILTER_CONTRAST, -50);
?>[/php]

Colorir (Colorize)

Para aplicar uma camada de cor sobre a imagem, você pode utilizar a constante IMG_FILTER_COLORIZE.

[php]<?php
imagefilter($img, IMG_FILTER_COLORIZE, 255,175,0);
?>[/php]

Detecção de bordas (Edge detect)

Efeito bem maluco, que encontra as bordas da imagem e as desenha. A constante utilizada é a IMG_FILTER_EDGEDETECT.

[php]<?php
imagefilter($img, IMG_FILTER_EDGEDETECT);
?>[/php]

Entalhe (Emboss)

Não confunda o “emboss” com o “embaçar, desfocar (blur)”. Com a constante você consegue gerar um efeito bacana.

[php]<?php
imagefilter($img, IMG_FILTER_EMBOSS);
?>[/php]

Gaussian Blur

Este comando dispensa comentários. A constante é IMG_FILTER_GAUSSIAN_BLUR.

[php]<?php
imagefilter($img, IMG_FILTER_GAUSSIAN_BLUR);
?>[/php]

Blur

Aplicar um Blur normal. Para tanto, utilize a constanteIMG_FILTER_SELECTIVE_BLUR.

[php]<?php
imagefilter($img, IMG_FILTER_SELECTIVE_BLUR);
?>[/php]

Sketch

Com a constante IMG_FILTER_MEAN_REMOVAL é possível atingir um efeito conhecido como “Sketch”, que é algo parecido com um rascunho ou algo passado apenas a lápis.
Surgem resultados bacanas quando você remove a saturação da imagem antes de aplicar este efeito.

[php]<?php
imagefilter($img, IMG_FILTER_MEAN_REMOVAL);
?>[/php]

Smooth

Aplique um filtro de suavização na imagem utilizando IMG_FILTER_SMOOTH.

[php]<?php
imagefilter($img, IMG_FILTER_SMOOTH, 90);
?>[/php]

Conclusão

A biblioteca GD é bastante completa. Muitos efeitos estão disponíveis e vai da imaginação de cada um aplicá-los como bem entender. É possível fazer muita coisa legal, mas sempre tomando cuidado para não estourar a memória do servidor.

Peço perdão a todos vocês pela demora em postar mais um tutorial, mas é que a minha vida está bastante corrida. Em breve terem muito mais tempo pra escrever… E trarei muitas novidades!
Mandem dúvidas e sugestões!

Um abraço e fiquem com Deus!