¿Puedes agregar ruido a un gradiente de CSS3?

¿Es posible agregar ruido a un degradado en CSS?

Aquí está mi código para un degradado radial:

body { color: #575757; font: 14px/21px Arial, Helvetica, sans-serif; background-color: #2f3b4b; background: -moz-radial-gradient(center 45deg, circle closest-corner, #2f3b4b 0%, #3e4f63 100%); background: -webkit-gradient(radial, center center, 10, center center, 900, from(#2f3b4b), to(#3e4f63)); } 

¿Qué agregaría a eso para tener ruido encima, para darle textura?

No hay forma actual en css para agregar ‘ruido’ a un fondo.

Una solución alternativa sería crear un ruido png transparente en su editor gráfico. A continuación, aplique ese gráfico como fondo a un

. Debería colocar ese

sobre toda el área del que debería dar la apariencia de un degradado con ruido.

Esta es, de lejos, la mejor manera de implementar esto sin problemas. Es puramente CSS y muy simple de hacer, sin archivos adicionales, nada. Bueno, no es la mejor manera posible, pero funciona muy bien, es muy confiable (nunca falló cuando se prueba en navegadores muy antiguos) y muy rápido de cargar.

Lo encontré hace unos meses y lo usaste desde entonces, simplemente copia y pega este código en tu CSS.

 background-image: url(); 

Luego agrega tu color de fondo

 background-color:#0094d0; 

Demostración: JSFiddle

Fuente: https://coderwall.com/p/m-uwvg

Puede usar un URI de datos dentro de su CSS para generar ruido de forma programática sin necesidad de un enlace a un archivo de imagen externo.

Ejemplo aquí , vea la fuente para ver cómo se ha hecho.

Publicación de blog con código descargable aquí

Sí, actualmente no existe un enfoque basado en CSS para las texturas de ruido. Sin embargo, si está empeñado en un enfoque programático (en lugar de basado en imágenes), podría intentar usar el canvas HTML5. Aquí hay un tutorial sobre cómo generar ruido usando JavaScript -> Crear ruido en el canvas de HTML5

Sin embargo, hacer el enfoque Canvas resultará en una experiencia mucho más lenta para sus visitantes, porque A) JavaScript es un lenguaje interpretado, y B) escribir gráficos usando JS es más lento.

Por lo tanto, a menos que intentes establecer un punto usando HTML5, me quedaré con una imagen. Será más rápido (para que lo haga y para que los usuarios carguen), y tendrá un grado de control más fino sobre la apariencia.

En aras de la novedad, aquí hay un poco de ruido de CSS puro sin usar un URI de datos (aunque parece que solo funciona en webkit):

 #box { width:250px; height:250px; position:relative; background-size:55px 10px; background-repeat: repeat; background-image: -webkit-repeating-radial-gradient(1% 21%, closest-corner, rgba(255,0,255,.5), rgba(0,255,255,.5), rgba(0,0,0,1) 1.7%), -webkit-repeating-radial-gradient(51% 51%, closest-corner, rgba(255,255,255,1), rgba(255,255,255,1), rgba(0,255,0,1) 10%); } #box::before { content:''; width:100%; height:100%; position:absolute; mix-blend-mode:exclusion; background-size:12px 22px; background-repeat: repeat; background-image: -webkit-repeating-radial-gradient(61% 21%, closest-corner, rgba(255,255,255,1), rgba(0,255,0,.5), rgba(3,0,255,1) 20%), -webkit-repeating-radial-gradient(91% 51%, closest-corner, rgba(255,255,255,1), rgba(255,255,1,.5), rgba(055,255,255,1) 20%); left:0; z-index:998; } #box::after { content:''; width:100%; height:100%; position:absolute; mix-blend-mode:exclusion; background-size:15px 13px; background-repeat: repeat; background-image: -webkit-repeating-radial-gradient(21% 21%, closest-corner, rgba(255,255,255,1), rgba(0,0,255,.5), rgba(3,0,255,1) 20%); left:0; top:0; z-index:999; } 
 

Si bien esto no califica como ruido verdadero, un enfoque de CSS3 puro usaría múltiples selectores de fondo de repetición lineal, que a menudo se utilizan en generadores de patrones.

Aquí están algunos ejemplos:

Con una combinación correcta de fondos, angularjs, paradas de color y transparencia, se puede lograr un efecto similar al ruido razonable 🙂

Espero que te ponga en la dirección correcta de todos modos …

Creación de texturas (ruido) Uso de filtros SVG y gradientes CSS

¿Quieres ruido en tu gradiente? ¡Estás de suerte!

El ruido de Perlin es un tipo de ruido de gradiente. El estándar SVG especifica una primitiva de filtro llamada , que implementa la función Perlin. Permite la síntesis de texturas artificiales como las nubes o el mármol: el ruido que deseas.

Paso 1: defina un gráfico SVG

Crea un pequeño archivo SVG llamado noise.svg .

        

Este gráfico define dos rectangularjs. El primero está lleno de un color sólido. El segundo es translúcido con el filtro de ruido aplicado. El segundo rectángulo se superpone sobre el primero para proporcionar un efecto de ruido.

Opciones de SVG

  1. Puño y más obvio es que puedes cambiar las dimensiones del gráfico. Sin embargo, la propiedad CSS background-repeat se puede usar para completar un elemento, por lo tanto 300 × 300 debería ser suficiente.

  2. El atributo de type del filtro puede ser fractalNoise o turbulence , que especifica la función de filtro. Ambos proporcionan una visión diferente, pero en mi opinión, el filtro de ruido es un poco más sutil.

  3. El atributo de baseFrequency del filtro puede variar de 0.5-0.9 para proporcionar un rumbo a una textura fina, respectivamente. Este rango es visualmente óptimo para cualquiera de los filtros en mi opinión.

  4. El primer fill del rectángulo se puede cambiar para proporcionar un color base diferente. Más tarde, sin embargo, combinamos este color con un gradiente de CSS translúcido, que también define un color (s). Entonces el blanco es un buen punto de partida aquí.

  5. La opacity del segundo rectángulo puede variar de 0.2-0.9 para establecer la intensidad del filtro, donde un número más alto aumenta la intensidad.

En este punto, podría ajustar las opciones mencionadas anteriormente, establecer este gráfico de ruido como una imagen de fondo a través de CSS y llamarlo un día. Pero si quiere un degradado, como el OP, vaya al Paso 2.

Paso 2: aplicar un gradiente de CSS

Usando la propiedad background-image , puede establecer el gráfico de ruido SVG como fondo en cualquier elemento y superponer un degradado . En este ejemplo, aplicaré el gráfico de ruido a todo el cuerpo y superponeré un degradado lineal .

 body { /* white to black linear noise gradient spanning from top to bottom */ background: linear-gradient(rgba(255,255,255,.5), rgba(0,0,0,.5)), url('noise.svg'); } 

La función de degradado lineal () crea una pseudoimagen , que se astack en la parte superior de noise.svg . El resultado es un gradiente translúcido con nuestro ruido a través de él.

Opciones de CSS

  1. Primero, y lo más obvio, es que los colores degradados definidos se pueden cambiar. Sin embargo, si desea un color sólido sin degradado, haga que los dos colores de punto final sean iguales. El beneficio es que puede usar el mismo gráfico de ruido con o sin un degradado en un sitio o entre proyectos.

  2. Varias imágenes, creadas con las *-gradient() , se pueden superponer en el gráfico de ruido y se pueden especificar más de dos parámetros y angularjs de color en una función de degradado individual para proporcionar todo tipo de efectos visuales interesantes.

  3. La opacidad de los parámetros de gradiente, es decir, rgba () y hsla (), se puede boost para intensificar el color definido y reducir el nivel de ruido. Nuevamente, 0.2-0.9 es un rango ideal.

Conclusión

Esta es una solución altamente personalizable y muy liviana (~ 400 bytes) que le permite simplemente definir el ruido de cualquier color o degradado. Aunque hay varias perillas para girar aquí, esto es solo el comienzo. Hay otras primitivas de filtro SVG, como y , que pueden proporcionar resultados adicionales.

No es posible (incluso si lo fuera, tomaría una buena cantidad de trucos de código hacerlo) para generar texturas de ruido usando solo CSS. No hay nuevas propiedades de CSS3 que brinden ese tipo de efecto de la caja. Una solución mucho más rápida es usar un editor gráfico como Photoshop para hacer eso.