SVG Filters: How to Apply Them to HTML Elements

Filtros SVG: cómo aplicarlos a elementos HTML

Puede usar CSS3 para agregar desenfoque, sombra, brillo o contraste a un elemento. En general, hay diez filtros disponibles. El formato SVG también conoce los efectos de filtro. Parcialmente, estas opciones se superponen, por ejemplo, cuando se trata de desenfoque. Sin embargo, el formato SVG conoce varios filtros adicionales que CSS3 por sí solo no puede crear. Con poco esfuerzo, puede agregar filtros SVG a un elemento HTML.

¿Qué filtros SVG existen?

Mientras que CSS3 tiene un total de diez filtros diferentes, el formato SVG ofrece 19 de ellos. Por ejemplo, existe “”, que mezcla píxeles en una imagen con píxeles adyacentes. Esto crea un efecto borroso similar al desenfoque de movimiento en Photoshop. El uso de «» le permite aplicar un desenfoque gaussiano, mientras que «» se asegura de que los píxeles de una imagen se adelgacen o engrosen.

svg-filter_original_verdickung
Imagen original y el filtro “” aplicado

Puede utilizar el filtro “” para diferentes manipulaciones de color, por ejemplo, para modificar la saturación, el tono y el brillo de una imagen.

Los dos filtros “” y “” le permiten agregar efectos de iluminación como luz difusa o reflejada a una imagen. Con “”, “” o “”, puede definir diferentes fuentes de luz.

svg-filter_beleuchtung
Imagen con filtro de iluminación

Hay varios otros filtros, algunos de los cuales son bastante poco espectaculares, ««, que solo mueve una imagen, y algunos de los cuales son bastante especiales, como ««, que crea turbulencias y fractales.

Creación y aplicación de filtros SVG

Si desea aplicar filtros SVG a cualquier elemento HTML, todo lo que necesita hacer es configurar el filtro a través de SVG. Esto debe hacerse dentro de la sección “”. Este está hecho para elementos como patrones, flujos o filtros, es decir, elementos que no son visibles, pero se aplican a otros elementos. Además, los filtros deben colocarse dentro del elemento ««.

<svg>
  <defs>
    <filter id="blurryexample">
      <feConvolveMatrix order="20, 1" kernelMatrix="1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1" />
    </filter>
  </defs>
</svg>

En el ejemplo, se establece el filtro “”. El atributo «orden» define cuántos píxeles adyacentes en los ejes x e y deben incluirse. En el ejemplo, solo se mezclan los píxeles en el eje x, lo que crea un desenfoque de movimiento. Los valores definidos por «orden» forman una matriz: 20 veces 1 píxel en este ejemplo. “kernelMatrix” se utiliza para definir los valores de cada píxel de la matriz. Como nuestra matriz solo consta de una línea, es necesario definir 20 valores para esta línea. Los valores para otras líneas se establecerán divididos por una coma.

svg-filter_bewegungsunschaerfe
Imagen con desenfoque de movimiento

El filtro necesita una ID para ser aplicable a otros elementos dentro del documento HTML. Luego, debe transferir la ID del filtro SVG al atributo CSS3 «filtro ()».

img {
  filter: url(#motionblur);
}

En el ejemplo, el filtro se aplica a todos los elementos “”. Debe tener en cuenta el hecho de que el atributo «filtro» solo funciona con un prefijo de proveedor adecuado en algunos navegadores.

Si bien los navegadores modernos como Chrome y Firefox admiten la opción de aplicar filtros SVG a cualquier elemento, esto no funciona en Internet Explorer y el nuevo navegador Edge de Microsoft (todavía).

Combinar filtros y aplicarlos a los textos

Por supuesto, también puedes combinar filtros. Para hacerlo, simplemente configure múltiples filtros dentro de un elemento “”.

svg-filter_bewegungsunschaerfe-farbton
Imagen con desenfoque de movimiento y cambios de tono

<svg>
  <defs>
    <filter id="motionblur_huevalue">
      <feConvolveMatrix order="20, 1" kernelMatrix="1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1" />
      <feColorMatrix type="hueRotate" values="-90" />
    </filter>
  </defs>
</svg>

En el ejemplo, se combinan los filtros “” y “”. Este último se asegura de que la rotación de tono («hueRotate») de 90 grados se logre a través de «tipo».

svg-filter_bewegungsunschaerfe_text
Texto con desenfoque de movimiento

Como se mencionó al principio, los filtros no solo funcionan para imágenes, sino para todos los elementos HTML. Esto le permite crear efectos de texto interesantes. Cuando se aplica a un encabezado, por ejemplo, obtiene un efecto de desenfoque de movimiento.

Ejemplos en Codepen

(dpe)

#Filtros #SVG #cómo #aplicarlos #elementos #HTML

Publicaciones Similares

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *