前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >CSS遮罩应用:带有不规则三角的气泡

CSS遮罩应用:带有不规则三角的气泡

作者头像
德顺
发布2019-11-13 17:05:42
1.4K0
发布2019-11-13 17:05:42
举报
文章被收录于专栏:前端资源

一般网站应用中都会应用到三角形,正三角形的写法也有很多,网上一搜一大把。

今天我看到一个带有不规则三角形气泡的写法,效果如下:

CSS遮罩应用:带有不规则三角的气泡 经验总结 第1张
CSS遮罩应用:带有不规则三角的气泡 经验总结 第1张

左边部分的矩形比较好实现,通过设置宽高可圆角就可以,但是右边的不规则三角不好用代码实现了。

在这里我们用到一个 CSS 的 遮罩属性(CSS Masks):-webkit-mask-image: url(mask.png);

CSS遮罩是2008年4月由苹果公司添加到webkit引擎中的。

遮罩提供一种基于像素级别的,可以控制元素透明度的能力,类似于png24位或png32位中的alpha透明通道的效果。

实现原理:

类似于Photoshop中的剪切蒙板,图像是由rgb三个通道以及在每个像素上定义的颜色组成的。但是在他们之上还有第四个通道,alpha通道,通过亮度定义每个像素上的透明度。白色意味着不透明,黑色意味着透明,介于黑白之间的灰色表示半透明。实现原理如下图:

CSS遮罩应用:带有不规则三角的气泡 经验总结 第2张
CSS遮罩应用:带有不规则三角的气泡 经验总结 第2张

代码部分:

说完原理我们来看一下代码:

首先我们在 body 中写一个 p 标签,class 设置为 mask

代码语言:javascript
复制
<body>
    <div class="mask"></div>
</body>

在 style 中给该标签设置背景、宽高和遮罩:

代码语言:javascript
复制
<style>
    .mask {
        background: url(img/pic.jpg) no-repeat center;
        background-size: cover;
        width: 247px;
        height: 305px;
        margin: 50px 10px;
        -webkit-mask-image: url(img/mask.png);
        float: left;
    }
</style>

背景图就是遮罩内展示的图片,遮罩图片就是有黑色图案的图片,这样就可以实现图一的效果了。

GitHub地址:点击访问

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档