Creating Background Blur Effects with CSS: `filter: blur()` and `backdrop-filter`

Learn different techniques for creating background blur effects in CSS, using both `filter: blur()` and the more advanced `backdrop-filter`. This tutorial explains how to apply blur effects, control blur intensity, and prevent blurring of content using pseudo-elements, enabling you to create visually engaging and sophisticated web page designs.



Creating Background Blur Effects with CSS

Background Blur using `filter: blur()`

Creating a blurred background effect is a common design technique to draw attention to specific elements on a page or to create a more visually appealing design. You can achieve a background blur effect using the `filter: blur()` property in CSS, although it affects the entire element and its children. It creates a Gaussian blur, blurring the element's content and any background images. The blur radius (a length value like `5px`) determines the intensity of the blur; higher values create a stronger blur effect.

Example CSS

.blurred-background {
  filter: blur(5px); /* Adjust the blur radius as needed */
}

To prevent the blur from affecting content within the element, use a pseudo-element (`::before` or `::after`) to create an overlay for the blurred background and set a higher `z-index` value for the actual content.

CSS `backdrop-filter`

The `backdrop-filter` property applies filter effects to the element's backdrop (the area behind the element). Unlike `filter`, which affects the element itself, `backdrop-filter` affects what's *behind* the element, allowing for unique visual effects. You can achieve blur, grayscale, sepia, and other filter effects on the area behind the element. You can also adjust the transparency of this effect using the alpha channel in the RGBA color model.

Example: Using `backdrop-filter`

This example shows how to use `backdrop-filter` to blur the area behind several elements. You'd need corresponding HTML to see this effect. The `backdrop-filter` property is applied directly to the element you want to style. Note that `backdrop-filter` only works if the element has some kind of transparency (e.g., `background-color: rgba(...)`).

Example CSS

.content {
  background-color: rgba(255, 255, 255, 0.8); /*Example semi-transparent background*/
  backdrop-filter: blur(10px); /* Adjust blur radius as needed */
  /* ... other styles ... */
}

Creating Blurred Backgrounds without `backdrop-filter`

You can also achieve a blurred background effect without `backdrop-filter` by using an overlay element. This often involves creating a pseudo-element (`::before` or `::after`) that sits behind the main content and applying the blur effect to that pseudo-element.

`backdrop-filter` Properties and Examples

The `backdrop-filter` property can accept various filter functions. Here are a few examples; you would need to have the corresponding HTML and CSS to see these in a browser. The `backdrop-filter` property is applied directly to the element you wish to style.

`blur()`

Applies a Gaussian blur to the backdrop. The value is the blur radius (e.g., `blur(10px)`).

`brightness()`

Adjusts the backdrop's brightness. Values above 100% brighten; below 100% darken.

`contrast()`

Adjusts the backdrop's contrast. Values above 100% increase contrast; below 100% decrease contrast.

`hue-rotate()`

Rotates the hue of the backdrop colors. The value is an angle in degrees.

Applying Filter Effects with CSS `filter`

Introduction to CSS Filters

CSS filters allow you to apply various visual effects to HTML elements, enhancing their appearance and adding visual interest to your web pages. These effects are applied to an element's content and background before the element is rendered, providing a simple and efficient method to achieve many graphical manipulations.

CSS Filter Functions

Several filter functions are available. These functions modify various aspects of an element's visual presentation, such as color, brightness, contrast, blur, saturation, and more.

`hue-rotate()`

Rotates the hue (color) of an image around a color wheel. The value is an angle in degrees (e.g., `hue-rotate(90deg)`). Higher values shift the colors towards warmer or cooler tones depending on the direction of the rotation.

Example CSS

.element {
  filter: hue-rotate(90deg);
}

`saturate()`

Adjusts the color saturation. Values below 100% desaturate the image (moving it towards grayscale); values above 100% increase saturation (making colors more vibrant).

Example CSS

.element {
  filter: saturate(150%);
}

`grayscale()`

Converts the image to grayscale. A value of 0% is the original image; 100% is full grayscale. Values between 0% and 100% create a partial grayscale effect.

Example CSS

.element {
  filter: grayscale(100%);
}

`invert()`

Inverts the colors of the image. A value of 0% is the original image; 100% is completely inverted.

Example CSS

.element {
  filter: invert(100%);
}

`sepia()`

Applies a sepia tone to the image. 0% is the original image; 100% is full sepia. Values between 0% and 100% create a partial sepia effect.

Example CSS

.element {
  filter: sepia(100%);
}

`drop-shadow()`

Adds a drop shadow effect to the element. The syntax is: `drop-shadow(offset-x offset-y blur-radius color)`.

Example CSS

.element {
  filter: drop-shadow(4px 4px 8px rgba(0, 0, 0, 0.2));
}

`opacity()`

Controls the transparency of the element. 0% is completely transparent; 100% is fully opaque.

Example CSS

.element {
  filter: opacity(70%);
}

`url()` (for SVG Filters)

Applies an SVG filter to the element. You provide the URL of the SVG file containing the filter definition.

Applying Multiple Filters

You can combine multiple filter functions by separating them with spaces. This allows for creating a complex and customized visual effect.

Example CSS

.element {
  filter: blur(2px) grayscale(50%);
}