Introduction
We can determine the size of the background image with the help of the background-size property. We can make the image as left, stretched, and fit for the available space. There are so many syntaxes for the implementation of the background-size property. We can set the property of background-size property with the help of values and unit values.
In unit values, we can define the background-size property in the form of percentages or pixels. We can define it with the help of global value also. We can implement it with the help of global value through the help of the below snippet.
.card-hero{
background-size: cover| 30%| 300px 250px| inherit
}
Let's understand the topic briefly.
Keyword values
We have the option to utilize the keyword value in conjunction with cover and contain. By employing these keyword values, we can adjust the background size accordingly.
1. Cover:
We can adjust the size of the background using the cover keyword. When we specify the background size as cover, the image will completely fill the container without any gaps. This setting will also improve the appearance of the image to fill the entire screen.
Let's grasp this concept better using the following example.
Example 1:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body {
margin: 0;
padding: 0;
font-family: Arial, sans-serif;
background-color: #f0f0f0;
}
.background-container {
position: relative;
width: 100vw;
height: 100vh;
background-image: url("https://e0.pxfuel.com/wallpapers/163/906/desktop-wallpaper-beautiful-nature-with-girl-beautiful-girl-with-nature-and-moon-high-resolution-beautiful.jpg");
background-size: cover;
background-position: center;
text-align: center;
color: white;
}
.background-container h1 {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
font-size: 2.5rem;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}
</style>
</head>
<body>
<div class="background-container">
<h1>Welcome to Nature's Beauty</h1>
</div>
</body>
</html>
Output
Explanation:
In the provided code snippet, the background-size attribute is set to cover to ensure that the image expands correctly and fits within the designated container.
2. Contain:
We can specify the background-size property using the keyword "contain". When we set the background-size to "contain", the image will be resized entirely to fit within the container without losing visibility. This scaling ensures that the image fits inside the container without any cropping.
Let's grasp this concept using the following example.
Example 2:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body {
margin: 0;
padding: 0;
font-family: Arial, sans-serif;
background-color: #f0f0f0;
}
.background-container {
position: relative;
width: 100vw;
height: 100vh;
background-image: url("https://media.istockphoto.com/id/1066602804/photo/idyllic-forest-at-sunrise.jpg?s=612x612&w=0&k=20&c=pdvtxNoKnouLEgIexWQua1bs0bYyQuccMtCHcPloQbs=");
background-size: contain;
background-repeat: no-repeat;
background-position: center;
text-align: center;
color: white;
}
.background-container h1 {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
font-size: 2.5rem;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}
</style>
</head>
<body>
<div class="background-container">
<h1>Welcome to Tranquil Forest</h1>
</div>
</body>
</html>
Output
Explanation:
In the preceding code, the background size has been set to "contain" to ensure the image fits inside the .background-container while preserving its aspect ratio. The background-repeat property with a value of "no-repeat" guarantees that the background image is not replicated.
NOTE: We can also use the background size as an auto. If we do this, then the image will be displayed in its original size. Auto is the default value for the background-size property.
Unit Values
We also have the option to define the background-size property using a unit value, which can be specified in pixels or percentages. The following examples demonstrate how to apply a unit value as the property value.
.card-hero{
background size: 15%;
}
.card-hero{
background-size: 400px;
}
.card-hero{
background-size: 30vw;
}
Let's consider an example demonstrating the unit value represented as a percentage.
Example 3:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body {
margin: 0;
padding: 0;
font-family: Arial, sans-serif;
background-color: #f0f0f0;
}
.background-container {
position: relative;
width: 100vw;
height: 100vh;
background-image: url("https://media.istockphoto.com/id/173593840/photo/vast-dry-land.jpg?s=612x612&w=0&k=20&c=LJd25zcGE5FNqVGasVliRW78af0Fu7RQixWa0EN7Bqw=");
background-size: contain;
background-repeat: no-repeat;
background-position: center;
text-align: center;
color: white;
}
.background-container h1 {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
font-size: 2.5rem;
text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.7);
}
</style>
</head>
<body>
<div class="background-container">
<h1>Exploring Vast Horizons</h1>
</div>
</body>
</html>
Output
Explanation:
In the provided code snippet, we have the flexibility to modify the percentage values within the background-size property. This adjustment enables us to manage the width and height of the image concerning the container.
Global Values
We can also specify a global value in the background-size property. Examples of these values include the following.
1. Inherit
By utilizing this keyword, we have the capability to modify the characteristics of the element to resemble those of the parent element. Essentially, this introduces the concept of inheritance into the scenario.
Example 4:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body {
margin: 0;
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background-color: #f0f0f0;
}
.container {
width: 300px;
height: 200px;
background-image: url('your-image-url.jpg');
background-size: inherit; /* Inherits the background size from the parent */
display: flex;
justify-content: center;
align-items: center;
}
.box {
width: 150px;
height: 100px;
background-color: rgba(255, 0, 0, 0.5);
}
</style>
</head>
<body>
<div class="container">
<div class="box"></div>
</div>
</body>
</html>
Output
Explanation:
In the provided code snippet, a div element has been nested within another div element. The background-size property with a value of inherit within the .container class results in the background image of the container element inheriting the dimensions of its parent element, which, in this instance, is the body element. The body element is styled with a light gray background color.
2. Initial
By utilizing this keyword, we have the ability to modify the starting value of the element through specifying a new initial value. Additionally, there are predefined default values available. To grasp this concept better, let's delve into an illustrative example.
Example 5:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
margin: 0;
padding: 0;
font-family: Arial, sans-serif;
}
.hero {
position: relative;
height: 100vh;
background-image: url("https://img.freepik.com/premium-photo/beautiful-wooden-path-plitvice-lake-croatia_31965-3194.jpg");
background-size: initial; /* Using initial to maintain the image's intrinsic size */
background-position: center;
background-repeat: no-repeat;
color: white;
text-align: center;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.hero-content {
padding: 20px;
background-color: rgba(0, 0, 0, 0.5);
border-radius: 10px;
}
.hero h1 {
font-size: 3rem;
margin-bottom: 10px;
}
.hero p {
font-size: 1.2rem;
}
</style>
<title>Initial Background Size Example</title>
</head>
<body>
<div class="hero">
<div class="hero-content">
<h1>Welcome to C# Programming</h1>
<p>Discover Amazing Designs</p>
</div>
</div>
</body>
</html>
Output
Explanation:
In the preceding code snippet, a hero class has been established, wherein the background size property has been set to "initial." This particular setting guarantees that the background image retains its original dimensions. By leveraging this setup, it becomes possible to craft content in both vertical and horizontal orientations. Moreover, incorporating semi-transparent backgrounds and rounded corners can infuse a sense of sophistication into the overall design.
3. Unset
By utilizing the unset property, it is possible to substitute both the original and inherited properties. When the property is defined as inherit, the unset property will also inherit that value. Conversely, if the property is not set to inherit, the unset property will default to initial. The following example will illustrate this concept.
Example 6:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
margin: 0;
padding: 0;
font-family: Arial, sans-serif;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
background-color: #f0f0f0;
}
.container {
width: 400px;
height: 300px;
background-image: url("https://img.freepik.com/premium-photo/beautiful-wooden-path-plitvice-lake-croatia_31965-3194.jpg");
background-size: unset;
border-radius: 10px;
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
overflow: hidden;
position: relative;
}
.overlay {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.5);
opacity: 0.8;
}
.content {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
color: #fff;
}
.content h1 {
margin: 0;
font-size: 24px;
}
.content p {
margin: 10px 0;
font-size: 16px;
}
</style>
<title>Background Size Example</title>
</head>
<body>
<div class="container">
<div class="overlay"></div>
<div class="content">
<h1>Welcome to C# Programming</h1>
<p>Discover a world of creativity and inspiration.</p>
</div>
</div>
</body>
</html>
Output
Explanation:
In the provided code snippet, the background-size attribute has been specified as unset. This setting enables the background image to maintain its original dimensions. This design features a centrally positioned container with an overlay and content. The overlay offers a partially transparent backdrop to enhance the readability of the text, while the content is precisely centered inside the container.
One Value
When a single value is required in the code, it is advisable to specify just that one value. By assigning a value to one parameter, the other parameter is automatically determined. This concept can be illustrated with an example.
Example 7:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
margin: 0;
padding: 0;
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background-color: #f4f4f4;
background-image: url("https://img.freepik.com/premium-photo/creative-mind-3d-illustration-with-light-bulb-generative-ai_549702-683.jpg?w=2000");
background-size: 70%; /* Adjusts the background-size */
background-repeat: no-repeat;
background-position: center;
font-family: Arial, sans-serif;
}
.content {
text-align: center;
padding: 2rem;
background-color: rgba(255, 255, 255, 0.9);
border-radius: 10px;
box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
}
h1 {
color: #333;
font-size: 2.5rem;
margin-bottom: 1rem;
}
p {
color: #666;
font-size: 1.2rem;
}
</style>
<title>Background Size Percentage Example</title>
</head>
<body>
<div class="content">
<h1>Welcome to C# Programming</h1>
<p>Where imagination meets design.</p>
</div>
</body>
</html>
Output
Explanation:
In the provided code snippet, the background-size attribute has been defined as 70%. This indicates that the background will occupy 70% of the total webpage area while preserving its original aspect ratio.
Two Value
If two values are specified for the background-size property, it will impact both the height and width of the background image. The initial value determines the height of the image while the subsequent value determines the width. To illustrate this concept, let's delve into an example.
Example 8:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
margin: 0;
padding: 0;
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background-color: #f4f4f4;
background-image: url("https://img.freepik.com/premium-photo/abstract-fusion-kaleidoscope-colors-shapes-where-creativity-knows-no-bounds_884630-1614.jpg");
background-size: 60% 80%; /* Adjusts the background-size */
background-repeat: no-repeat;
background-position: center;
font-family: Arial, sans-serif;
}
.content {
text-align: center;
padding: 2rem;
background-color: rgba(255, 255, 255, 0.9);
border-radius: 10px;
box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
}
h1 {
color: #333;
font-size: 2.5rem;
margin-bottom: 1rem;
}
p {
color: #666;
font-size: 1.2rem;
}
</style>
<title>Background Size Two-Value Example</title>
</head>
<body>
<div class="content">
<h1>Welcome to C# Programming</h1>
<p>Where creativity knows no bounds.</p>
</div>
</body>
</html>
Output
Explanation:
In the provided code snippet, the background-size is configured to range between 60% and 80%. The initial value (60%) determines the width of the background image as 60% of the total webpage width, whereas the subsequent value (80%) determines the height of the background image as 80% of the webpage's height.
Multiple Images
We can also designate multiple images to serve as the background image. This can be accomplished by specifying several images separated by commas. To illustrate this concept, let's consider an example.
Example 9:
Code:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
margin: 0;
padding: 0;
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
background-color: #f4f4f4;
background-image: url(""), url("https://img.freepik.com/premium-photo/beautiful-landscape-based-3d-rendering-illustration_771975-25.jpg?w=2000"), url("https://static.vecteezy.com/system/resources/previews/022/448/291/original/save-earth-day-poster-environment-day-nature-green-ai-generative-glossy-background-images-tree-and-water-free-photo.jpg");
background-size: 30%, 40%, cover; /* Adjusts the background-size */
background-repeat: no-repeat, no-repeat, no-repeat;
background-position: left top, right top, center;
font-family: Arial, sans-serif;
}
.content {
text-align: center;
padding: 2rem;
background-color: rgba(255, 255, 255, 0.9);
border-radius: 10px;
box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
}
h1 {
color: #333;
font-size: 2.5rem;
margin-bottom: 1rem;
}
p {
color: #666;
font-size: 1.2rem;
}
</style>
<title>Combined Background Images Example</title>
</head>
<body>
<div class="content">
<h1>Welcome to C# Programming</h1>
<p>Where every step unveils a new wonder.</p>
</div>
</body>
</html>
Output
Explanation:
In the provided code snippet, three background images are merged using the background-image attribute. The background-size declaration defines the dimensions for each individual background image: 30% width for the initial image, 40% width for the second image, and a cover size for the third image. To achieve a harmonious layout, distinct values are assigned to the background-position attribute for each image.