- Css权威指南(4th,第四版中文翻译)-19. 滤镜,渲染,裁
- 《Hadoop权威指南(第四版)》中文PDF+英文PDF+源代码
- 《Hadoop权威指南(第四版)》中文PDF+英文PDF+源代码
- Css权威指南(4th,第四版中文翻译)-0.Preface
- Css权威指南(4th,第四版中文翻译)-11.定位
- Css权威指南(4th,第四版中文翻译)-17.过渡
- Css权威指南(4th,第四版中文翻译)-18.动画
- Css权威指南(4th,第四版中文翻译)-12.Flexbox
- Css权威指南(4th,第四版中文翻译)-10.Floating
- Css权威指南(4th,第四版中文翻译)-16.Transfor
这章我们探讨几个有意思的辅助显示工具。
CSS 滤镜
最早的滤镜是微软在DirectX上做的效果,CSS通过filter属性实现了一个版本。
data:image/s3,"s3://crabby-images/55ef8/55ef8458559315a418db9db1dceecb9e68361397" alt=""
几个函数分别控制注入模糊,透明度和阴影等,来看个效果:
data:image/s3,"s3://crabby-images/19697/19697bbe0149632706721232c160f7457bb72bef" alt=""
再来看个不同的drop-shadow:
data:image/s3,"s3://crabby-images/a7e38/a7e38a24f2092a8f138068295d0859cb2a6b10d3" alt=""
颜色滤镜
data:image/s3,"s3://crabby-images/30f1e/30f1e137adba4bee8fa39518a36f690a2d564a85" alt=""
SVG 滤镜
data:image/s3,"s3://crabby-images/3fffa/3fffa485eeae4e3abc93e7f664322f92b76cb743" alt=""
img.logo {filter: url(/assets/filters.svg#spotlight);}
img.logo.print {filter: url(/assets/filters.svg#spotlight) grayscale(100%);}
img.logo.censored {filter: url(/assets/filters.svg#spotlight) blur(3px);}
组合和渲染
除了上面说的滤镜,CSS同样可以控制元素的组合,比如让两个元素部分重合。
渲染元素
在元素重合的时候,可以通过改变元素的混合模式
data:image/s3,"s3://crabby-images/f75fe/f75fe6ee6ed7b80b0dc8558e90eb23f206b89585" alt=""
data:image/s3,"s3://crabby-images/4fca6/4fca6d1578f5eb77facd8510729f427b739c80c5" alt=""
裁剪和遮罩
剪裁
data:image/s3,"s3://crabby-images/73f42/73f4236b7f3aa38cfad71b877475d0548475c467" alt=""
借助svg定义的形状我们生成需要裁剪的形状:
p {background: orange; color: black; padding: 0.75em;} p.clipped {clip-path: url(shapes.svg#cloud02);}
data:image/s3,"s3://crabby-images/79d90/79d90432fc5bdd2fe6bb10bf6789b8c822cc0049" alt=""
裁剪形状
clip-path叶童拱了多个默认的形状,来看看例子:
.ex01 {clip-path: none;}
.ex02 {clip-path: inset(10px 0 25% 2em);}
.ex03 {clip-path: circle(100px at 50% 50%);}
.ex04 {clip-path: ellipse(100px 50px at 75% 25%);}
.ex05 {clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);}
.ex06 {clip-path: polygon(0 0, 50px 100px, 150px 5px, 300px 150px, 0 100%);}
data:image/s3,"s3://crabby-images/5c12a/5c12ae947fb3f600be710709a215a6c5b362056f" alt=""
clip 盒子
我们也可以将clip-path指定元素的边框:
data:image/s3,"s3://crabby-images/180c9/180c949cb2ceaf3a02fc5e1b65c38d2b19a93fca" alt=""
遮罩
遮罩类似于裁剪路径,只不过只支持图片,并且定义了一堆的可配置属性:
定义遮罩
data:image/s3,"s3://crabby-images/abc93/abc93dc966b7aca5796346c40ebefecb90234664" alt=""
data:image/s3,"s3://crabby-images/4a0ca/4a0ca62596c24eb8808b21f28356f007de4b9868" alt=""
改变遮罩模式
data:image/s3,"s3://crabby-images/2fc2c/2fc2cfb3abdb6302c56b7f325583c5abc245fdd5" alt=""
之前都是用alpha来做遮罩,现在luminance表示亮度也是可以的:
img.theatre {mask-image: url(i/theatre-masks.svg);} img.compass {mask-image: url(i/Compass_masked.png);} img.lum {mask-mode: luminance;}
<img src="i/theatre-masks.svg">
<img class="theatre" src="i/mask.JPG"> <img class="theatre lum" src="i/mask.JPG"> <img src="i/Compass_masked.png">
<img class="compass" src="i/mask.JPG"> <img class="compass lum" src="i/mask.JPG">
data:image/s3,"s3://crabby-images/c45bf/c45bf534b0eba8f0f943927f0c9cc889ccdb273a" alt=""
设置大小和重复遮罩
遮罩的大小通过marsk-size来控制:
data:image/s3,"s3://crabby-images/f4431/f4431b83e26a0e31353203085e4f8ea8d3f3db70" alt=""
p {mask-image: url(i/hexlike.svg);}
p:nth-child(1) {mask-size: 100% 100%;}
p:nth-child(2) {mask-size: 50% 100%;}
p:nth-child(3) {mask-size: 2em 3em;}
p:nth-child(4) {mask-size: cover;}
p:nth-child(5) {mask-size: contain;}
p:nth-child(6) {mask-size: 200% 50%;}
data:image/s3,"s3://crabby-images/eb765/eb7650e8ec0ee6fc00ea0b706223660fe0277576" alt=""
data:image/s3,"s3://crabby-images/084d9/084d908f828335eed2f1b9b3fce4e45c486aa197" alt=""
p {mask-image: url(i/theatre-masks.svg);}
p:nth-child(1) {mask-repeat: no-repeat; mask-size: 10% auto;}
p:nth-child(2) {mask-repeat: repeat-x; mask-size: 10% auto;}
p:nth-child(3) {mask-repeat: repeat-y; mask-size: 10% auto;}
p:nth-child(4) {mask-repeat: repeat; mask-size: 30% auto;}
p:nth-child(5) {mask-repeat: repeat round; mask-size: 30% auto;}
p:nth-child(6) {mask-repeat: space no-repeat; mask-size: 21% auto;}
data:image/s3,"s3://crabby-images/41861/41861cfa0734a5e317813b93c679a2336c556d1c" alt=""
放置遮罩的位置
data:image/s3,"s3://crabby-images/2ce79/2ce79442697efa111c6b5983cfae4893ebe95889" alt=""
p {mask-image: url(i/Compass_masked.png); mask-repeat: no-repeat; mask-size: 67% auto;}
p:nth-child(1) {mask-position: center;} p:nth-child(2) {mask-position: top right;} p:nth-child(3) {mask-position: 33% 80%;} p:nth-child(4) {mask-position: 5em 120%;}
data:image/s3,"s3://crabby-images/b050c/b050c34093b45665a2c96f55f6da591fdcbf4439" alt=""
同时我们可以设置marsk的原点
data:image/s3,"s3://crabby-images/7238d/7238dade93a32fc72567165a3ab35932d1c6711c" alt=""
data:image/s3,"s3://crabby-images/5e33a/5e33a8d82e829975573cca1714f438a5eb9351d1" alt=""
最有意思的就属如何组合多个元素了:
data:image/s3,"s3://crabby-images/5bab3/5bab33b7d05b5c50d759698f4949d2c6f6fb175f" alt=""
data:image/s3,"s3://crabby-images/8fe2a/8fe2a92719728cc1e66355b0326667018cb9a610" alt=""
mask 的简写
data:image/s3,"s3://crabby-images/76b6a/76b6acfe5153a9ec8685321b5634823150f465ac" alt=""
#example {
mask-image: url(circle.svg), url(square.png), url(triangle.gif); mask-repeat: repeat-y, no-repeat;
mask-position: top right, center, 25% 67%;
mask-composite: subtract, add, add;
mask-size: auto, 50% 33%, contain;
} #example {
mask:
url(circle.svg) repeat-y top right / auto subtract, url(square.png) no-repeat center / 50% 33% add, url(triangle.gif) repeat-y 25% 67% / contain add;
}
data:image/s3,"s3://crabby-images/cf421/cf4210a59100a992f7da302a8b3ea897ed4f68e4" alt=""
mask type
如果要设置svg元素的遮罩类型:
data:image/s3,"s3://crabby-images/d6c94/d6c94c960d985dfcfa81eda1bad1beb2470a5884" alt=""
svg #mask {mask-type: alpha;}
img.masked {mask: url(#mask) no-repeat center/cover luminance;}
网友评论