用CSS怎样做凹面渐变的矩形效果?
Admin 2021-09-29 群英技术资讯 1898 次浏览
今天给大家分享的是关于用CSS实现凹面渐变的矩形效果的内容,要实现这个效果,有两个难点,一个是凹面矩形实现,另一个给凹面矩形添加渐变的效果,本文有实现代码和详细的介绍供大家参考,感兴趣的朋友接下来跟随小编一起看看吧。
上图

实现凹面矩形

实现这个样式的灵感来自网上一篇使用css实现内凹角的文章,描述如何实现chrome标签页的内凹角效果,大概是下面这样子:

使用 radial-gradient 径向渐变来实现,将渐变的模糊距离缩小到0就能看到清晰的圆形界限。 按照这个思路就能实现内凹矩形的样式了,通过调整渐变的 position 控制中心点的位置,调整径向圆的size可以控制凹面的弯曲程度,就像下面这样:

可以在MDN的径向渐变demo里调试:

background: radial-gradient(300px 300px at 112px 0, #eee 75%, #333 75%);
小细节
实现线性渐变的凹面矩形

上一节已经实现了凹面矩形,那如何给凹面矩形再设置线性渐变呢?background已经被使用了,不能又设置径向渐变又设置线性渐变。
可以使用 mask-image 来实现抠图的效果,MDN的例子:

MDN的例子使用五角星形状的svg在绿色的背景上抠图得到了绿色的五角星,要实现渐变的凹面矩形可以用凹面矩形的形状在线性渐变的背景上抠图。
用 mask-image 设置形状, background 设置线性渐变:
.xxx {
background: linear-gradient(115deg, #ff66ff, #4db8ff);
mask-image: radial-gradient(300px 300px at 112px 0, rgba(255, 255, 255, 0) 75%, #333 75%);
}
效果:

小细节
mask-image在移动端的兼容性竟然比径向渐变要好,安卓4.4.4是支持的。
渐变背景色的过渡
background-image本身是不支持过渡动画的,但是可以通过一些骚操作来实现,张鑫旭老师的文章说得非常详细:
https://www.zhangxinxu.com/wordpress/2020/08/background-image-animation/
https://www.zhangxinxu.com/wordpress/2018/03/background-gradient-transtion/
background-image不支持过渡动画,但是opacity支持呀,在之前的线性渐变凹面矩形上再叠加一层伪元素,设置伪元素背景色为另一个线性渐变色,然后控制伪元素的opacity,实现线性渐变过渡效果。
以上就是用CSS实现凹面渐变的矩形效果的介绍,有需要的朋友可以借鉴参考,希望对大家有帮助,想要了解更多实现CSS的应用,大家可以继续浏览群英网络其他相关的文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
css两个div怎么实现水平布局两边对齐?我们做网页设计时,有些需求需要两个div在两边对齐,那么要怎么写呢?有哪些实现方法?下面我们一起来看看。
1/100的视口宽度。在客户端,视口指的是浏览器的可视区域;而在移动端,它涉及3个视口:Layout Viewport(布局视口),Visual Viewport(视觉视口),Ideal Viewport(理想视口)。指的就是Layout V
CSS鼠标跟随的原理:1、鼠标跟随就是元素会跟随着鼠标的移动,而作出相对应的运动。2、为了能够监控当前鼠标的位置,只需在页面上铺上元素即可。
本文给大家分享float和margin结合使用实现各种布局的内容,下文有具体的实现多种布局的代码供大家参考,对新手学习CSS布局有一定的帮助,需要的朋友可以了解看看,接下来我们一起来学习一下吧。
大部分人在使用selenium定位元素时,用的是xpath定位,css定位往往被忽略掉了,其实css定位也有它的价值,css定位更快,语法更简洁一、CSS 选择器常见符号:<br /> #表示 id选择器<br /> .表示 clas
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008