CSS mask 实现鼠标跟随镂空效果
作者:XboxYan
简介:偏用户体验的前端
来源:SegmentFault 思否社区
data:image/s3,"s3://crabby-images/43bd5/43bd553b9464e9dfc21e906e53d41eff2549287c" alt=""
一、普通半透明的效果
data:image/s3,"s3://crabby-images/45625/456255685870e6a585a54fabfeb76720945a5ace" alt=""
<div class="wrap" id="img">
<img class="prew" src="https://tva1.sinaimg.cn/large/008i3skNgy1gubr2sbyqdj60xa0m6tey02.jpg">
</div>
data:image/s3,"s3://crabby-images/f82af/f82afbfd63bd4e3f28deecb58165cf70739280bb" alt=""
.wrap::before{
content:'';
position: absolute;
width: 100px;
height: 100px;
border-radius: 50%;
left: 50%;
top: 50%;
transform: translate(-50%,-50%); /*默认居中*/
box-shadow: 0 0 0 999vw rgba(0, 0, 0, .5); /*足够大的投影*/
}
data:image/s3,"s3://crabby-images/45625/456255685870e6a585a54fabfeb76720945a5ace" alt=""
二、借助 CSS 变量传递鼠标位置
img.addEventListener('mousemove', (ev) => {
img.style.left = '...';
img.style.top = '...';
})
.wrap::before{
left: calc(var(--x) * 100%);
top: calc(var(--y) * 100%);
}
img.addEventListener('mousemove', (ev) => {
img.style.setProperty('--x', ev.offsetX / ev.target.offsetWidth);
img.style.setProperty('--y', ev.offsetY / ev.target.offsetHeight);
})
data:image/s3,"s3://crabby-images/72bb4/72bb4fb9feae0737bf067286c9c74b397a87f3e2" alt=""
三、渐变也能实现半透明的效果
.wrap::before{
content: '';
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
background: radial-gradient( circle at center, transparent 50px, rgba(0,0,0,.5) 51px);
}
data:image/s3,"s3://crabby-images/45625/456255685870e6a585a54fabfeb76720945a5ace" alt=""
.wrap::before{
background: radial-gradient( circle at calc(var(--x) * 100% ) calc(var(--y) * 100% ), transparent 50px, rgba(0,0,0,.5) 51px);
}
data:image/s3,"s3://crabby-images/7225c/7225c8423484a1a23af35cd56be078fb4ae19a55" alt=""
四、背景模糊的效果尝试
backdrop-filter: blur(10px);
data:image/s3,"s3://crabby-images/93cc5/93cc56fb38846fcd34f79abef963ce295223a49e" alt=""
data:image/s3,"s3://crabby-images/99b1d/99b1de38a3d4215910f642b99a03e8c08065a748" alt=""
1. 阴影实现
.wrap::before{
content:'';
position: absolute;
width: 100px;
height: 100px;
border-radius: 50%;
left: 50%;
top: 50%;
transform: translate(-50%,-50%); /*默认居中*/
box-shadow: 0 0 0 999vw rgba(0, 0, 0, .5); /*足够大的投影*/
backdrop-filter: blur(5px)
}
data:image/s3,"s3://crabby-images/15d05/15d054e3a3bfc9580373c43cf9fe9303f5599695" alt=""
2. 渐变实现
.wrap::before{
content: '';
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
background: radial-gradient( circle at calc(var(--x) * 100% ) calc(var(--y) * 100% ), transparent 50px, rgba(0,0,0,.5) 51px);
backdrop-filter: blur(5px)
}`
data:image/s3,"s3://crabby-images/302d9/302d9738a66384345ba8aeb60f81be98b6a51e1f" alt=""
五、CSS MASK 实现镂空
data:image/s3,"s3://crabby-images/04198/04198a1e6e6032803ed1eaf67c61aac730999433" alt=""
.wrap::before{
content: '';
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
-webkit-mask: radial-gradient( circle at calc(var(--x, .5) * 100% ) calc(var(--y, .5) * 100% ), transparent 50px, #000 51px);
background: rgba(0,0,0,.3);
backdrop-filter: blur(5px)
}
data:image/s3,"s3://crabby-images/8922c/8922cc08659bd1b7be78333b21df9e08a552a6e8" alt=""
六、CSS MASK COMPOSITE 实现更丰富的镂空效果
/* Keyword values */
mask-composite: add; /* 叠加(默认) */
mask-composite: subtract; /* 减去,排除掉上层的区域 */
mask-composite: intersect; /* 相交,只显示重合的地方 */
mask-composite: exclude; /* 排除,只显示不重合的地方 */
data:image/s3,"s3://crabby-images/927ec/927ec32bc6e90e2e9478604a5e38d8c407caf65e" alt=""
-webkit-mask-composite: clear; /*清除,不显示任何遮罩*/
-webkit-mask-composite: copy; /*只显示上方遮罩,不显示下方遮罩*/
-webkit-mask-composite: source-over;
-webkit-mask-composite: source-in; /*只显示重合的地方*/
-webkit-mask-composite: source-out; /*只显示上方遮罩,重合的地方不显示*/
-webkit-mask-composite: source-atop;
-webkit-mask-composite: destination-over;
-webkit-mask-composite: destination-in; /*只显示重合的地方*/
-webkit-mask-composite: destination-out;/*只显示下方遮罩,重合的地方不显示*/
-webkit-mask-composite: destination-atop;
-webkit-mask-composite: xor; /*只显示不重合的地方*/
data:image/s3,"s3://crabby-images/b6a3c/b6a3c2ac4ab3a0f14aac602d678fa041672ca43c" alt=""
.wrap::before{
content: '';
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
-webkit-mask: url("data:image/svg+xml,%3Csvg width='50' height='50' viewBox='0 0 50 50' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='25' cy='25' r='25' fill='%23C4C4C4'/%3E%3C/svg%3E"), linear-gradient(red, red);
-webkit-mask-size: 50px, 100%;
-webkit-mask-repeat: no-repeat;
-webkit-mask-position: calc(var(--x, .5) * 100% + var(--x, .5) * 100px - 50px ) calc(var(--y, .5) * 100% + var(--y, .5) * 100px - 50px ), 0;
-webkit-mask-composite: xor; /*只显示不重合的地方, chorem 、safari 支持*/
mask-composite: exclude; /* 排除,只显示不重合的地方, firefox 支持 */
background: rgba(0,0,0,.3);
backdrop-filter: blur(5px)
}
data:image/s3,"s3://crabby-images/8922c/8922cc08659bd1b7be78333b21df9e08a552a6e8" alt=""
data:image/s3,"s3://crabby-images/beb0c/beb0c1dc4f0ef5dbd8b4d27bac131d584e58ed14" alt=""
data:image/s3,"s3://crabby-images/7286e/7286ef3e507ead25dd18e90960f5302984821c6a" alt=""
.wrap::before{
content: '';
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
-webkit-mask: url("data:image/svg+xml,%3Csvg width='96' height='91' viewBox='0 0 96 91' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M48 0l11.226 34.55h36.327l-29.39 21.352L77.39 90.45 48 69.098 18.61 90.451 29.837 55.9.447 34.55h36.327L48 0z' fill='%23C4C4C4'/%3E%3C/svg%3E"), linear-gradient(red, red);
-webkit-mask-size: 50px, 100%;
-webkit-mask-repeat: no-repeat;
-webkit-mask-position: calc(var(--x, .5) * 100% + var(--x, .5) * 100px - 50px ) calc(var(--y, .5) * 100% + var(--y, .5) * 100px - 50px ), 0;
-webkit-mask-composite: xor; /*只显示不重合的地方, chorem 、safari 支持*/
mask-composite: exclude; /* 排除,只显示不重合的地方, firefox 支持 */
background: rgba(0,0,0,.3);
backdrop-filter: blur(5px)
}
data:image/s3,"s3://crabby-images/55fd2/55fd2a58e4e3ab2c5c3fc09a78c9625cf1bdec95" alt=""
七、总结和说明
足够大的阴影是一个实现圆形镂空效果的小技巧 CSS 渐变也能轻易的绘制出圆形镂空背景 借助 CSS 变量可以很方便的利用鼠标位置实现想要的效果 backdrop-filter 可以想象成磨砂玻璃的功能 CSS Mask 可以给磨砂玻璃打孔,实现镂空的效果 借助遮罩合成特性和SVG,可以实现任意形状的镂空效果
data:image/s3,"s3://crabby-images/3173b/3173b39b69089a25b21367c3471f6b54eabaaa46" alt=""
data:image/s3,"s3://crabby-images/5be91/5be9106d1b5febafe54478f40221899f8ac053e7" alt=""
关注公众号:拾黑(shiheibook)了解更多
赞助链接:
关注数据与安全,洞悉企业级服务市场:https://www.ijiandao.com/
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/