Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

CSS background image to fit width, height should auto-scale in proportion

Tags:

html

css

I have

body {     background: url(images/background.svg); } 

The desired effect is that this background image will have width equal to that of the page, height changing to maintain the proportion. e.g. if the original image happens to be 100*200 (any units) and the body is 600px wide, the background image should end up being 1200px high. The height should change automatically if the window is resized. Is this possible?

At the moment, Firefox looks like it's making the height fit and then adjusting the width. Is this perhaps because the height is the longest dimension and it's trying to avoid cropping? I want to crop vertically, then scroll: no horizontal repeat.

Also, Chrome is placing the image in the centre, no repeat, even when background-repeat:repeat is given explicitly, which is the default anyway.

like image 818
spraff Avatar asked Feb 13 '12 15:02

spraff


People also ask

How do you autofit a background image in CSS?

There are four different syntaxes you can use with this property: the keyword syntax ("auto", "cover" and "contain"), the one-value syntax (sets the width of the image (height becomes "auto"), the two-value syntax (first value: width of the image, second value: height), and the multiple background syntax (separated ...

How do I stretch a background image in CSS to fit the screen?

When you work with background images, you may want an image to stretch to fit the page despite the wide range of devices and screen sizes. The best way to stretch an image to fit the background of an element is to use the CSS3 property, for background-size, and set it equal to cover.

How do I scale an image to fit CSS?

The CSS object-fit property is used to specify how an <img> or <video> should be resized to fit its container. This property tells the content to fill the container in a variety of ways; such as "preserve that aspect ratio" or "stretch up and take up as much space as possible".

How would you change the size of the background image so it fits the entire page?

Use background-size property to cover the entire viewport The CSS background-size property can have the value of cover . The cover value tells the browser to automatically and proportionally scale the background image's width and height so that they are always equal to, or greater than, the viewport's width/height.


1 Answers

There is a CSS3 property for this, namely background-size (compatibility check). While one can set length values, it's usually used with the special values contain and cover. In your specific case, you should use cover:

body {     background-image:    url(images/background.svg);     background-size:     cover;                      /* <------ */     background-repeat:   no-repeat;     background-position: center center;              /* optional, center the image */ } 

Eggsplanation for contain and cover

Sorry for the bad pun, but I'm going to use the picture of the day by Biswarup Ganguly for demonstration. Lets say that this is your screen, and the gray area is outside of your visible screen. For demonstration, I'm going to assume a 16x9 ratio.

screen

We want to use the aforementioned picture of the day as a background. However, we cropped the image to 4x3 for some reason. We could set the background-size property to some fixed length, but we will focus on contain and cover. Note that I also assume that we didn't mangle the width and/or height of body.

contain

contain 

Scale the image, while preserving its intrinsic aspect ratio (if any), to the largest size such that both its width and its height can fit inside the background positioning area.

This makes sure that the background image is always completely contained in the background positioning area, however, there could be some empty space filled with your background-color in this case:

contain

cover

cover 

Scale the image, while preserving its intrinsic aspect ratio (if any), to the smallest size such that both its width and its height can completely cover the background positioning area.

This makes sure that the background image is covering everything. There will be no visible background-color, however depending on the screen's ratio a great part of your image could be cut off:

cover

Demonstration with actual code

div > div {    background-image: url(http://i.stack.imgur.com/r5CAq.jpg);    background-repeat: no-repeat;    background-position: center center;    background-color: #ccc;    border: 1px solid;    width: 20em;    height: 10em;  }  div.contain {    background-size: contain;  }  div.cover {    background-size: cover;  }  /********************************************   Additional styles for the explanation boxes   *********************************************/    div > div {    margin: 0 1ex 1ex 0;    float: left;  }  div + div {    clear: both;    border-top: 1px dashed silver;    padding-top:1ex;  }  div > div::after {    background-color: #000;    color: #fefefe;    margin: 1ex;    padding: 1ex;    opacity: 0.8;    display: block;    width: 10ex;    font-size: 0.7em;    content: attr(class);  }
<div>    <div class="contain"></div>    <p>Note the grey background. The image does not cover the whole region, but it's fully <em>contained</em>.    </p>  </div>  <div>    <div class="cover"></div>    <p>Note the ducks/geese at the bottom of the image. Most of the water is cut, as well as a part of the sky. You don't see the complete image anymore, but neither do you see any background color; the image <em>covers</em> all of the <code>&lt;div&gt;</code>.</p>  </div>
like image 179
Zeta Avatar answered Oct 20 '22 06:10

Zeta