¿Puedo configurar la imagen de fondo y la opacidad en la misma propiedad?

264

Puedo ver en las referencias de CSS cómo configurar la transparencia de la imagen y cómo configurar una imagen de fondo . Pero, ¿cómo puedo combinar estos dos para establecer una imagen de fondo transparente?

Tengo una imagen que me gustaría usar como fondo, pero es demasiado brillante, me gustaría reducir la opacidad a aproximadamente 0.2. ¿Cómo puedo hacer esto?

#main {
    background-image: url(/wp-content/uploads/2010/11/tandem.jpg); 
}
AP257
fuente

Respuestas:

133

Dos métodos:

  1. Convierta a PNG y haga que la imagen original tenga una opacidad de 0.2
  2. (Método Mejor) tiene una <div>que es position: absolute;antes #mainy la misma altura que #main, a continuación, aplicar la imagen de fondo y opacity: 0.2; filter: alpha(opacity=20);.
Niet the Dark Absol
fuente
Sí, el gran problema con un PNG es el tamaño. Es probable que sea realmente grande. Ahora que podemos especificar opacity: ...en todos los navegadores, ¡es mucho mejor!
Alexis Wilke
1
Te sorprendería lo que puedes sacar de PNG. Por ejemplo, con una opacidad de 0.2, es probable que no elija muchos detalles, por lo que puede convertir a PNG indexado. De hecho, uso esto en mi propio sitio web, y aplasta una imagen de fondo de 1920x1080 a poco menos de 250 kb de tamaño.
Niet the Dark Absol
Es mejor agregar el índice z: -1 a esa posición: absoluta, para permitir el uso de fondos por encima de la superposición. Buena respuesta.
Raz
1
También puede usar WebP: admite transparencia y el tamaño del archivo es mucho más pequeño que PNG. Todos los principales navegadores, excepto Safari, ahora admiten WebP. Puede servir WebP para admitir navegadores y PNG para Safari.
Dan Roberts el
365
#main {
    position: relative;
}
#main:after {
    content : "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background-image: url(/wp-content/uploads/2010/11/tandem.jpg); 
    width: 100%;
    height: 100%;
    opacity : 0.2;
    z-index: -1;
}
Dan Eastwell
fuente
44
Contenido generado a partir de IE8. caniuse.com/#feat=css-gencontent , usa la propiedad de filtro para IE8. caniuse.com/#search=opacity
Dan Eastwell
3
Agregué un "índice z: -1" al CSS. De esa manera, la opacidad afecta la imagen de fondo, no el resto del contenido de #main
patrick
17
Yo uso en :beforelugar de:after y luego no tengo que manipular el z-indexporque :beforetermina automáticamente debajo del contenido principal. (Actualmente probado en Chrome y FF.)
KajMagnus
1
@KajMagnus Si haces eso, entonces todo lo que sigue no se muestra. Intenta tener una opacidad de 1.0 y verás lo que quiero decir.
Jessica
1
Si obtiene una imagen de fondo repetida, es posible que desee / necesite agregar background-repeat: no-repeat; background-attachment: fixed; background-position: center;dentro de #main: después de {...} .
prohibición de geoingeniería
106

Solución con 1 div y SIN imagen transparente:

Puede usar la función CSS3 multibackground y poner dos fondos: uno con la imagen, otro con un panel transparente sobre él (porque creo que no hay forma de establecer directamente la opacidad de la imagen de fondo):

background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.7) 100%), url(bg.png) repeat 0 0, url(https://cdn.sstatic.net/stackoverflow/img/apple-touch-icon.png) repeat 0 0;

background: -moz-linear-gradient(top, rgba(255,255,255,0.7) 0%, rgba(255,255,255,0.7) 100%), url(https://cdn.sstatic.net/stackoverflow/img/apple-touch-icon.png) repeat 0 0;

background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,0.7)), color-stop(100%,rgba(255,255,255,0.7))), url(https://cdn.sstatic.net/stackoverflow/img/apple-touch-icon.png) repeat 0 0;

background: -webkit-linear-gradient(top, rgba(255,255,255,0.7) 0%,rgba(255,255,255,0.7) 100%), url(https://cdn.sstatic.net/stackoverflow/img/apple-touch-icon.png) repeat 0 0;

background: -o-linear-gradient(top, rgba(255,255,255,0.7) 0%,rgba(255,255,255,0.7) 100%), url(https://cdn.sstatic.net/stackoverflow/img/apple-touch-icon.png) repeat 0 0;

background: -ms-linear-gradient(top, rgba(255,255,255,0.7) 0%,rgba(255,255,255,0.7) 100%), url(https://cdn.sstatic.net/stackoverflow/img/apple-touch-icon.png) repeat 0 0;

background: linear-gradient(to bottom, rgba(255,255,255,0.7) 0%,rgba(255,255,255,0.7) 100%), url(https://cdn.sstatic.net/stackoverflow/img/apple-touch-icon.png) repeat 0 0;

No puede usarlo rgba(255,255,255,0.5)porque solo solo se acepta en la parte posterior, por lo que he usado gradientes generados para cada navegador para este ejemplo (es por eso que es tan largo). Pero el concepto es el siguiente:

background: tranparentColor, url("myImage"); 

http://jsfiddle.net/pBVsD/1/

Madera
fuente
Esto solo funcionará si el fondo es un color sólido, si tiene PNG24, que es un fondo y desea que tenga opacidad (por ejemplo, al pasar el mouse), entonces esto no funcionará y tendrá que usar el método de pseudoelemento , que en realidad es mejor ya que podría usarse en IE 8 y versiones posteriores.
vsync
66

Solución simple

si necesita establecer el gradiente solo en la imagen de fondo :

background-image: url(IMAGE_URL); /* fallback for older browsers */

background-image: linear-gradient(to bottom, rgba(0,0,0,0.6) 0%,rgba(0,0,0,0.6) 100%), url(IMAGE_URL);
Francesco Borzi
fuente
La imagen se mueve ligeramente hacia arriba. ¿Tiene una solución?
HFR1994
66
También puede usar la imagen de fondo RGBA 255,255,255: gradiente lineal (hacia abajo, rgba (255,255,255,0.6) 0%, rgba (255,255,255,0.6) 100%), url (IMAGE_URL);
Romano
@Roman Puede establecer el componente de color rgba en el valor utilizado como color de fondo en el elemento o su elemento primario incrustado (probado en Chrome 58.0.3029.81, Edge 38.14393.0.0).
collapsar el
46

Vi esto y en CSS3 ahora puede colocar el código de esta manera. Digamos que quiero que cubra todo el fondo, haría algo como esto. Luego, con hsla(0,0%,100%,0.70)o rgba, usa un fondo blanco con cualquier porcentaje de saturación u opacidad para obtener el aspecto que desea.

.body{
    background-attachment: fixed;
    background-image: url(../images/Store1.jpeg);
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    background-color: hsla(0,0%,100%,0.70);
    background-blend-mode: overlay;
    background-repeat: no-repeat;
}
Nathaniel Helms
fuente
2
Agregar el color de fondo y el modo de mezcla de fondo me sirvieron. ¡Ahora tengo un div con una opacidad que no afecta a sus hijos!
Diego Victor de Jesus
1
¡esto es genial! Creé una función jquery para cambiar la opacidad en el desplazamiento, creando un color sobre una imagen de fondo a medida que se desplaza hacia abajo. $ (function () {$ (window) .scroll (function () {var scroll = $ (window) .scrollTop (); var current = 0; var now = (current-scroll) / 7; $ ('. slide ') .css (' background-position ', '50%' + now + 'px'); var color = Math.round (scroll / 7) / 100; $ ('. slide'). css ('background- color ',' rgba (128, 45, 87, '+ color +') ');});});
drooh
10

Puede usar CSS psuedo selector :: after para lograr esto. Aquí hay una demostración en funcionamiento.

ingrese la descripción de la imagen aquí

.bg-container{
  width: 100%;
  height: 300px;
  border: 1px solid #000;
  position: relative;
}
.bg-container .content{
  position: absolute;
  z-index:999;
  text-align: center;
  width: 100%;
}
.bg-container::after{
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  z-index:-99;
  background-image: url(https://i.stack.imgur.com/Hp53k.jpg);
  background-size: cover;
  opacity: 0.4;
}
<div class="bg-container">
   <div class="content">
     <h1>Background Opacity 0.4</h1>
   </div>
</div>

Hari Das
fuente
4

Tuve un problema similar Tenía una imagen y quería reducir la transparencia y tener un fondo negro detrás de la imagen. En lugar de reducir la opacidad o crear un fondo negro o cualquier div secundario, configuro un degradado lineal para la imagen, todo en una línea:

background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.8) 100%), url("/img/picture.png");

matteo_dm
fuente
3

He usado la respuesta de @Dan Eastwell y funciona muy bien. El código es similar a su código pero con algunas adiciones.

.granddata {
    position: relative;
    margin-left :0.5%;
    margin-right :0.5%;
}
.granddata:after {
    content : "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("/Images/blabla.jpg");
    width: 100%;
    height: 100%;
    opacity: 0.2;
    z-index: -1;
    background-repeat: no-repeat;
    background-position: center;
    background-attachment:fixed;
}
El camerouniano
fuente
2

Una excelente manera de hacerlo para una imagen simple es hacerlo usando solo CSS para establecer el fondo del elemento HTML de esta manera.

HTML {
    background: url('http://www.earthtimes.org/newsimage/eat-lead-by-example-obesity-expert-tells-parents_139.jpg');
    width: 100%;
    height: 100%;
}

Si quieres ponerte elegante y configurar su opacidad, entonces, en IE9 + *, puedes configurar un color de fondo transparente del cuerpo. Esto funciona superponiendo el blanco semitransparente para que la imagen sea más blanca y parezca más brillante. Por ejemplo, el blanco con 75% de opacidad ( rgba(255,255,255,.75)) produciría el siguiente efecto.

HTML {
  background: url('http://www.earthtimes.org/newsimage/eat-lead-by-example-obesity-expert-tells-parents_139.jpg');
  width: 100%;
  height: 100%;
  position: relative;
}

body {
  width: 100%;
  min-height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  background: rgba(255, 255, 255, .75);
}
<p>Lorem ipsum dolor sit amet, et id, maecenas a convallis, elit facilisi congue augue id ac. Suscipit luctus egestas rutrum, amet tincidunt porttitor ante convallis magna, vivamus amet at turpis, ante lacinia blandit vel metus mauris rutrum. Ipsum nam adipiscing.
  Est sapien quis sem vestibulum, quis cubilia turpis, suspendisse mattis vehicula enim risus pede, placerat suspendisse dui. Convallis nostrud pede, mollit lobortis, ornare ipsum tempor faucibus tortor, vel pede, porttitor nulla nonummy vestibulum purus.
  Eros placerat tenetur augue ipsum aliquam, pellentesque congue condimentum sed vitae lectus.</p>
<p>Aliquam venenatis curabitur pellentesque sociosqu quam. Tincidunt id erat vestibulum in, est fermentum ipsum et augue, nascetur etiam. Lorem elit, sed donec, leo vivamus ac id enim faucibus vel. Nullam sit feugiat sed massa consectetuer auctor, nulla
  et erat lacinia nec, eget ut ante nullam est non in, elit porttitor in in donec eget porttitor. Interdum ultricies sem morbi facilisis nibh erat. Id suspendisse, sed tincidunt fringilla sit, sapien odio vel, at culpa augue sed taciti neque inceptos,
  massa class non. Vel tristique condimentum at pellentesque, commodo nulla sagittis rhoncus lorem. Viverra maecenas tellus pretium urna mauris proin, vel libero morbi, ante volutpat vestibulum augue. Itaque leo mauris turpis, vivamus nisl congue nisl
  nulla in turpis, eget vitae accumsan dolor ipsum leo venenatis, feugiat vehicula in risus, donec eu pede vivamus itaque nam. Justo amet vitae pellentesque sed, posuere fusce sapien, sed nam placerat libero sed etiam curabitur, suspendisse justo, amet
  porttitor.</p>
<p>Condimentum eget. Sem elementum a et mauris sem a, velit justo consectetuer in turpis mauris, sit sed elit cum, fusce suspendisse pretium dictum, mattis dui tortor tellus. Volutpat ut ante lorem nec laoreet aliquam, lorem est magna amet, integer mauris
  purus tellus. Porta enim repellendus aliquam eros. Turpis posuere elementum suscipit wisi lobortis, nec nunc consequat dictum ut unde at, mi lorem amet nunc. Cubilia pede, integer dolor, eget platea felis elit enim rhoncus, integer proin quam in ipsum
  lorem, diam curabitur netus pretium pellentesque. Donec rutrum ultrices placerat, curabitur maecenas, feugiat pede varius accumsan quam lorem, dui et dictumst asperiores nulla, vivamus urna nam leo libero. Posuere non convallis amet justo parturient,
  imperdiet consectetuer arcu praesent cursus risus, quis pretium dolor.</p>

  • Consejo: observe cómo es el HTML position: relative, mientras que el cuerpo es position: absolute. Esto es para evitar que el color de fondo del cuerpo se comporte más como un resaltador del texto en el cuerpo.

Esto incluso podría expandirse a algo comparable, pero aún muy distinto de los filtros CSS al cambiar el fondo de color RGBA del cuerpo. Por ejemplo, rgba(0,255,0,.75)crearía un tinte muy verde como puede ver en el fragmento de código.

HTML {
    background: url('http://www.earthtimes.org/newsimage/eat-lead-by-example-obesity-expert-tells-parents_139.jpg');
    width: 100%;
    height: 100%;
    position: relative;
}
body {
    width: 100%;
    min-height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    background: rgba(0,255,0,.75);
}
<p>Aliquam venenatis curabitur pellentesque sociosqu quam. Tincidunt id erat vestibulum in, est fermentum ipsum et augue, nascetur etiam. Lorem elit, sed donec, leo vivamus ac id enim faucibus vel. Nullam sit feugiat sed massa consectetuer auctor, nulla et erat lacinia nec, eget ut ante nullam est non in, elit porttitor in in donec eget porttitor. Interdum ultricies sem morbi facilisis nibh erat. Id suspendisse, sed tincidunt fringilla sit, sapien odio vel, at culpa augue sed taciti neque inceptos, massa class non. Vel tristique condimentum at pellentesque, commodo nulla sagittis rhoncus lorem. Viverra maecenas tellus pretium urna mauris proin, vel libero morbi, ante volutpat vestibulum augue. Itaque leo mauris turpis, vivamus nisl congue nisl nulla in turpis, eget vitae accumsan dolor ipsum leo venenatis, feugiat vehicula in risus, donec eu pede vivamus itaque nam. Justo amet vitae pellentesque sed, posuere fusce sapien, sed nam placerat libero sed etiam curabitur, suspendisse justo, amet porttitor.</p>
<p>Condimentum eget. Sem elementum a et mauris sem a, velit justo consectetuer in turpis mauris, sit sed elit cum, fusce suspendisse pretium dictum, mattis dui tortor tellus. Volutpat ut ante lorem nec laoreet aliquam, lorem est magna amet, integer mauris purus tellus. Porta enim repellendus aliquam eros. Turpis posuere elementum suscipit wisi lobortis, nec nunc consequat dictum ut unde at, mi lorem amet nunc. Cubilia pede, integer dolor, eget platea felis elit enim rhoncus, integer proin quam in ipsum lorem, diam curabitur netus pretium pellentesque. Donec rutrum ultrices placerat, curabitur maecenas, feugiat pede varius accumsan quam lorem, dui et dictumst asperiores nulla, vivamus urna nam leo libero. Posuere non convallis amet justo parturient, imperdiet consectetuer arcu praesent cursus risus, quis pretium dolor.</p>
<p>Lorem ipsum dolor sit amet, et id, maecenas a convallis, elit facilisi congue augue id ac. Suscipit luctus egestas rutrum, amet tincidunt porttitor ante convallis magna, vivamus amet at turpis, ante lacinia blandit vel metus mauris rutrum. Ipsum nam adipiscing. Est sapien quis sem vestibulum, quis cubilia turpis, suspendisse mattis vehicula enim risus pede, placerat suspendisse dui. Convallis nostrud pede, mollit lobortis, ornare ipsum tempor faucibus tortor, vel pede, porttitor nulla nonummy vestibulum purus. Eros placerat tenetur augue ipsum aliquam, pellentesque congue condimentum sed vitae lectus.</p>

  • Consejo: RGBA corresponde a R ed G reen B lue A lpha. Entonces, el navegador interpreta rgba(0,255,0,.75)como algo ejemplificado por {red:0, green:255, blue:0, alpha:'75%'}.


* Se puede encontrar una tabla de compatibilidad completa en Can I Use. Sin embargo, tenga en cuenta también que debe hacer clic en "Mostrar todo" para ver que IE9 lo admite.


Apéndice

Como ya he respondido a la pregunta pero tengo más que quiero agregar, estoy titulando este apéndice de la sección y haciendo que agregue información potencialmente útil. Por lo tanto, para extrapolar aún más el contenido anterior, puede usar un SVG como imagen de fondo para hacer cosas increíbles. Por ejemplo, podría crear un fondo de pantalla de carga con un icono de sitio web genial como puede ver en el ejemplo de un SVG codificado en base64 a continuación.

HTML {
    background: url('');
    width: 100%;
    height: 100%;
    position: relative;
    background-size: cover;
}
body {
    width: 100%;
    min-height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    background: rgba(255,255,255,.5);
}
<p>Condimentum eget. Sem elementum a et mauris sem a, velit justo consectetuer in turpis mauris, sit sed elit cum, fusce suspendisse pretium dictum, mattis dui tortor tellus. Volutpat ut ante lorem nec laoreet aliquam, lorem est magna amet, integer mauris purus tellus. Porta enim repellendus aliquam eros. Turpis posuere elementum suscipit wisi lobortis, nec nunc consequat dictum ut unde at, mi lorem amet nunc. Cubilia pede, integer dolor, eget platea felis elit enim rhoncus, integer proin quam in ipsum lorem, diam curabitur netus pretium pellentesque. Donec rutrum ultrices placerat, curabitur maecenas, feugiat pede varius accumsan quam lorem, dui et dictumst asperiores nulla, vivamus urna nam leo libero. Posuere non convallis amet justo parturient, imperdiet consectetuer arcu praesent cursus risus, quis pretium dolor.</p>
<p>Lorem ipsum dolor sit amet, et id, maecenas a convallis, elit facilisi congue augue id ac. Suscipit luctus egestas rutrum, amet tincidunt porttitor ante convallis magna, vivamus amet at turpis, ante lacinia blandit vel metus mauris rutrum. Ipsum nam adipiscing. Est sapien quis sem vestibulum, quis cubilia turpis, suspendisse mattis vehicula enim risus pede, placerat suspendisse dui. Convallis nostrud pede, mollit lobortis, ornare ipsum tempor faucibus tortor, vel pede, porttitor nulla nonummy vestibulum purus. Eros placerat tenetur augue ipsum aliquam, pellentesque congue condimentum sed vitae lectus.</p>
<p>Aliquam venenatis curabitur pellentesque sociosqu quam. Tincidunt id erat vestibulum in, est fermentum ipsum et augue, nascetur etiam. Lorem elit, sed donec, leo vivamus ac id enim faucibus vel. Nullam sit feugiat sed massa consectetuer auctor, nulla et erat lacinia nec, eget ut ante nullam est non in, elit porttitor in in donec eget porttitor. Interdum ultricies sem morbi facilisis nibh erat. Id suspendisse, sed tincidunt fringilla sit, sapien odio vel, at culpa augue sed taciti neque inceptos, massa class non. Vel tristique condimentum at pellentesque, commodo nulla sagittis rhoncus lorem. Viverra maecenas tellus pretium urna mauris proin, vel libero morbi, ante volutpat vestibulum augue. Itaque leo mauris turpis, vivamus nisl congue nisl nulla in turpis, eget vitae accumsan dolor ipsum leo venenatis, feugiat vehicula in risus, donec eu pede vivamus itaque nam. Justo amet vitae pellentesque sed, posuere fusce sapien, sed nam placerat libero sed etiam curabitur, suspendisse justo, amet porttitor.</p>

  • Consejo: El background-size: coverCSS hace que el logotipo de SVG en el fondo cambie de tamaño al tamaño del elemento HTML.
3.1415926535897932384626433833
fuente
1

En su CSS agregue ...

 filter: opacity(50%);

En JavaScript usa ...

 element.style.filter='opacity(50%)';

NB: agregue prefijos de proveedor según sea necesario, pero Chromium debería estar bien sin él.

Codificador42
fuente
0

Bueno, la única forma CSS de hacer solo la transparencia de fondo es a través de, RGBapero dado que desea usar una imagen, sugeriría usar Photoshop o Gimp para hacer que la imagen sea transparente y luego usarla como fondo.


fuente
Esto no es correcto, hay una declaración CSS3: opactiy: 1;no solo RGBa.
Kyle
44
Lo que está diciendo es establecer el background-imageestilo en un contenedor y luego establecer un opacityestilo en el mismo elemento. Eso también haría que el texto y otros contenidos de ese elemento sean transparentes. Pruebe esto si no me cree: w3schools.com/Css/tryit.asp?filename=trycss_transparency
0

Acabo de agregar position = absolute, top = 0, width = 100% en #main y configuré el valor de opacidad en #background

#main{height:100%;position:absolute; top:0;width:100%}
#background{//same height as main;background-image:url(image URL);opacity:0.2}

Apliqué el fondo a un div antes del principal.

perezoso
fuente
-1

Me encontré con esta publicación porque tenía el mismo problema y luego pensé ¿por qué meterse con CSS, ajustar los valores y presionar Actualizar cuando puede ajustar fácilmente la opacidad en Photoshop? Copie la imagen, péguela como una nueva capa y luego mueva el control deslizante de opacidad.

MBM
fuente
2
ArtB acertó con la última nota. Esta es una solución perfectamente buena para otro problema. Hay momentos en que esta no es la solución correcta y esta es una de ellas.
jon
-1

Tuve un problema similar y simplemente tomé la imagen de fondo con Photoshop y creé un nuevo .png con la opacidad que necesitaba. Problema resuelto sin preocuparme si mi CSS funcionaba en todos los dispositivos y navegadores

Aebares
fuente