web前端入门到实战:CSS新属性实现特殊的图片显示效果(css浮雕效果)
1 概述
1.1 前言
使用一个或多个图像相关的CSS属性(background-blend-mode, mix-blend-mode, or filter)可以实现许多特殊的图片显示效果,共列举了20种图片显示效果。
2 效果列表
2.1 铅笔画效果
效果示例
data:image/s3,"s3://crabby-images/76859/768599705b196c73e4cfe1e0c620033a6f04ee67" alt=""
SCSS代码
.pencil-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: invert(1)) and (background-blend-mode: difference) { background-image: $url, $url; background-blend-mode: difference; background-position: calc(50% - 1px) calc(50% - 1px), calc(50% + 1px) calc(50% + 1px); filter: brightness(2) invert(1) grayscale(1); box-shadow: inset 0 0 0 1px black; } }
我自己是一名从事了多年开发的web前端老程序员,目前辞职在做自己的web前端私人定制课程,今年年初我花了一个月整理了一份最适合2019年学习的web前端学习干货,各种框架都有整理,送给每一位前端小伙伴,想要获取的可以关注我的头条号并在后台私信我:前端,即可免费获取。
2.2 水彩效果
效果示例
data:image/s3,"s3://crabby-images/32817/3281720783c5de008ea5bb3207ff1e71a7f95fc4" alt=""
SCSS代码
.watercolor-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: blur(2px)) and (mix-blend-mode: multiply) { position: relative; overflow: hidden; &:before, &:after { display: block; content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-size: cover; } &:before { background-image: $url, $url; background-blend-mode: difference; background-position: calc(50% - 1px) calc(50% - 1px), calc(50% + 1px) calc(50% + 1px); filter: brightness(2) invert(1) grayscale(1); box-shadow: inset 0 0 0 1px black; } &:after { background-image: $url; background-position: center; mix-blend-mode: multiply; filter: brightness(1.3) blur(2px) contrast(2); } } }
2.3 浮雕效果
效果示例
data:image/s3,"s3://crabby-images/bf766/bf76658d3dfe12fede9e2f04ce8f230830645f23" alt=""
SCSS代码
.emboss-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: invert(1)) and (background-blend-mode: difference, screen) { background-image: $url, $url, $url; background-blend-mode: difference, screen; background-position: calc(50% - 1px) calc(50% - 1px), calc(50% + 1px) calc(50% + 1px), center; filter: brightness(2) invert(1) grayscale(1); } }
2.4 彩铅效果
效果示例
data:image/s3,"s3://crabby-images/196d5/196d5240e4507a3ffee967d69927df90d76de2ac" alt=""
SCSS代码
.colored-pencil-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: invert(1)) and (mix-blend-mode: color) { position: relative; &:before, &:after { display: block; content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-size: cover; box-shadow: inset 0 0 0 1px black; } &:before { background-image: $url, $url; background-blend-mode: difference; background-position: calc(50% - 1px) calc(50% - 1px), calc(50% + 1px) calc(50% + 1px); filter: brightness(2) invert(1) grayscale(1); } &:after { background: inherit; mix-blend-mode: color; } } }
2.5 黑板效果
效果示例
data:image/s3,"s3://crabby-images/67c09/67c0914561a326361c760bd2d8274f10ce64357a" alt=""
SCSS代码
.chalkboard-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: grayscale(1)) and (background-blend-mode: difference) { background-image: $url, $url; background-blend-mode: difference; background-position: calc(50% - 1px) calc(50% - 1px), calc(50% + 1px) calc(50% + 1px); filter: brightness(1.5) grayscale(1); } }
2.6 彩色黑板效果
效果示例
data:image/s3,"s3://crabby-images/6dd5f/6dd5f8a83fa8d5e38af3c2344d5718b106762be7" alt=""
SCSS代码
.colored-chalkboard-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: brightness(2)) and (background-blend-mode: color, difference) { background-image: $url, $url, $url; background-size: cover; background-position: calc(50% - 1px) calc(50% - 1px), calc(50% + 1px) calc(50% + 1px), center; background-blend-mode: color, difference; filter: brightness(2); } }
2.7 喷枪效果
效果示例
data:image/s3,"s3://crabby-images/70a56/70a56765854b449bd7f303cc26abb69661617e89" alt=""
SCSS代码
.airbrush-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: blur(5px) contrast(5)) and (mix-blend-mode: multiply) { position: relative; overflow: hidden; &:after { display: block; content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: inherit; filter: brightness(1.5) saturate(100) blur(5px) contrast(5); mix-blend-mode: multiply; } } }
2.8 绚烂效果
效果示例
data:image/s3,"s3://crabby-images/79ec4/79ec4404f55bf80cfde2bf981a32821411b4bce3" alt=""
SCSS代码
.hallucination-effect { $url : url(photo.jpg); $offset : 5px; background-image: $url; background-size: cover; background-position: center; @supports (mix-blend-mode: multiply) { position: relative; overflow: hidden; background-color: magenta; background-blend-mode: screen; &:before, &:after { display: block; content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: inherit; mix-blend-mode: multiply; transform: scale(1.05); } &:before { background-color: yellow; background-blend-mode: screen; transform-origin: top left; } &:after { background-color: cyan; background-blend-mode: screen; transform-origin: bottom right; } } }
2.9 绒布效果
效果示例
data:image/s3,"s3://crabby-images/07c5e/07c5ef9f5615dec77fb4d7e059bac5b6f50186e5" alt=""
SCSS代码
.flannel-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (background-blend-mode: overlay) { background-image: $url, $url, $url; background-position: center; background-size: 100%, 100000% 100%, 100% 100000%; background-blend-mode: overlay; } }
2.10 水平低墨
效果示例
data:image/s3,"s3://crabby-images/ee76d/ee76d072a2a281a0007b6aac39de61d0b49f3ae6" alt=""
SCSS代码
.low-ink-x-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (background-blend-mode: screen, overlay) { background-image: $url, $url, $url; background-size: 100% 100%, 10000% 100%; background-blend-mode: screen, overlay; } }
2.11 垂直低墨效果
效果示例
data:image/s3,"s3://crabby-images/e0535/e053533f7c3a0c3f7d94992b60b0ca3dcb4dddfa" alt=""
SCSS代码
.low-ink-y-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (background-blend-mode: screen, overlay) { background-image: $url, $url, $url; background-size: 100% 100%, 100% 1000%; background-blend-mode: screen, overlay; } }
2.12 拼贴效果
效果示例
data:image/s3,"s3://crabby-images/85b5e/85b5ef07c8680796a990a21778faa4304eabe0dd" alt=""
SCSS代码
.collage-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (background-blend-mode: overlay) { background-image: $url, $url, $url, $url, $url, $url; background-size: 200%, 80%, 60%, 50%, 40%, 100%; background-position: 50%, 80%, 30%, 0; background-blend-mode: overlay; background-repeat: no-repeat; } }
2.13 马赛克效果
效果示例
data:image/s3,"s3://crabby-images/5c152/5c152a6dcb9de54b19a78441063b96f6cacf4e8c" alt=""
SCSS代码
.mosaic-effect { $url : url(photo.jpg); background-image: $url, $url; background-size: cover, 5% 5%; background-position: center; background-blend-mode: overlay; }
2.14 图片边框效果
效果示例
data:image/s3,"s3://crabby-images/6f5a3/6f5a3e04ff82ab914963138f3d7475473773d203" alt=""
SCSS代码
.photo-border-effect { $url : url(photo.jpg); background-image: $url, $url; background-position: center; background-size: 60%, 20%; background-repeat: no-repeat, repeat; }
2.15 红外效果
效果示例
data:image/s3,"s3://crabby-images/c87f2/c87f27f3badb2d2551e621d899dfb4438694e279" alt=""
SCSS代码
.infrared-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; filter: hue-rotate(180deg) saturate(2); }
2.16 夜视效果
效果示例
data:image/s3,"s3://crabby-images/21bab/21bab84af75f21be1729dcac919d17ffc6e0f872" alt=""
SCSS代码
.night-vision-effect { $url : url(photo.jpg); $line-width: 5px; background-image: $url , radial-gradient( #0F0, #000 ), repeating-linear-gradient( transparent 0, rgba(0,0,0,0.1) $line-width/2, transparent $line-width ); background-size: cover; background-position: center; background-blend-mode: overlay; }
2.17 沃霍尔效果
效果示例
data:image/s3,"s3://crabby-images/2c0ea/2c0ea54caed9713014894a5f249f53e65c0b6c23" alt=""
SCSS代码
.warhol-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (background-blend-mode: color) { background-image: linear-gradient( #14EBFF 0, #14EBFF 50%, #FFFF70 50%, #FFFF70 100% ), linear-gradient( #FF85DA 0, #FF85DA 50%, #AAA 50%, #AAA 100% ), $url; background-size: 50% 100%, 50% 100%, 50% 50%; background-position: top left, top right; background-repeat: no-repeat, no-repeat, repeat; background-blend-mode: color; } }
2.18 颜色校正效果
效果示例
data:image/s3,"s3://crabby-images/6cc82/6cc8236bb131d693abb98aeafe2619f34b4f6736" alt=""
SCSS代码
.selective-color-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (filter: brightness(3)) and (mix-blend-mode: color) { position: relative; &:before, &:after { display: block; content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: inherit; background-color: red; background-blend-mode: screen; mix-blend-mode: color; filter: brightness(3); } } }
2.19 水平镜像效果
效果示例
data:image/s3,"s3://crabby-images/26914/269141d181df25e302786800726ac1c132423dda" alt=""
SCSS代码
.mirror-x-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (transform: scaleX(-1)) { position: relative; &:before, &:after { display: block; content: ""; position: absolute; top: 0; bottom: 0; background: inherit; } &:before { left: 0; right: 50%; transform: scaleX(-1); } &:after { left: 50%; right: 0; } } }
2.20 垂直镜像效果
效果示例
data:image/s3,"s3://crabby-images/ab474/ab474bf095778426c4dc50daa14a66732c39e20a" alt=""
SCSS代码
.mirror-y-effect { $url : url(photo.jpg); background-image: $url; background-size: cover; background-position: center; @supports (transform: scaleY(-1)) { position: relative; &:before, &:after { display: block; content: ""; position: absolute; left: 0; right: 0; background: inherit; } &:before { top: 0; bottom: 50%; transform: scaleY(-1); } &:after { top: 50%; bottom: 0; } } }