Czy mogę ustawić obraz tła i krycie w tej samej właściwości?

264

Widzę w odnośnikach CSS, jak ustawić przezroczystość obrazu i jak ustawić obraz tła . Ale jak połączyć te dwa elementy, aby ustawić przezroczysty obraz tła?

Mam obraz, który chciałbym wykorzystać jako tło, ale jest on zbyt jasny - chciałbym zmniejszyć krycie do około 0,2. W jaki sposób mogę to zrobić?

#main {
    background-image: url(/wp-content/uploads/2010/11/tandem.jpg); 
}
AP257
źródło

Odpowiedzi:

133

Dwie metody:

  1. Konwertuj na PNG i ustaw oryginalny obraz na 0,2 krycia
  2. (Metoda Better) mają <div>to position: absolute;przed #maini taką samą wysokość jak #main, a następnie zastosować obraz tła i opacity: 0.2; filter: alpha(opacity=20);.
Niet the Dark Absol
źródło
Tak, dużym problemem z PNG jest rozmiar. Prawdopodobnie będzie naprawdę duży. Teraz, gdy możemy określić opacity: ...we wszystkich przeglądarkach, jest o wiele lepiej!
Alexis Wilke
1
Byłbyś zaskoczony tym, co możesz wycisnąć z PNG. Na przykład przy 0.2 krycia prawdopodobnie nie wybierzesz wielu szczegółów, więc możesz przekonwertować na Indexed-PNG. Właściwie używam tego na własnej stronie internetowej, co powoduje zmiażdżenie obrazu tła 1920x1080 do rozmiaru prawie 250 KB.
Niet the Dark Absol
Lepiej dodaj indeks Z: -1 do tej pozycji: bezwzględny, aby umożliwić użycie dna nad nakładką. Dobra odpowiedź.
Raz
1
Możesz także użyć WebP - obsługuje przezroczystość, a rozmiar pliku jest znacznie mniejszy niż PNG. Wszystkie główne przeglądarki oprócz Safari obsługują teraz WebP. Możesz obsługiwać WebP do obsługi przeglądarek, a PNG do Safari.
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;
}
Dan Eastwell
źródło
4
Wygenerowana treść od IE8 w górę. caniuse.com/#feat=css-gencontent , użyj właściwości filtru dla IE8. caniuse.com/#search=opacity
Dan Eastwell
3
Dodałem „Z-index: -1” do CSS. W ten sposób na obraz tła wpływa nieprzezroczystość, a nie reszta zawartości #main
Patrick
17
Używam :beforezamiast, :aftera potem nie muszę manipulować, z-indexponieważ automatycznie :beforekończy się poniżej głównej zawartości. (Obecnie testowane w Chrome i FF.)
KajMagnus
1
@KajMagnus Jeśli to zrobisz, wszystko po tym nie zostanie wyświetlone. Spróbuj mieć krycie 1,0, a zobaczysz, co mam na myśli.
Jessica,
1
Jeśli otrzymujesz powtarzający się obraz tła, możesz chcieć / trzeba dodać background-repeat: no-repeat; background-attachment: fixed; background-position: center;w ciągu #main: after {...} .
zakaz geoinżynierii
106

Rozwiązanie z 1 dywizją i BEZ przezroczystego obrazu:

Możesz użyć funkcji CSS3 multibackground i umieścić dwa tła: jedno z obrazem, drugie z przezroczystym panelem nad nim (bo myślę, że nie ma sposobu, aby ustawić bezpośrednio krycie obrazu tła):

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;

Nie możesz użyć, rgba(255,255,255,0.5)ponieważ sam jest akceptowany tylko z tyłu, więc użyłem wygenerowanych gradientów dla każdej przeglądarki w tym przykładzie (dlatego jest tak długi). Ale koncepcja jest następująca:

background: tranparentColor, url("myImage"); 

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

Drewno
źródło
Działa to tylko wtedy, gdy tło ma jednolity kolor, jeśli masz PNG24, który jest tłem i chcesz, aby miał krycie (na przykład po najechaniu myszą), to nie zadziała i będziesz musiał użyć metody pseudoelementu , co jest w rzeczywistości lepsze, ponieważ można go używać w IE 8 i nowszych wersjach.
vsync,
66

Proste rozwiązanie

jeśli chcesz ustawić gradient tylko na obraz w tle :

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
źródło
Obraz przesuwa się nieznacznie na górę. Czy to naprawia?
HFR1994
6
Możesz także użyć obrazu tła RGBA 255,255,255: gradient liniowy (do dołu, rgba (255,255,255,0,6) 0%, rgba (255,255,255,0,6) 100%), adres URL (IMAGE_URL);
Rzym.
@Roman Możesz ustawić komponent koloru rgba na wartość używaną jako kolor tła w elemencie lub jego macierzystym obiekcie do osadzania (testowane na Chrome 58.0.3029.81, Edge 38.14393.0.0).
Collapsar
46

Widziałem to, aw CSS3 możesz teraz umieścić kod w ten sposób. Powiedzmy, że chcę, aby obejmował całe tło, zrobiłbym coś takiego. Następnie z hsla(0,0%,100%,0.70)lub rgba używasz białego tła z dowolnym procentowym nasyceniem lub kryciem, aby uzyskać pożądany wygląd.

.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;
}
Nataniel steruje
źródło
2
Dodanie koloru tła i trybu mieszania tła pomogło mi. Teraz mam divę z nieprzezroczystością, która nie wpływa na jej dzieci!
Diego Victor de Jesus,
1
to jest świetne! Stworzyłem funkcję jquery, aby zmienić krycie przy przewijaniu, tworząc kolor nad obrazem tła podczas przewijania w dół. $ (funkcja () {$ (okno) .scroll (funkcja () {var scroll = $ (okno) .scrollTop (); var current = 0; var now = (current-scroll) / 7; $ ('. slide ') .css („tło-pozycja”, „50%” + teraz + „px”); var color = Math.round (scroll / 7) / 100; $ („. slide”). css („background- color ',' rgba (128, 45, 87, '+ color +') ');});});
drooh
10

Aby to zrobić, możesz użyć selektora psuedo CSS :: po. Oto działające demo.

wprowadź opis zdjęcia tutaj

.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
źródło
4

Miałem podobny problem. Miałem obraz i chciałem zmniejszyć przezroczystość i mieć czarne tło za obrazem. Zamiast zmniejszania krycia lub tworzenia czarnego tła lub jakiegokolwiek dodatkowego elementu div ustawiam gradient liniowy na obrazie w jednym wierszu:

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
źródło
3

Użyłem odpowiedzi @Dan Eastwell i działa bardzo dobrze. Kod jest podobny do jego kodu, ale z pewnymi dodatkami.

.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 Kamerun
źródło
2

Świetnym sposobem na zrobienie tego dla prostego obrazu jest zrobienie tego za pomocą CSS, aby ustawić tło elementu HTML w ten sposób.

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

Jeśli chcesz się spodobać i ustawić jego krycie, to w IE9 + * możesz ustawić przezroczysty kolor tła ciała. Działa to poprzez nałożenie półprzezroczystej bieli, aby obraz był bielszy i wydawał się jaśniejszy. Na przykład biel z 75% kryciem ( rgba(255,255,255,.75)) dałaby następujący efekt.

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>

  • Wskazówka: zauważ, jaki jest kod HTML position: relative, podczas gdy treść jest position: absolute. Zapobiega to zachowaniu się koloru tła ciała bardziej jak rozświetlacza tekstu w ciele.

Można to nawet rozszerzyć na coś porównywalnego, ale wciąż bardzo różniącego się od filtrów CSS, zmieniając wokół koloru tła RGBA. Na przykład rgba(0,255,0,.75)utworzyłby bardzo zielony odcień, co widać we fragmencie kodu.

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>

  • Wskazówka: RGBA odpowiada R ed G reen B lue A lpha. Tak więc przeglądarka interpretuje to rgba(0,255,0,.75)jako przykład {red:0, green:255, blue:0, alpha:'75%'}.


* Pełną tabelę zgodności można znaleźć na stronie Can I Use. Pamiętaj jednak, że musisz kliknąć „Pokaż wszystko”, aby zobaczyć, że IE9 obsługuje to.


Uzupełnienie

Ponieważ już odpowiedziałem na pytanie, ale mam więcej, które chcę dodać, zatytułuję ten dodatek do sekcji i dodam kilka potencjalnie pomocnych informacji. Tak więc, aby ekstrapolować jeszcze bardziej na powyższej treści, możesz użyć SVG jako obrazu tła, aby robić niegodziwe niesamowite rzeczy. Na przykład możesz utworzyć tło ekranu ładowania z fajną ikoną witryny, jak widać na przykładzie SVG zakodowanego w standardzie base64 poniżej.

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>

  • Wskazówka:background-size: cover CSS powoduje logo SVG w tle, aby być zmniejszane do rozmiaru elementu HTML.
3,1415926535897932384626433833
źródło
1

W swoim CSS dodaj ...

 filter: opacity(50%);

W JavaScript użyj ...

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

Uwaga: w razie potrzeby dodaj prefiksy dostawcy, ale bez Chromium.

Coder42
źródło
0

Cóż, jedynym sposobem CSS na zrobienie tylko przezroczystości tła jest RGBaprzejście, ale ponieważ chcesz użyć obrazu, sugeruję użycie Photoshopa lub Gimpa, aby uczynić obraz przezroczystym, a następnie użyć go jako tła.


źródło
To nie jest poprawne, istnieje deklaracja CSS3: opactiy: 1;nie tylko RGBa.
Kyle,
4
To, co mówi, to ustawienie background-imagestylu na kontenerze, a następnie ustawienie opacitystylu na tym samym elemencie. Dzięki temu tekst i inne treści tego elementu będą przejrzyste. Wypróbuj to, jeśli mi nie wierzysz: w3schools.com/Css/tryit.asp?filename=trycss_transparency
0

Właśnie dodałem pozycję = wartość absolutna, góra = 0, szerokość = 100% w #main i ustawiłem wartość krycia na #background

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

Zastosowałem tło do div przed main.

leniwy
źródło
-1

Natknąłem się na ten post, ponieważ miałem ten sam problem, a potem pomyślałem, po co mieszać się z css, dostosowywać wartości i odświeżać, skoro możesz łatwo dostosować krycie w Photoshopie? Skopiuj obraz, wklej go jako nową warstwę, a następnie przesuń suwak krycia.

MBM
źródło
2
ArtB ma rację z ostatnią nutą. Jest to doskonałe rozwiązanie dla innego problemu. Są chwile, kiedy nie jest to właściwe rozwiązanie i jest to jedno z nich.
jon
-1

Miałem podobny problem i właśnie zrobiłem obraz tła w Photoshopie i utworzyłem nowy plik .png z nieprzezroczystością, której potrzebowałem. Problem rozwiązany bez obawy, że mój CSS działał na wszystkich urządzeniach i przeglądarkach

Aebares
źródło