Aynı mülkte arka plan resmi ve opaklık ayarlayabilir miyim?


264

CSS referanslar görebileceğiniz görüntü saydamlığını ayarlamak için nasıl ve ne kadar bir arka plan görüntüsü ayarlamak için . Ancak şeffaf bir arka plan görüntüsü ayarlamak için bu ikisini nasıl birleştirebilirim?

Arka plan olarak kullanmak istediğim bir görüntüm var, ama çok parlak - opaklığı yaklaşık 0.2'ye düşürmek istiyorum. Bunu nasıl yapabilirim?

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

Yanıtlar:


133

İki yöntem:

  1. PNG'ye dönüştürün ve orijinal görüntüyü 0.2 opaklık haline getirin
  2. (Daha iyi yöntemi) bir var <div>olduğunu position: absolute;daha önce #mainve aynı yükseklikte #mainsonra Arka plan resmi uygulamak ve, opacity: 0.2; filter: alpha(opacity=20);.

Evet, PNG ile ilgili büyük sorun boyuttur. Muhtemelen çok büyük olacak. Artık opacity: ...tüm tarayıcılarda belirleyebileceğimize göre , çok daha iyi!
Alexis Wilke

1
PNG'den neler sıkabileceğinize şaşıracaksınız. Örneğin, 0.2 opaklıkta muhtemelen pek çok ayrıntı seçmeyeceksiniz, böylece Dizinlenmiş PNG'ye dönüştürebilirsiniz. Bunu kendi web sitemde kullanıyorum ve 1920x1080 arka plan resmini 250kb'nin biraz altına sıkıştırıyor.
Niet the Dark Absol

Bu konuma z-index: -1 eklemeniz daha iyi olur, bindirmenin üst kısmında diplerin kullanılmasına izin vermek için. İyi cevap.
Raz

1
WebP'yi de kullanabilirsiniz - saydamlığı destekler ve dosya boyutu PNG'den çok daha küçüktür. Safari dışındaki tüm büyük tarayıcılar artık WebP'yi destekliyor. WebP'yi destekleyen tarayıcılara ve PNG'den Safari'ye sunabilirsiniz.
Dan Roberts

364
#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;
}

4
IE8'den itibaren içerik oluşturuldu. caniuse.com/#feat=css-gencontent , IE8 için filter özelliğini kullanın. caniuse.com/#search=opacity
Dan Eastwell

3
CSS'ye bir "z-endeksi: -1" ekledim. Bu şekilde arka plan görüntüsü, #main
patrick

17
Bunun :beforeyerine kullanıyorum :afterve daha sonra kurcalamak zorunda değilim z-indexçünkü :beforeotomatik olarak ana içeriğin altında bitiyor. (Şu anda Chrome ve FF'de test edilmiştir.)
KajMagnus

1
@KajMagnus Bunu yaparsanız, bundan sonraki her şey gösterilmez. 1.0 opaklığa sahip olmayı deneyin, ne demek istediğimi anlayacaksınız.
Jessica

1
Tekrarlanan bir arka plan görüntüsü alıyorsanız, sen isteyebilirsiniz / ekleme ihtiyacını background-repeat: no-repeat; background-attachment: fixed; background-position: center;dahilinde #main: sonra {...} .
ban-geoengineering

106

1 div ve NO şeffaf görüntü ile çözüm:

Çok arka planlı CSS3 özelliğini kullanabilir ve iki arka plan koyabilirsiniz: biri görüntü ile, diğeri üzerinde şeffaf bir panel ile (çünkü doğrudan arka plan görüntüsünün opaklığını ayarlamanın bir yolu olmadığını düşünüyorum):

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;

Kullanamazsınız rgba(255,255,255,0.5)çünkü sadece arkada kabul edilir, bu nedenle bu örnek için her tarayıcı için oluşturulan degradeler kullandınız (bu yüzden çok uzun). Ancak konsept şu şekildedir:

background: tranparentColor, url("myImage"); 

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


Bu yalnızca arka plan düz bir renkse çalışır, arka plan olan PNG24'ünüz varsa ve opaklığa sahip olmasını istiyorsanız (örneğin fareyle üzerine geldiyseniz) bu işe yaramaz ve sözde öğe yöntemini kullanmanız gerekir IE 8 ve üzeri sürümlerde kullanılabileceğinden daha iyi.
vsync

66

Basit çözüm

degradeyi yalnızca arka plan resmine ayarlamanız gerekirse :

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);

Görüntü hafifçe yukarı taşınır. Bir düzeltmesi var mı?
HFR1994

6
RGBA 255,255,255 arka plan resmi de kullanabilirsiniz: doğrusal gradyan (en alta, rgba (255,255,255,0,6)% 0, rgba (255,255,255,0,6)% 100), url (IMAGE_URL);
Roman

@Roman rgba renk bileşenini öğede veya gömme üst öğesinde arka plan rengi olarak kullanılan değere ayarlayabilirsiniz (Chrome 58.0.3029.81, Edge 38.14393.0.0'da test edilmiştir).
collapsar

46

Bunu gördüm ve CSS3'e şimdi kodu böyle yerleştirebilirsiniz. Diyelim ki tüm arka planı kaplamasını istiyorum, böyle bir şey yaparım. Daha sonra hsla(0,0%,100%,0.70)veya rgba ile istediğiniz görünümü elde etmek için yüzde doygunluğu veya opaklığı olan beyaz bir arka plan kullanırsınız.

.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;
}

2
Arka plan rengi ve arka plan karışımı modu eklemek benim için hile yaptı. Şimdi çocuklarını etkilemeyen opaklığa sahip bir div var!
Diego Victor de Jesus

1
bu harika! Kaydırma sırasında opaklığı değiştirmek, aşağı kaydırdığınızda arka plan görüntüsü üzerinde renk oluşturmak için bir jquery işlevi oluşturdum. $ (function () {$ (window) .scroll (function () {var scroll = $ (window) .scrollTop (); var current = 0; var now = (current-scroll) / 7; $ ('. slayt ') .css (' arka plan konumu ','% 50 '+ şimdi +' px '); var color = Math.round (kaydırma / 7) / 100; $ ('. slide '). css (' background- renk ',' rgba (128, 45, 87, '+ renk +') ');});});
drooh

10

Bunu başarmak için CSS psuedo selector :: after komutunu kullanabilirsiniz. İşte çalışan bir demo.

resim açıklamasını buraya girin

.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>


4

Benzer bir sorunum vardı. Bir görüntüm vardı ve saydamlığı azaltmak ve görüntünün arkasında siyah bir arka plan olmasını istedim. Opaklığı azaltmak veya siyah bir arka plan veya herhangi bir ikincil div oluşturmak yerine, görüntüye bir satırda doğrusal bir degrade ayarladım:

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


3

@Dan Eastwell'in cevabını kullandım ve çok iyi çalışıyor. Kod, koduna benzer, ancak bazı eklemelerle.

.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;
}

2

Basit bir görüntü için bunu yapmanın harika bir yolu, HTML öğesinin arka planını böyle ayarlamak için yalnızca CSS kullanarak yapmaktır.

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

Eğer almak istiyorsanız fantezi , ve opaklığını ayarlamak, o zaman, IE9 + *, sen vücudun şeffaf arka plan rengini ayarlayabilirsiniz. Bu, görüntüyü daha beyaz yapmak için yarı saydam beyazın üzerine bindirerek çalışır ve daha parlak görünür. Örneğin,% 75 opaklığa ( rgba(255,255,255,.75)) sahip beyaz , aşağıdaki etkiyi yaratır.

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>

  • İpucu: HTML nasıl ihbar position: relativevücut iken, position: absolute. Bu, vücudun arka plan renginin vücuttaki metnin bir vurgulayıcı gibi davranmasını önlemek içindir.

Bu , vücudun RGBA renk arka planını değiştirerek CSS filtreleriyle karşılaştırılabilir, ancak yine de çok farklı bir şeye genişletilebilir . Örneğin rgba(0,255,0,.75), kod snippet'inde gördüğünüz gibi çok yeşil bir renk tonu oluşturur.

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>

  • İpucu: RGBA, R ed G reen B lue A lpha'ya karşılık gelir . Dolayısıyla, tarayıcı rgba(0,255,0,.75)örnek olarak verilen bir şey olarak yorumlar {red:0, green:255, blue:0, alpha:'75%'}.


* Tam uyumluluk tablosu Can I Use'da bulunabilir. Ancak, IE9'un desteklediğini görmek için "Tümünü Göster" i tıklamanız gerektiğini lütfen unutmayın.


ek

Soruyu daha önce yanıtladığımdan ancak eklemek istediğim daha fazla şeyim olduğundan, bu bölüm eklentisini başlıklıyorum ve potansiyel olarak yararlı bilgiler eklemesini sağlıyorum. Bu nedenle, yukarıdaki içerikte daha da fazla tahmin yapmak için, bir SVG'yi kötü harika şeyler yapmak için arka plan görüntüsü olarak kullanabilirsiniz. Örneğin, aşağıdaki base64 kodlu SVG örneğinde gördüğünüz gibi havalı bir web sitesi simgesi içeren bir yükleme ekranı arka planı oluşturabilirsiniz.

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>

  • İpucu:background-size: cover CSS arka planda SVG logosu HTML öğesinin boyutuna getirilebilen neden olur.

1

CSS'nize ekleyin ...

 filter: opacity(50%);

JavaScript kullanımında ...

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

Not: Gerektiğinde satıcı önekleri ekleyin, ancak Chromium olmadan iyi olmalıdır.


0

Sadece arka plan saydamlığını yapmanın tek CSS yolu RGBabitti, ancak bir görüntü kullanmak istediğiniz için, görüntüyü şeffaf hale getirmek için Photoshop veya Gimp kullanmanızı ve ardından arka plan olarak kullanmanızı öneririm.


Bu doğru değil, bir CSS3 bildirimi var: opactiy: 1;sadece RGBa değil.
Kyle

4
Söylediği, background-imagestili bir kap üzerine ayarlamak ve sonra opacityaynı öğeye bir stil ayarlamaktır . Bu, o öğenin metnini ve diğer içeriğini de şeffaf hale getirir. Bana inanmıyorsan bu out deneyin: w3schools.com/Css/tryit.asp?filename=trycss_transparency

0

#Main'de pozisyon = mutlak, üst = 0, genişlik =% 100 ekledim ve #background'a opaklık değerini ayarladım

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

Arka planı ana bölümden önce bir div'e uyguladım.


-1

Aynı konuya sahip olduğum için bu yazıya rastladım, sonra neden Photoshop'ta opaklığı ayarlayabildiğiniz zaman css, değerleri ayarlama ve yenilemeye vurma hakkında düşündüm? Görüntüyü kopyalayın, yeni bir katman olarak yapıştırın, sonra opaklık kaydırıcısını hareket ettirin.


2
ArtB son notla doğru anladı. Bu, başka bir sorun için mükemmel bir çözümdür. Bunun doğru çözüm olmadığı zamanlar var ve bu da onlardan biri.
jon

-1

Benzer bir sorunum vardı ve arka plan resmini photoshop ile aldım ve ihtiyacım olan opaklıkla yeni bir .png oluşturdum. CSS'm tüm cihazlarda ve tarayıcılarda çalışıp çalışmadığı konusunda endişelenmeden sorun çözüldü

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.