Can I set background image and opacity in the same property?












240















I can see in CSS references how to set image transparency and how to set a background image. But how can I combine these two in order to set a transparent background image?



I have an image that I'd like to use as a background, but it is too bright - I'd like to turn the opacity down to about 0.2. How can I do this?



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









share|improve this question





























    240















    I can see in CSS references how to set image transparency and how to set a background image. But how can I combine these two in order to set a transparent background image?



    I have an image that I'd like to use as a background, but it is too bright - I'd like to turn the opacity down to about 0.2. How can I do this?



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









    share|improve this question



























      240












      240








      240


      52






      I can see in CSS references how to set image transparency and how to set a background image. But how can I combine these two in order to set a transparent background image?



      I have an image that I'd like to use as a background, but it is too bright - I'd like to turn the opacity down to about 0.2. How can I do this?



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









      share|improve this question
















      I can see in CSS references how to set image transparency and how to set a background image. But how can I combine these two in order to set a transparent background image?



      I have an image that I'd like to use as a background, but it is too bright - I'd like to turn the opacity down to about 0.2. How can I do this?



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






      css






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Jan 3 at 20:11









      TylerH

      15.6k105267




      15.6k105267










      asked Nov 15 '10 at 11:37









      AP257AP257

      26.6k72168248




      26.6k72168248
























          13 Answers
          13






          active

          oldest

          votes


















          125














          Two methods:




          1. Convert to PNG and make the original image 0.2 opacity

          2. (Better method) have a <div> that is position: absolute; before #main and the same height as #main, then apply the background-image and opacity: 0.2; filter: alpha(opacity=20);.






          share|improve this answer


























          • Yeah, the big problem with a PNG is the size. It is likely going to be really large. Now that we can specify opacity: ... in all browsers, it way better!

            – Alexis Wilke
            Jul 1 '17 at 23:49






          • 1





            You'd be surprised what you can squeeze out of PNG. For instance, at 0.2 opacity, you're probably not going to be picking out many details, so you can convert to Indexed-PNG. I actually use this on my own website, and it squashes a 1920x1080 background image to just under 250kb in size.

            – Niet the Dark Absol
            Jul 2 '17 at 9:50











          • You better add z-index: -1 to that position:absolute, in order to allow using bottoms above the overlay. Good answer.

            – Raz
            Feb 28 '18 at 15:10



















          330














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





          share|improve this answer





















          • 4





            Generated content from IE8 up. caniuse.com/#feat=css-gencontent, use filter property for IE8. caniuse.com/#search=opacity

            – Dan Eastwell
            Jun 1 '12 at 11:18






          • 3





            I added a "z-index: -1" to the CSS. That way the background image is affected by the opacity, not the rest of the contents of #main

            – patrick
            Mar 20 '14 at 22:36






          • 12





            I use :before instead of :after and then I don't have to tamper with the z-index because :before ends up below the main contents automatically. (Currently tested in Chrome and FF.)

            – KajMagnus
            Jun 28 '15 at 9:30








          • 1





            @KajMagnus If you do that, then everything after that doesn't get shown. Try having an opacity of 1.0, and you'll see what I mean.

            – Jessica
            Nov 4 '15 at 23:58






          • 1





            If you are getting a repeated background image, you may want/need to add background-repeat: no-repeat; background-attachment: fixed; background-position: center; within #main:after {...}.

            – ban-geoengineering
            Mar 15 '17 at 15:26



















          102














          Solution with 1 div and NO transparent image:



          You can use the multibackground CSS3 feature and put two backgrounds: one with the image, another with a transparent panel over it (cause I think there's no way to set directly the opacity of the background image):



          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;


          You can't use rgba(255,255,255,0.5) because alone it is only accepted on the back, so you I've used generated gradients for each browser for this example (that's why it is so long). But the concept is the following:



          background: tranparentColor, url("myImage"); 


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






          share|improve this answer
























          • This will only work if the background is a solid color, if you have PNG24 which is a background and you want it to have opacity (on hover for example) then this will not work, and you will have to use the pseudo-element method, which is actually better since it could be used in IE 8 and up.

            – vsync
            Dec 17 '14 at 15:57





















          54














          Simple solution



          if you need to set the gradient to background-image only:



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





          share|improve this answer


























          • Image moves slightly to the top. Does it have a fix?

            – HFR1994
            Apr 4 '16 at 18:25








          • 5





            You can also use RGBA 255,255,255 background-image: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 100%), url(IMAGE_URL);

            – Roman
            Sep 11 '16 at 15:22











          • @Roman You may set the rgba color component to the value used as background-color in the element or its embedding parent (tested on Chrome 58.0.3029.81, Edge 38.14393.0.0).

            – collapsar
            Apr 26 '17 at 10:17



















          38














          I saw this and in CSS3 you can now place code in like this. Lets say I want it to cover the whole background I would do something like this. Then with hsla(0,0%,100%,0.70) or rgba you use a white background with whatever percentage saturation or opacity to get the look you desire.



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





          share|improve this answer

































            9














            You can use CSS psuedo selector ::after to achieve this. Here is a working demo.



            enter image description here






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








            share|improve this answer































              2














              I have used the answer of @Dan Eastwell and it works very well. The code is similar to his code but with some additions.



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





              share|improve this answer

































                1














                In your CSS add...



                 filter: opacity(50%);


                In JavaScript use...



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


                NB: Add vendor prefixes as required but Chromium should be fine without.






                share|improve this answer































                  1














                  A great way to do it for a simple image is to do it using only CSS to set the background of the HTML element like so.






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





                  If you want to get fancy, and set its opacity, then, in IE9+*, you can set a transparent background color of the body. This works by overlaying semitransparent white to make the image whiter, and appear to be brighter. For example, white with 75% opacity (rgba(255,255,255,.75)) would produce the following effect.






                  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>







                  • Tip: notice how the HTML is position: relative, while the body is position: absolute. This is to prevent the background color of the body from behaving more like a highlighter of the text in the body.


                  This could even be expanded to something comparable to, but still very distinct from, CSS filters by changing around the body's RGBA color background. For example, rgba(0,255,0,.75) would create a very green tint as you can see in the code snippet.






                  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>







                  • Tip: RGBA corresponds to RedGreenBlueAlpha. So, the browser interprets rgba(0,255,0,.75) as something exemplified by {red:0, green:255, blue:0, alpha:'75%'}.





                  *A full compatibility table can be found at Can I Use. However, please also note that you need to click the "Show All" to see that IE9 supports it.






                  Addendum



                  Since I have already answered the question but I have more I want to add, I am titling this section addendum and having it add some potentially helpful information. So, to extrapolate even further on the content above, you could use an SVG as a background image to do wicked awesome things. For example, you could create a loading screen background featuring a cool website icon as you can see in the example of a base64 encoded SVG below.






                  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>







                  • Tip: The background-size: cover CSS causes the SVG logo in the background to be resized to the size of the HTML element.






                  share|improve this answer

































                    0














                    Well the only CSS way of doing only background transparency is via RGBa but since you want to use an image I would suggest using Photoshop or Gimp to make the image transparent and then using it as the background.






                    share|improve this answer
























                    • This is not correct, there is a CSS3 declaration: opactiy: 1;, not just RGBa.

                      – Kyle
                      Nov 15 '10 at 11:49








                    • 4





                      What he is saying is setting the background-image style on a container and then setting an opacity style on the same element. That would also make the text and other contents of that element transparent. Try this out if you don't believe me: w3schools.com/Css/tryit.asp?filename=trycss_transparency

                      – Glenn Nelson
                      Nov 15 '10 at 15:57



















                    0














                    I just added position=absolute,top=0,width=100% in the #main and set the opacity value to the #background



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


                    I applied the background to a div before the main.






                    share|improve this answer































                      -1














                      I came across this post as I had the same issue then I thought why mess about with css, adjusting values and hitting refresh when you can easily adjust the opacity in Photoshop? Copy the image, paste it as a new layer then move the opacity slider.






                      share|improve this answer



















                      • 2





                        ArtB got it right w/ the last note. This is a perfectly fine solution for another problem. There are times when this isn't the right solution and this is one of them.

                        – jon
                        Aug 4 '13 at 20:27



















                      -1














                      I had a similar issue and I just took the background image with photoshop and created a new .png with the opacity I needed. Problem solved without worrying about if my CSS worked accross all devices & browsers






                      share|improve this answer























                        Your Answer






                        StackExchange.ifUsing("editor", function () {
                        StackExchange.using("externalEditor", function () {
                        StackExchange.using("snippets", function () {
                        StackExchange.snippets.init();
                        });
                        });
                        }, "code-snippets");

                        StackExchange.ready(function() {
                        var channelOptions = {
                        tags: "".split(" "),
                        id: "1"
                        };
                        initTagRenderer("".split(" "), "".split(" "), channelOptions);

                        StackExchange.using("externalEditor", function() {
                        // Have to fire editor after snippets, if snippets enabled
                        if (StackExchange.settings.snippets.snippetsEnabled) {
                        StackExchange.using("snippets", function() {
                        createEditor();
                        });
                        }
                        else {
                        createEditor();
                        }
                        });

                        function createEditor() {
                        StackExchange.prepareEditor({
                        heartbeatType: 'answer',
                        autoActivateHeartbeat: false,
                        convertImagesToLinks: true,
                        noModals: true,
                        showLowRepImageUploadWarning: true,
                        reputationToPostImages: 10,
                        bindNavPrevention: true,
                        postfix: "",
                        imageUploader: {
                        brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
                        contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
                        allowUrls: true
                        },
                        onDemand: true,
                        discardSelector: ".discard-answer"
                        ,immediatelyShowMarkdownHelp:true
                        });


                        }
                        });














                        draft saved

                        draft discarded


















                        StackExchange.ready(
                        function () {
                        StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f4183948%2fcan-i-set-background-image-and-opacity-in-the-same-property%23new-answer', 'question_page');
                        }
                        );

                        Post as a guest















                        Required, but never shown

























                        13 Answers
                        13






                        active

                        oldest

                        votes








                        13 Answers
                        13






                        active

                        oldest

                        votes









                        active

                        oldest

                        votes






                        active

                        oldest

                        votes









                        125














                        Two methods:




                        1. Convert to PNG and make the original image 0.2 opacity

                        2. (Better method) have a <div> that is position: absolute; before #main and the same height as #main, then apply the background-image and opacity: 0.2; filter: alpha(opacity=20);.






                        share|improve this answer


























                        • Yeah, the big problem with a PNG is the size. It is likely going to be really large. Now that we can specify opacity: ... in all browsers, it way better!

                          – Alexis Wilke
                          Jul 1 '17 at 23:49






                        • 1





                          You'd be surprised what you can squeeze out of PNG. For instance, at 0.2 opacity, you're probably not going to be picking out many details, so you can convert to Indexed-PNG. I actually use this on my own website, and it squashes a 1920x1080 background image to just under 250kb in size.

                          – Niet the Dark Absol
                          Jul 2 '17 at 9:50











                        • You better add z-index: -1 to that position:absolute, in order to allow using bottoms above the overlay. Good answer.

                          – Raz
                          Feb 28 '18 at 15:10
















                        125














                        Two methods:




                        1. Convert to PNG and make the original image 0.2 opacity

                        2. (Better method) have a <div> that is position: absolute; before #main and the same height as #main, then apply the background-image and opacity: 0.2; filter: alpha(opacity=20);.






                        share|improve this answer


























                        • Yeah, the big problem with a PNG is the size. It is likely going to be really large. Now that we can specify opacity: ... in all browsers, it way better!

                          – Alexis Wilke
                          Jul 1 '17 at 23:49






                        • 1





                          You'd be surprised what you can squeeze out of PNG. For instance, at 0.2 opacity, you're probably not going to be picking out many details, so you can convert to Indexed-PNG. I actually use this on my own website, and it squashes a 1920x1080 background image to just under 250kb in size.

                          – Niet the Dark Absol
                          Jul 2 '17 at 9:50











                        • You better add z-index: -1 to that position:absolute, in order to allow using bottoms above the overlay. Good answer.

                          – Raz
                          Feb 28 '18 at 15:10














                        125












                        125








                        125







                        Two methods:




                        1. Convert to PNG and make the original image 0.2 opacity

                        2. (Better method) have a <div> that is position: absolute; before #main and the same height as #main, then apply the background-image and opacity: 0.2; filter: alpha(opacity=20);.






                        share|improve this answer















                        Two methods:




                        1. Convert to PNG and make the original image 0.2 opacity

                        2. (Better method) have a <div> that is position: absolute; before #main and the same height as #main, then apply the background-image and opacity: 0.2; filter: alpha(opacity=20);.







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Sep 22 '14 at 14:54









                        TylerH

                        15.6k105267




                        15.6k105267










                        answered Nov 15 '10 at 11:42









                        Niet the Dark AbsolNiet the Dark Absol

                        257k53360468




                        257k53360468













                        • Yeah, the big problem with a PNG is the size. It is likely going to be really large. Now that we can specify opacity: ... in all browsers, it way better!

                          – Alexis Wilke
                          Jul 1 '17 at 23:49






                        • 1





                          You'd be surprised what you can squeeze out of PNG. For instance, at 0.2 opacity, you're probably not going to be picking out many details, so you can convert to Indexed-PNG. I actually use this on my own website, and it squashes a 1920x1080 background image to just under 250kb in size.

                          – Niet the Dark Absol
                          Jul 2 '17 at 9:50











                        • You better add z-index: -1 to that position:absolute, in order to allow using bottoms above the overlay. Good answer.

                          – Raz
                          Feb 28 '18 at 15:10



















                        • Yeah, the big problem with a PNG is the size. It is likely going to be really large. Now that we can specify opacity: ... in all browsers, it way better!

                          – Alexis Wilke
                          Jul 1 '17 at 23:49






                        • 1





                          You'd be surprised what you can squeeze out of PNG. For instance, at 0.2 opacity, you're probably not going to be picking out many details, so you can convert to Indexed-PNG. I actually use this on my own website, and it squashes a 1920x1080 background image to just under 250kb in size.

                          – Niet the Dark Absol
                          Jul 2 '17 at 9:50











                        • You better add z-index: -1 to that position:absolute, in order to allow using bottoms above the overlay. Good answer.

                          – Raz
                          Feb 28 '18 at 15:10

















                        Yeah, the big problem with a PNG is the size. It is likely going to be really large. Now that we can specify opacity: ... in all browsers, it way better!

                        – Alexis Wilke
                        Jul 1 '17 at 23:49





                        Yeah, the big problem with a PNG is the size. It is likely going to be really large. Now that we can specify opacity: ... in all browsers, it way better!

                        – Alexis Wilke
                        Jul 1 '17 at 23:49




                        1




                        1





                        You'd be surprised what you can squeeze out of PNG. For instance, at 0.2 opacity, you're probably not going to be picking out many details, so you can convert to Indexed-PNG. I actually use this on my own website, and it squashes a 1920x1080 background image to just under 250kb in size.

                        – Niet the Dark Absol
                        Jul 2 '17 at 9:50





                        You'd be surprised what you can squeeze out of PNG. For instance, at 0.2 opacity, you're probably not going to be picking out many details, so you can convert to Indexed-PNG. I actually use this on my own website, and it squashes a 1920x1080 background image to just under 250kb in size.

                        – Niet the Dark Absol
                        Jul 2 '17 at 9:50













                        You better add z-index: -1 to that position:absolute, in order to allow using bottoms above the overlay. Good answer.

                        – Raz
                        Feb 28 '18 at 15:10





                        You better add z-index: -1 to that position:absolute, in order to allow using bottoms above the overlay. Good answer.

                        – Raz
                        Feb 28 '18 at 15:10













                        330














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





                        share|improve this answer





















                        • 4





                          Generated content from IE8 up. caniuse.com/#feat=css-gencontent, use filter property for IE8. caniuse.com/#search=opacity

                          – Dan Eastwell
                          Jun 1 '12 at 11:18






                        • 3





                          I added a "z-index: -1" to the CSS. That way the background image is affected by the opacity, not the rest of the contents of #main

                          – patrick
                          Mar 20 '14 at 22:36






                        • 12





                          I use :before instead of :after and then I don't have to tamper with the z-index because :before ends up below the main contents automatically. (Currently tested in Chrome and FF.)

                          – KajMagnus
                          Jun 28 '15 at 9:30








                        • 1





                          @KajMagnus If you do that, then everything after that doesn't get shown. Try having an opacity of 1.0, and you'll see what I mean.

                          – Jessica
                          Nov 4 '15 at 23:58






                        • 1





                          If you are getting a repeated background image, you may want/need to add background-repeat: no-repeat; background-attachment: fixed; background-position: center; within #main:after {...}.

                          – ban-geoengineering
                          Mar 15 '17 at 15:26
















                        330














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





                        share|improve this answer





















                        • 4





                          Generated content from IE8 up. caniuse.com/#feat=css-gencontent, use filter property for IE8. caniuse.com/#search=opacity

                          – Dan Eastwell
                          Jun 1 '12 at 11:18






                        • 3





                          I added a "z-index: -1" to the CSS. That way the background image is affected by the opacity, not the rest of the contents of #main

                          – patrick
                          Mar 20 '14 at 22:36






                        • 12





                          I use :before instead of :after and then I don't have to tamper with the z-index because :before ends up below the main contents automatically. (Currently tested in Chrome and FF.)

                          – KajMagnus
                          Jun 28 '15 at 9:30








                        • 1





                          @KajMagnus If you do that, then everything after that doesn't get shown. Try having an opacity of 1.0, and you'll see what I mean.

                          – Jessica
                          Nov 4 '15 at 23:58






                        • 1





                          If you are getting a repeated background image, you may want/need to add background-repeat: no-repeat; background-attachment: fixed; background-position: center; within #main:after {...}.

                          – ban-geoengineering
                          Mar 15 '17 at 15:26














                        330












                        330








                        330







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





                        share|improve this answer















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






                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Sep 17 '18 at 22:01









                        Nisse Engström

                        4,12892134




                        4,12892134










                        answered Jun 1 '12 at 11:16









                        Dan EastwellDan Eastwell

                        3,92641432




                        3,92641432








                        • 4





                          Generated content from IE8 up. caniuse.com/#feat=css-gencontent, use filter property for IE8. caniuse.com/#search=opacity

                          – Dan Eastwell
                          Jun 1 '12 at 11:18






                        • 3





                          I added a "z-index: -1" to the CSS. That way the background image is affected by the opacity, not the rest of the contents of #main

                          – patrick
                          Mar 20 '14 at 22:36






                        • 12





                          I use :before instead of :after and then I don't have to tamper with the z-index because :before ends up below the main contents automatically. (Currently tested in Chrome and FF.)

                          – KajMagnus
                          Jun 28 '15 at 9:30








                        • 1





                          @KajMagnus If you do that, then everything after that doesn't get shown. Try having an opacity of 1.0, and you'll see what I mean.

                          – Jessica
                          Nov 4 '15 at 23:58






                        • 1





                          If you are getting a repeated background image, you may want/need to add background-repeat: no-repeat; background-attachment: fixed; background-position: center; within #main:after {...}.

                          – ban-geoengineering
                          Mar 15 '17 at 15:26














                        • 4





                          Generated content from IE8 up. caniuse.com/#feat=css-gencontent, use filter property for IE8. caniuse.com/#search=opacity

                          – Dan Eastwell
                          Jun 1 '12 at 11:18






                        • 3





                          I added a "z-index: -1" to the CSS. That way the background image is affected by the opacity, not the rest of the contents of #main

                          – patrick
                          Mar 20 '14 at 22:36






                        • 12





                          I use :before instead of :after and then I don't have to tamper with the z-index because :before ends up below the main contents automatically. (Currently tested in Chrome and FF.)

                          – KajMagnus
                          Jun 28 '15 at 9:30








                        • 1





                          @KajMagnus If you do that, then everything after that doesn't get shown. Try having an opacity of 1.0, and you'll see what I mean.

                          – Jessica
                          Nov 4 '15 at 23:58






                        • 1





                          If you are getting a repeated background image, you may want/need to add background-repeat: no-repeat; background-attachment: fixed; background-position: center; within #main:after {...}.

                          – ban-geoengineering
                          Mar 15 '17 at 15:26








                        4




                        4





                        Generated content from IE8 up. caniuse.com/#feat=css-gencontent, use filter property for IE8. caniuse.com/#search=opacity

                        – Dan Eastwell
                        Jun 1 '12 at 11:18





                        Generated content from IE8 up. caniuse.com/#feat=css-gencontent, use filter property for IE8. caniuse.com/#search=opacity

                        – Dan Eastwell
                        Jun 1 '12 at 11:18




                        3




                        3





                        I added a "z-index: -1" to the CSS. That way the background image is affected by the opacity, not the rest of the contents of #main

                        – patrick
                        Mar 20 '14 at 22:36





                        I added a "z-index: -1" to the CSS. That way the background image is affected by the opacity, not the rest of the contents of #main

                        – patrick
                        Mar 20 '14 at 22:36




                        12




                        12





                        I use :before instead of :after and then I don't have to tamper with the z-index because :before ends up below the main contents automatically. (Currently tested in Chrome and FF.)

                        – KajMagnus
                        Jun 28 '15 at 9:30







                        I use :before instead of :after and then I don't have to tamper with the z-index because :before ends up below the main contents automatically. (Currently tested in Chrome and FF.)

                        – KajMagnus
                        Jun 28 '15 at 9:30






                        1




                        1





                        @KajMagnus If you do that, then everything after that doesn't get shown. Try having an opacity of 1.0, and you'll see what I mean.

                        – Jessica
                        Nov 4 '15 at 23:58





                        @KajMagnus If you do that, then everything after that doesn't get shown. Try having an opacity of 1.0, and you'll see what I mean.

                        – Jessica
                        Nov 4 '15 at 23:58




                        1




                        1





                        If you are getting a repeated background image, you may want/need to add background-repeat: no-repeat; background-attachment: fixed; background-position: center; within #main:after {...}.

                        – ban-geoengineering
                        Mar 15 '17 at 15:26





                        If you are getting a repeated background image, you may want/need to add background-repeat: no-repeat; background-attachment: fixed; background-position: center; within #main:after {...}.

                        – ban-geoengineering
                        Mar 15 '17 at 15:26











                        102














                        Solution with 1 div and NO transparent image:



                        You can use the multibackground CSS3 feature and put two backgrounds: one with the image, another with a transparent panel over it (cause I think there's no way to set directly the opacity of the background image):



                        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;


                        You can't use rgba(255,255,255,0.5) because alone it is only accepted on the back, so you I've used generated gradients for each browser for this example (that's why it is so long). But the concept is the following:



                        background: tranparentColor, url("myImage"); 


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






                        share|improve this answer
























                        • This will only work if the background is a solid color, if you have PNG24 which is a background and you want it to have opacity (on hover for example) then this will not work, and you will have to use the pseudo-element method, which is actually better since it could be used in IE 8 and up.

                          – vsync
                          Dec 17 '14 at 15:57


















                        102














                        Solution with 1 div and NO transparent image:



                        You can use the multibackground CSS3 feature and put two backgrounds: one with the image, another with a transparent panel over it (cause I think there's no way to set directly the opacity of the background image):



                        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;


                        You can't use rgba(255,255,255,0.5) because alone it is only accepted on the back, so you I've used generated gradients for each browser for this example (that's why it is so long). But the concept is the following:



                        background: tranparentColor, url("myImage"); 


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






                        share|improve this answer
























                        • This will only work if the background is a solid color, if you have PNG24 which is a background and you want it to have opacity (on hover for example) then this will not work, and you will have to use the pseudo-element method, which is actually better since it could be used in IE 8 and up.

                          – vsync
                          Dec 17 '14 at 15:57
















                        102












                        102








                        102







                        Solution with 1 div and NO transparent image:



                        You can use the multibackground CSS3 feature and put two backgrounds: one with the image, another with a transparent panel over it (cause I think there's no way to set directly the opacity of the background image):



                        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;


                        You can't use rgba(255,255,255,0.5) because alone it is only accepted on the back, so you I've used generated gradients for each browser for this example (that's why it is so long). But the concept is the following:



                        background: tranparentColor, url("myImage"); 


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






                        share|improve this answer













                        Solution with 1 div and NO transparent image:



                        You can use the multibackground CSS3 feature and put two backgrounds: one with the image, another with a transparent panel over it (cause I think there's no way to set directly the opacity of the background image):



                        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;


                        You can't use rgba(255,255,255,0.5) because alone it is only accepted on the back, so you I've used generated gradients for each browser for this example (that's why it is so long). But the concept is the following:



                        background: tranparentColor, url("myImage"); 


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







                        share|improve this answer












                        share|improve this answer



                        share|improve this answer










                        answered Jul 30 '13 at 11:10









                        WoodWood

                        1,6261810




                        1,6261810













                        • This will only work if the background is a solid color, if you have PNG24 which is a background and you want it to have opacity (on hover for example) then this will not work, and you will have to use the pseudo-element method, which is actually better since it could be used in IE 8 and up.

                          – vsync
                          Dec 17 '14 at 15:57





















                        • This will only work if the background is a solid color, if you have PNG24 which is a background and you want it to have opacity (on hover for example) then this will not work, and you will have to use the pseudo-element method, which is actually better since it could be used in IE 8 and up.

                          – vsync
                          Dec 17 '14 at 15:57



















                        This will only work if the background is a solid color, if you have PNG24 which is a background and you want it to have opacity (on hover for example) then this will not work, and you will have to use the pseudo-element method, which is actually better since it could be used in IE 8 and up.

                        – vsync
                        Dec 17 '14 at 15:57







                        This will only work if the background is a solid color, if you have PNG24 which is a background and you want it to have opacity (on hover for example) then this will not work, and you will have to use the pseudo-element method, which is actually better since it could be used in IE 8 and up.

                        – vsync
                        Dec 17 '14 at 15:57













                        54














                        Simple solution



                        if you need to set the gradient to background-image only:



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





                        share|improve this answer


























                        • Image moves slightly to the top. Does it have a fix?

                          – HFR1994
                          Apr 4 '16 at 18:25








                        • 5





                          You can also use RGBA 255,255,255 background-image: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 100%), url(IMAGE_URL);

                          – Roman
                          Sep 11 '16 at 15:22











                        • @Roman You may set the rgba color component to the value used as background-color in the element or its embedding parent (tested on Chrome 58.0.3029.81, Edge 38.14393.0.0).

                          – collapsar
                          Apr 26 '17 at 10:17
















                        54














                        Simple solution



                        if you need to set the gradient to background-image only:



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





                        share|improve this answer


























                        • Image moves slightly to the top. Does it have a fix?

                          – HFR1994
                          Apr 4 '16 at 18:25








                        • 5





                          You can also use RGBA 255,255,255 background-image: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 100%), url(IMAGE_URL);

                          – Roman
                          Sep 11 '16 at 15:22











                        • @Roman You may set the rgba color component to the value used as background-color in the element or its embedding parent (tested on Chrome 58.0.3029.81, Edge 38.14393.0.0).

                          – collapsar
                          Apr 26 '17 at 10:17














                        54












                        54








                        54







                        Simple solution



                        if you need to set the gradient to background-image only:



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





                        share|improve this answer















                        Simple solution



                        if you need to set the gradient to background-image only:



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






                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Sep 17 '18 at 7:16

























                        answered Mar 15 '16 at 12:31









                        Francesco BorzìFrancesco Borzì

                        13.9k84984




                        13.9k84984













                        • Image moves slightly to the top. Does it have a fix?

                          – HFR1994
                          Apr 4 '16 at 18:25








                        • 5





                          You can also use RGBA 255,255,255 background-image: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 100%), url(IMAGE_URL);

                          – Roman
                          Sep 11 '16 at 15:22











                        • @Roman You may set the rgba color component to the value used as background-color in the element or its embedding parent (tested on Chrome 58.0.3029.81, Edge 38.14393.0.0).

                          – collapsar
                          Apr 26 '17 at 10:17



















                        • Image moves slightly to the top. Does it have a fix?

                          – HFR1994
                          Apr 4 '16 at 18:25








                        • 5





                          You can also use RGBA 255,255,255 background-image: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 100%), url(IMAGE_URL);

                          – Roman
                          Sep 11 '16 at 15:22











                        • @Roman You may set the rgba color component to the value used as background-color in the element or its embedding parent (tested on Chrome 58.0.3029.81, Edge 38.14393.0.0).

                          – collapsar
                          Apr 26 '17 at 10:17

















                        Image moves slightly to the top. Does it have a fix?

                        – HFR1994
                        Apr 4 '16 at 18:25







                        Image moves slightly to the top. Does it have a fix?

                        – HFR1994
                        Apr 4 '16 at 18:25






                        5




                        5





                        You can also use RGBA 255,255,255 background-image: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 100%), url(IMAGE_URL);

                        – Roman
                        Sep 11 '16 at 15:22





                        You can also use RGBA 255,255,255 background-image: linear-gradient(to bottom, rgba(255,255,255,0.6) 0%,rgba(255,255,255,0.6) 100%), url(IMAGE_URL);

                        – Roman
                        Sep 11 '16 at 15:22













                        @Roman You may set the rgba color component to the value used as background-color in the element or its embedding parent (tested on Chrome 58.0.3029.81, Edge 38.14393.0.0).

                        – collapsar
                        Apr 26 '17 at 10:17





                        @Roman You may set the rgba color component to the value used as background-color in the element or its embedding parent (tested on Chrome 58.0.3029.81, Edge 38.14393.0.0).

                        – collapsar
                        Apr 26 '17 at 10:17











                        38














                        I saw this and in CSS3 you can now place code in like this. Lets say I want it to cover the whole background I would do something like this. Then with hsla(0,0%,100%,0.70) or rgba you use a white background with whatever percentage saturation or opacity to get the look you desire.



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





                        share|improve this answer






























                          38














                          I saw this and in CSS3 you can now place code in like this. Lets say I want it to cover the whole background I would do something like this. Then with hsla(0,0%,100%,0.70) or rgba you use a white background with whatever percentage saturation or opacity to get the look you desire.



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





                          share|improve this answer




























                            38












                            38








                            38







                            I saw this and in CSS3 you can now place code in like this. Lets say I want it to cover the whole background I would do something like this. Then with hsla(0,0%,100%,0.70) or rgba you use a white background with whatever percentage saturation or opacity to get the look you desire.



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





                            share|improve this answer















                            I saw this and in CSS3 you can now place code in like this. Lets say I want it to cover the whole background I would do something like this. Then with hsla(0,0%,100%,0.70) or rgba you use a white background with whatever percentage saturation or opacity to get the look you desire.



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






                            share|improve this answer














                            share|improve this answer



                            share|improve this answer








                            edited Jan 13 '17 at 1:34









                            jrbedard

                            2,89052131




                            2,89052131










                            answered Jan 13 '17 at 1:10









                            nathaniel helmsnathaniel helms

                            38135




                            38135























                                9














                                You can use CSS psuedo selector ::after to achieve this. Here is a working demo.



                                enter image description here






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








                                share|improve this answer




























                                  9














                                  You can use CSS psuedo selector ::after to achieve this. Here is a working demo.



                                  enter image description here






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








                                  share|improve this answer


























                                    9












                                    9








                                    9







                                    You can use CSS psuedo selector ::after to achieve this. Here is a working demo.



                                    enter image description here






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








                                    share|improve this answer













                                    You can use CSS psuedo selector ::after to achieve this. Here is a working demo.



                                    enter image description here






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








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





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






                                    share|improve this answer












                                    share|improve this answer



                                    share|improve this answer










                                    answered Jun 16 '17 at 9:27









                                    Hari DasHari Das

                                    3,11742536




                                    3,11742536























                                        2














                                        I have used the answer of @Dan Eastwell and it works very well. The code is similar to his code but with some additions.



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





                                        share|improve this answer






























                                          2














                                          I have used the answer of @Dan Eastwell and it works very well. The code is similar to his code but with some additions.



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





                                          share|improve this answer




























                                            2












                                            2








                                            2







                                            I have used the answer of @Dan Eastwell and it works very well. The code is similar to his code but with some additions.



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





                                            share|improve this answer















                                            I have used the answer of @Dan Eastwell and it works very well. The code is similar to his code but with some additions.



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






                                            share|improve this answer














                                            share|improve this answer



                                            share|improve this answer








                                            edited Sep 17 '18 at 21:56









                                            Nisse Engström

                                            4,12892134




                                            4,12892134










                                            answered Oct 7 '16 at 13:27









                                            El camerounianEl camerounian

                                            756




                                            756























                                                1














                                                In your CSS add...



                                                 filter: opacity(50%);


                                                In JavaScript use...



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


                                                NB: Add vendor prefixes as required but Chromium should be fine without.






                                                share|improve this answer




























                                                  1














                                                  In your CSS add...



                                                   filter: opacity(50%);


                                                  In JavaScript use...



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


                                                  NB: Add vendor prefixes as required but Chromium should be fine without.






                                                  share|improve this answer


























                                                    1












                                                    1








                                                    1







                                                    In your CSS add...



                                                     filter: opacity(50%);


                                                    In JavaScript use...



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


                                                    NB: Add vendor prefixes as required but Chromium should be fine without.






                                                    share|improve this answer













                                                    In your CSS add...



                                                     filter: opacity(50%);


                                                    In JavaScript use...



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


                                                    NB: Add vendor prefixes as required but Chromium should be fine without.







                                                    share|improve this answer












                                                    share|improve this answer



                                                    share|improve this answer










                                                    answered Nov 17 '16 at 23:25









                                                    Coder42Coder42

                                                    111




                                                    111























                                                        1














                                                        A great way to do it for a simple image is to do it using only CSS to set the background of the HTML element like so.






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





                                                        If you want to get fancy, and set its opacity, then, in IE9+*, you can set a transparent background color of the body. This works by overlaying semitransparent white to make the image whiter, and appear to be brighter. For example, white with 75% opacity (rgba(255,255,255,.75)) would produce the following effect.






                                                        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>







                                                        • Tip: notice how the HTML is position: relative, while the body is position: absolute. This is to prevent the background color of the body from behaving more like a highlighter of the text in the body.


                                                        This could even be expanded to something comparable to, but still very distinct from, CSS filters by changing around the body's RGBA color background. For example, rgba(0,255,0,.75) would create a very green tint as you can see in the code snippet.






                                                        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>







                                                        • Tip: RGBA corresponds to RedGreenBlueAlpha. So, the browser interprets rgba(0,255,0,.75) as something exemplified by {red:0, green:255, blue:0, alpha:'75%'}.





                                                        *A full compatibility table can be found at Can I Use. However, please also note that you need to click the "Show All" to see that IE9 supports it.






                                                        Addendum



                                                        Since I have already answered the question but I have more I want to add, I am titling this section addendum and having it add some potentially helpful information. So, to extrapolate even further on the content above, you could use an SVG as a background image to do wicked awesome things. For example, you could create a loading screen background featuring a cool website icon as you can see in the example of a base64 encoded SVG below.






                                                        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>







                                                        • Tip: The background-size: cover CSS causes the SVG logo in the background to be resized to the size of the HTML element.






                                                        share|improve this answer






























                                                          1














                                                          A great way to do it for a simple image is to do it using only CSS to set the background of the HTML element like so.






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





                                                          If you want to get fancy, and set its opacity, then, in IE9+*, you can set a transparent background color of the body. This works by overlaying semitransparent white to make the image whiter, and appear to be brighter. For example, white with 75% opacity (rgba(255,255,255,.75)) would produce the following effect.






                                                          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>







                                                          • Tip: notice how the HTML is position: relative, while the body is position: absolute. This is to prevent the background color of the body from behaving more like a highlighter of the text in the body.


                                                          This could even be expanded to something comparable to, but still very distinct from, CSS filters by changing around the body's RGBA color background. For example, rgba(0,255,0,.75) would create a very green tint as you can see in the code snippet.






                                                          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>







                                                          • Tip: RGBA corresponds to RedGreenBlueAlpha. So, the browser interprets rgba(0,255,0,.75) as something exemplified by {red:0, green:255, blue:0, alpha:'75%'}.





                                                          *A full compatibility table can be found at Can I Use. However, please also note that you need to click the "Show All" to see that IE9 supports it.






                                                          Addendum



                                                          Since I have already answered the question but I have more I want to add, I am titling this section addendum and having it add some potentially helpful information. So, to extrapolate even further on the content above, you could use an SVG as a background image to do wicked awesome things. For example, you could create a loading screen background featuring a cool website icon as you can see in the example of a base64 encoded SVG below.






                                                          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>







                                                          • Tip: The background-size: cover CSS causes the SVG logo in the background to be resized to the size of the HTML element.






                                                          share|improve this answer




























                                                            1












                                                            1








                                                            1







                                                            A great way to do it for a simple image is to do it using only CSS to set the background of the HTML element like so.






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





                                                            If you want to get fancy, and set its opacity, then, in IE9+*, you can set a transparent background color of the body. This works by overlaying semitransparent white to make the image whiter, and appear to be brighter. For example, white with 75% opacity (rgba(255,255,255,.75)) would produce the following effect.






                                                            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>







                                                            • Tip: notice how the HTML is position: relative, while the body is position: absolute. This is to prevent the background color of the body from behaving more like a highlighter of the text in the body.


                                                            This could even be expanded to something comparable to, but still very distinct from, CSS filters by changing around the body's RGBA color background. For example, rgba(0,255,0,.75) would create a very green tint as you can see in the code snippet.






                                                            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>







                                                            • Tip: RGBA corresponds to RedGreenBlueAlpha. So, the browser interprets rgba(0,255,0,.75) as something exemplified by {red:0, green:255, blue:0, alpha:'75%'}.





                                                            *A full compatibility table can be found at Can I Use. However, please also note that you need to click the "Show All" to see that IE9 supports it.






                                                            Addendum



                                                            Since I have already answered the question but I have more I want to add, I am titling this section addendum and having it add some potentially helpful information. So, to extrapolate even further on the content above, you could use an SVG as a background image to do wicked awesome things. For example, you could create a loading screen background featuring a cool website icon as you can see in the example of a base64 encoded SVG below.






                                                            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>







                                                            • Tip: The background-size: cover CSS causes the SVG logo in the background to be resized to the size of the HTML element.






                                                            share|improve this answer















                                                            A great way to do it for a simple image is to do it using only CSS to set the background of the HTML element like so.






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





                                                            If you want to get fancy, and set its opacity, then, in IE9+*, you can set a transparent background color of the body. This works by overlaying semitransparent white to make the image whiter, and appear to be brighter. For example, white with 75% opacity (rgba(255,255,255,.75)) would produce the following effect.






                                                            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>







                                                            • Tip: notice how the HTML is position: relative, while the body is position: absolute. This is to prevent the background color of the body from behaving more like a highlighter of the text in the body.


                                                            This could even be expanded to something comparable to, but still very distinct from, CSS filters by changing around the body's RGBA color background. For example, rgba(0,255,0,.75) would create a very green tint as you can see in the code snippet.






                                                            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>







                                                            • Tip: RGBA corresponds to RedGreenBlueAlpha. So, the browser interprets rgba(0,255,0,.75) as something exemplified by {red:0, green:255, blue:0, alpha:'75%'}.





                                                            *A full compatibility table can be found at Can I Use. However, please also note that you need to click the "Show All" to see that IE9 supports it.






                                                            Addendum



                                                            Since I have already answered the question but I have more I want to add, I am titling this section addendum and having it add some potentially helpful information. So, to extrapolate even further on the content above, you could use an SVG as a background image to do wicked awesome things. For example, you could create a loading screen background featuring a cool website icon as you can see in the example of a base64 encoded SVG below.






                                                            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>







                                                            • Tip: The background-size: cover CSS causes the SVG logo in the background to be resized to the size of the HTML element.






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





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





                                                            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>





                                                            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>





                                                            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>





                                                            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>





                                                            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>





                                                            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>






                                                            share|improve this answer














                                                            share|improve this answer



                                                            share|improve this answer








                                                            edited May 29 '17 at 21:57

























                                                            answered May 28 '17 at 22:40









                                                            3.14159265358979323846264338333.1415926535897932384626433833

                                                            437




                                                            437























                                                                0














                                                                Well the only CSS way of doing only background transparency is via RGBa but since you want to use an image I would suggest using Photoshop or Gimp to make the image transparent and then using it as the background.






                                                                share|improve this answer
























                                                                • This is not correct, there is a CSS3 declaration: opactiy: 1;, not just RGBa.

                                                                  – Kyle
                                                                  Nov 15 '10 at 11:49








                                                                • 4





                                                                  What he is saying is setting the background-image style on a container and then setting an opacity style on the same element. That would also make the text and other contents of that element transparent. Try this out if you don't believe me: w3schools.com/Css/tryit.asp?filename=trycss_transparency

                                                                  – Glenn Nelson
                                                                  Nov 15 '10 at 15:57
















                                                                0














                                                                Well the only CSS way of doing only background transparency is via RGBa but since you want to use an image I would suggest using Photoshop or Gimp to make the image transparent and then using it as the background.






                                                                share|improve this answer
























                                                                • This is not correct, there is a CSS3 declaration: opactiy: 1;, not just RGBa.

                                                                  – Kyle
                                                                  Nov 15 '10 at 11:49








                                                                • 4





                                                                  What he is saying is setting the background-image style on a container and then setting an opacity style on the same element. That would also make the text and other contents of that element transparent. Try this out if you don't believe me: w3schools.com/Css/tryit.asp?filename=trycss_transparency

                                                                  – Glenn Nelson
                                                                  Nov 15 '10 at 15:57














                                                                0












                                                                0








                                                                0







                                                                Well the only CSS way of doing only background transparency is via RGBa but since you want to use an image I would suggest using Photoshop or Gimp to make the image transparent and then using it as the background.






                                                                share|improve this answer













                                                                Well the only CSS way of doing only background transparency is via RGBa but since you want to use an image I would suggest using Photoshop or Gimp to make the image transparent and then using it as the background.







                                                                share|improve this answer












                                                                share|improve this answer



                                                                share|improve this answer










                                                                answered Nov 15 '10 at 11:41









                                                                Glenn NelsonGlenn Nelson

                                                                3,02273555




                                                                3,02273555













                                                                • This is not correct, there is a CSS3 declaration: opactiy: 1;, not just RGBa.

                                                                  – Kyle
                                                                  Nov 15 '10 at 11:49








                                                                • 4





                                                                  What he is saying is setting the background-image style on a container and then setting an opacity style on the same element. That would also make the text and other contents of that element transparent. Try this out if you don't believe me: w3schools.com/Css/tryit.asp?filename=trycss_transparency

                                                                  – Glenn Nelson
                                                                  Nov 15 '10 at 15:57



















                                                                • This is not correct, there is a CSS3 declaration: opactiy: 1;, not just RGBa.

                                                                  – Kyle
                                                                  Nov 15 '10 at 11:49








                                                                • 4





                                                                  What he is saying is setting the background-image style on a container and then setting an opacity style on the same element. That would also make the text and other contents of that element transparent. Try this out if you don't believe me: w3schools.com/Css/tryit.asp?filename=trycss_transparency

                                                                  – Glenn Nelson
                                                                  Nov 15 '10 at 15:57

















                                                                This is not correct, there is a CSS3 declaration: opactiy: 1;, not just RGBa.

                                                                – Kyle
                                                                Nov 15 '10 at 11:49







                                                                This is not correct, there is a CSS3 declaration: opactiy: 1;, not just RGBa.

                                                                – Kyle
                                                                Nov 15 '10 at 11:49






                                                                4




                                                                4





                                                                What he is saying is setting the background-image style on a container and then setting an opacity style on the same element. That would also make the text and other contents of that element transparent. Try this out if you don't believe me: w3schools.com/Css/tryit.asp?filename=trycss_transparency

                                                                – Glenn Nelson
                                                                Nov 15 '10 at 15:57





                                                                What he is saying is setting the background-image style on a container and then setting an opacity style on the same element. That would also make the text and other contents of that element transparent. Try this out if you don't believe me: w3schools.com/Css/tryit.asp?filename=trycss_transparency

                                                                – Glenn Nelson
                                                                Nov 15 '10 at 15:57











                                                                0














                                                                I just added position=absolute,top=0,width=100% in the #main and set the opacity value to the #background



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


                                                                I applied the background to a div before the main.






                                                                share|improve this answer




























                                                                  0














                                                                  I just added position=absolute,top=0,width=100% in the #main and set the opacity value to the #background



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


                                                                  I applied the background to a div before the main.






                                                                  share|improve this answer


























                                                                    0












                                                                    0








                                                                    0







                                                                    I just added position=absolute,top=0,width=100% in the #main and set the opacity value to the #background



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


                                                                    I applied the background to a div before the main.






                                                                    share|improve this answer













                                                                    I just added position=absolute,top=0,width=100% in the #main and set the opacity value to the #background



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


                                                                    I applied the background to a div before the main.







                                                                    share|improve this answer












                                                                    share|improve this answer



                                                                    share|improve this answer










                                                                    answered Mar 6 '17 at 4:02









                                                                    lazylazy

                                                                    289




                                                                    289























                                                                        -1














                                                                        I came across this post as I had the same issue then I thought why mess about with css, adjusting values and hitting refresh when you can easily adjust the opacity in Photoshop? Copy the image, paste it as a new layer then move the opacity slider.






                                                                        share|improve this answer



















                                                                        • 2





                                                                          ArtB got it right w/ the last note. This is a perfectly fine solution for another problem. There are times when this isn't the right solution and this is one of them.

                                                                          – jon
                                                                          Aug 4 '13 at 20:27
















                                                                        -1














                                                                        I came across this post as I had the same issue then I thought why mess about with css, adjusting values and hitting refresh when you can easily adjust the opacity in Photoshop? Copy the image, paste it as a new layer then move the opacity slider.






                                                                        share|improve this answer



















                                                                        • 2





                                                                          ArtB got it right w/ the last note. This is a perfectly fine solution for another problem. There are times when this isn't the right solution and this is one of them.

                                                                          – jon
                                                                          Aug 4 '13 at 20:27














                                                                        -1












                                                                        -1








                                                                        -1







                                                                        I came across this post as I had the same issue then I thought why mess about with css, adjusting values and hitting refresh when you can easily adjust the opacity in Photoshop? Copy the image, paste it as a new layer then move the opacity slider.






                                                                        share|improve this answer













                                                                        I came across this post as I had the same issue then I thought why mess about with css, adjusting values and hitting refresh when you can easily adjust the opacity in Photoshop? Copy the image, paste it as a new layer then move the opacity slider.







                                                                        share|improve this answer












                                                                        share|improve this answer



                                                                        share|improve this answer










                                                                        answered Jun 1 '12 at 16:56









                                                                        MBMMBM

                                                                        151




                                                                        151








                                                                        • 2





                                                                          ArtB got it right w/ the last note. This is a perfectly fine solution for another problem. There are times when this isn't the right solution and this is one of them.

                                                                          – jon
                                                                          Aug 4 '13 at 20:27














                                                                        • 2





                                                                          ArtB got it right w/ the last note. This is a perfectly fine solution for another problem. There are times when this isn't the right solution and this is one of them.

                                                                          – jon
                                                                          Aug 4 '13 at 20:27








                                                                        2




                                                                        2





                                                                        ArtB got it right w/ the last note. This is a perfectly fine solution for another problem. There are times when this isn't the right solution and this is one of them.

                                                                        – jon
                                                                        Aug 4 '13 at 20:27





                                                                        ArtB got it right w/ the last note. This is a perfectly fine solution for another problem. There are times when this isn't the right solution and this is one of them.

                                                                        – jon
                                                                        Aug 4 '13 at 20:27











                                                                        -1














                                                                        I had a similar issue and I just took the background image with photoshop and created a new .png with the opacity I needed. Problem solved without worrying about if my CSS worked accross all devices & browsers






                                                                        share|improve this answer




























                                                                          -1














                                                                          I had a similar issue and I just took the background image with photoshop and created a new .png with the opacity I needed. Problem solved without worrying about if my CSS worked accross all devices & browsers






                                                                          share|improve this answer


























                                                                            -1












                                                                            -1








                                                                            -1







                                                                            I had a similar issue and I just took the background image with photoshop and created a new .png with the opacity I needed. Problem solved without worrying about if my CSS worked accross all devices & browsers






                                                                            share|improve this answer













                                                                            I had a similar issue and I just took the background image with photoshop and created a new .png with the opacity I needed. Problem solved without worrying about if my CSS worked accross all devices & browsers







                                                                            share|improve this answer












                                                                            share|improve this answer



                                                                            share|improve this answer










                                                                            answered Jan 21 '14 at 20:28









                                                                            AebaresAebares

                                                                            17




                                                                            17






























                                                                                draft saved

                                                                                draft discarded




















































                                                                                Thanks for contributing an answer to Stack Overflow!


                                                                                • Please be sure to answer the question. Provide details and share your research!

                                                                                But avoid



                                                                                • Asking for help, clarification, or responding to other answers.

                                                                                • Making statements based on opinion; back them up with references or personal experience.


                                                                                To learn more, see our tips on writing great answers.




                                                                                draft saved


                                                                                draft discarded














                                                                                StackExchange.ready(
                                                                                function () {
                                                                                StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f4183948%2fcan-i-set-background-image-and-opacity-in-the-same-property%23new-answer', 'question_page');
                                                                                }
                                                                                );

                                                                                Post as a guest















                                                                                Required, but never shown





















































                                                                                Required, but never shown














                                                                                Required, but never shown












                                                                                Required, but never shown







                                                                                Required, but never shown

































                                                                                Required, but never shown














                                                                                Required, but never shown












                                                                                Required, but never shown







                                                                                Required, but never shown







                                                                                Popular posts from this blog

                                                                                Xamarin.iOS Cant Deploy on Iphone

                                                                                Glorious Revolution

                                                                                Dulmage-Mendelsohn matrix decomposition in Python