This is an experimental technology
Because this technology's specification has not stabilized, check the compatibility table for usage in various browsers. Also note that the syntax and behavior of an experimental technology is subject to change in future versions of browsers as the specification changes.
The image-rendering
CSS property provides a hint to the browser about the algorithm it should use to scale images. It applies to the element itself as well as any images supplied in other properties for the element. It has no effect on non-scaled images.
For example, if the natural size of the image is 100×100px but the page author specifies its dimensions as 200×200px
(or 50×50px
), then the image will be upscaled (or downscaled) to the new dimensions using the specified algorithm. Scaling may also apply due to user interaction (zooming).
Initial value | auto |
---|---|
Applies to | all elements |
Inherited | yes |
Media | visual |
Computed value | as specified |
Animatable | no |
Canonical order | the unique non-ambiguous order defined by the formal grammar |
image-rendering: auto; image-rendering: crisp-edges; image-rendering: pixelated; /* Global values */ image-rendering: inherit; image-rendering: initial; image-rendering: unset;
auto
crisp-edges
pixelated
optimizeQuality
and optimizeSpeed
present in early draft (and coming from its SVG counterpart) are defined as synonyms for the auto
value.auto | crisp-edges | pixelated
/* applies to GIF and PNG images; avoids blurry edges */ img[src$=".gif"], img[src$=".png"] { image-rendering: -moz-crisp-edges; /* Firefox */ image-rendering: -o-crisp-edges; /* Opera */ image-rendering: -webkit-optimize-contrast;/* Webkit (non-standard naming) */ image-rendering: crisp-edges; -ms-interpolation-mode: nearest-neighbor; /* IE (non-standard property) */ }
div { background: url(chessboard.gif) no-repeat 50% 50%; image-rendering: -moz-crisp-edges; /* Firefox */ image-rendering: -o-crisp-edges; /* Opera */ image-rendering: -webkit-optimize-contrast;/* Webkit (non-standard naming) */ image-rendering: crisp-edges; -ms-interpolation-mode: nearest-neighbor; /* IE (non-standard property) */ }
78% 100% 138% downsized upsized
78% 100% 138% downsized upsized
78% 100% 138% downsized upsized
Specification | Status | Comment |
---|---|---|
CSS Image Values and Replaced Content Module Level 3 The definition of 'image-rendering' in that specification. | Candidate Recommendation | Initial definition |
Though initially close from the SVG image-rendering
property, the values are quite different now.
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|
Basic support (auto ) | (Yes) | 3.6 (1.9.2) | No support[1] | 11.60 | (Yes) |
crisp-edges | No support | 3.6 (1.9.2)-moz | No support | 11.60-o | (Yes) [2] |
pixelated | 41.0 | No support (bug 856337) | No support | 26.0 | (Yes) [3] |
optimizeQuality , optimizeSpeed
| No support | 3.6 (1.9.2) | No support | 11.60 | (Yes) |
Feature | Android | Firefox Mobile (Gecko) | IE Phone | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|
Basic support | 41.0 | ? | ? | ? | ? |
[1] Internet Explorer 7 and 8 supports the non-standard -ms-interpolation-mode
property with two values (bicubic
and nearest-neighbor
):
nearest-neighbor
(low quality) bicubic
(high quality)[2] Supported with a non-standard name: -webkit-optimize-contrast
.
[3] WebKit Nightly support, see bug
Canvas can provide a fallback solution for crisp-edge/optimize-contrast through manual imageData manipulation.
© 2005–2017 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/CSS/image-rendering