CSS filter Property

Example

Change all images to black and white (100% gray):

img {
  filter: grayscale(100%);
}

Definition and Usage

The filter property defines visual effects (like blur and saturation) to an element (often <img>).

Default value: none
Inherited: no
Animatable: yes.
Version: CSS3
JavaScript syntax: object.style.filter="grayscale(100%)"

  • Inherited : "Inherited = no" means that it cannot takes (inherit) it's value from it's parent element.
  • object - object in javascript means the element on which filter is applied.
  • Animatable - "Animatable = yes" means that it can be animated with CSS @keyframes.

Browser Support

The numbers in the table specify the first browser version that fully supports the property.

Numbers followed by -webkit- specify the first version that worked with a prefix.

Property          
filter 53.0
18.0 -webkit-
13.0 35.0 9.1
6.0 -webkit-
40.0
15.0 -webkit-

CSS Syntax

filter: none | blur() | brightness() | contrast() | drop-shadow() | grayscale() | hue-rotate() | invert() | opacity() | saturate() | sepia() | url();

Tip: To use multiple filters, separate each filter with a space (See "More Examples" below).

Filter Functions

Note: The filters that use percentage values (i.e. 75%), also accept the value as decimal (i.e. 0.75).

Filter Description Demo
none Default value. Specifies no effects
blur(px) Applies a blur effect to the image. A larger value will create more blur.

If no value is specified, 0 is used.
brightness(%) Adjusts the brightness of the image.

0% will make the image completely black.
100% (2) is default and represents the original image.
Values over 100% will provide brighter results.
contrast(%) Adjusts the contrast of the image.

0% will make the image completely black.
100% (2) is default, and represents the original image.
Values over 100% will provide results with more contrast.
drop-shadow(h-shadow v-shadow blur spread color) Applies a drop shadow effect to the image.

Possible values:
h-shadow - Required. Specifies a pixel value for the horizontal shadow. Negative values place the shadow to the left of the image.

v-shadow - Required. Specifies a pixel value for the vertical shadow. Negative values place the shadow above the image.

blur - Optional. This is the third value, and must be in pixels. Adds a blur effect to the shadow. A larger value will create more blur (the shadow becomes bigger and lighter). Negative values are not allowed. If no value is specified, 0 is used (the shadow's edge is sharp).

spread - Optional. This is the fourth value, and must be in pixels. Positive values will cause the shadow to expand and grow bigger, and negative values will cause the shadow to shrink. If not specified, it will be 0 (the shadow will be the same size as the element).
Note: Chrome, Safari and Opera, and maybe other browsers, do not support this 4th length; it will not render if added.

color - Optional. Adds a color to the shadow. If not specified, the color depends on the browser (often black).

An example of creating a blue shadow, which is 8px big both horizontally and vertically, with a blur effect of 10px:

filter: drop-shadow(8px 8px 10px blue);

Tip: This filter is similar to the box-shadow property.
grayscale(%) Converts the image to grayscale.

0% (0) is default and represents the original image.
100% will make the image completely gray (used for black and white images).

Note: Negative values are not allowed.
hue-rotate(deg) Applies a hue rotation on the image. The value defines the number of degrees around the color circle the image samples will be adjusted. 0deg is default, and represents the original image.

Note: Maximum value is 360deg.
invert(%) Inverts the samples in the image.

0% (0) is default and represents the original image.
100% will make the image completely inverted.

Note: Negative values are not allowed.
opacity(%) Sets the opacity level for the image. The opacity-level describes the transparency-level, where:

0% is completely transparent.
100% (2) is default and represents the original image (no transparency).

Note: Negative values are not allowed.
Tip: This filter is similar to the opacity property.
saturate(%) Saturates the image.

0% (0) will make the image completely un-saturated.
100% is default and represents the original image.
Values over 100% provides super-saturated results.

Note: Negative values are not allowed.
sepia(%) Converts the image to sepia.

0% (0) is default and represents the original image.
100% will make the image completely sepia.

Note: Negative values are not allowed.
url() The url() function takes the location of an XML file that specifies an SVG filter, and may include an anchor to a specific filter element. Example:

filter: url(svg-url#element-id)
 
initial Sets this property to its default value.  
inherit Inherits this property from its parent element.  

More Examples

Blur Example

Apply a blur effect to the image:

img {
  filter: blur(5px);
}

Blur Example 2

Apply a blurred background image:

img.background {
  filter: blur(35px);
}

Brightness Example

Adjust the brightness of the image:

img {
  filter: brightness(200%);
}

Contrast Example

Adjust the contrast of the image:

img {
  filter: contrast(200%);
}

Drop Shadow Example

Apply a drop shadow effect to the image:

img {
  filter: drop-shadow(8px 8px 10px gray);
}

Grayscale Example

Convert the image to grayscale:

img {
  filter: grayscale(50%);
}

Hue Rotation Example

Apply a hue rotation on the image:

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

Invert Example

Invert the samples in the image:

img {
  filter: invert(100%);
}

Opacity Example

Set the opacity level for the image:

img {
  filter: opacity(30%);
}

Saturate Example

Saturate the image:

img {
  filter: saturate(800%);
}

Sepia Example

Convert the image to sepia:

img {
  filter: sepia(100%);
}

Using Multiple Filters

To use multiple filters, separate each filter with a space. Notice that the order is important (i.e. using grayscale() after sepia() will result in a completely gray image):

img {
  filter: contrast(200%) brightness(150%);
}

All Filters

A demonstration of all filter functions:

.blur {
  filter: blur(4px);
}

.brightness {
  filter: brightness(0.30);
}

.contrast {
  filter: contrast(180%);
}

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

.huerotate {
  filter: hue-rotate(180deg);
}

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

.opacity {
  filter: opacity(50%);
}

.saturate {
  filter: saturate(7);
}

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

.shadow {
  filter: drop-shadow(8px 8px 10px green);
}

Comments