Duotone using CSS blend modes
data:image/s3,"s3://crabby-images/28d02/28d02199792f43d45c1a0944565e1285dd41ef27" alt="José M. Pérez"
José M. Pérez / October 26, 2017
1 min read • 10,961 views
In a past post I explained how to use SVG and a feColorMatrix
filter to apply a duotone effect to an image. This time I'm going to show how to achieve a similar effect with only CSS.
data:image/s3,"s3://crabby-images/2d80f/2d80fa3227f8866faafdfd4345d3f515a5f3d068" alt="Duotone effect on image using CSS blend modes"
Demo & Code: https://codepen.io/jmperez/pen/wrVxga
The code consists of a <div/>
that has an image set as a background. Then, we add a ::before
and an ::after
pseudo-elements with the colours we want to apply and the right blend modes.
Previously, my colleague Thodoris described how to achieve this effect in JS using Canvas and in iOS. I also reproduced it using SVG and a feColorMatrix
filter.
This version is based on the technique described by Una Kravets:
Duotone images are so #trendy right now 😎 Had some airport time so I drew out how to get this effect w/one div in CSS 😊 #devdoodles
which is also what the colofilter.css library is based on to achieve the duotone effect.