CSS教程

关注公众号 jb51net

关闭
网页制作 > CSS > CSS教程 >

用一个DIV画图通过background-image叠加实现

脚本之家

这些图片都是用一个DIV绘制出来的,其实原理并不复杂。

 

这些图片都是由CSS绘制出来的,通过background-image叠加实现,

如蘑菇头的实现,通过 radial-gradient 径向渐变 , linear-gradient 线性渐变相互叠加实现,如:


div {
width: 170px;
height: 140px;
background-image:
radial-gradient(circle at 50% 120%, rgba(0,0,0,0.7) 23%, rgba(0,0,0,0) 48%),
linear-gradient(30deg, rgba(0,0,0,0.4) 10%, rgba(0,0,0,0) 20%),
radial-gradient(circle at 50% 33%, #f8f6f7 32%, rgba(255,255,255,0) 32%),
radial-gradient(circle at -13% 55%, #f8f6f7 20%, rgba(255,255,255,0) 20%),
radial-gradient(circle at 113% 55%, #f8f6f7 20%, rgba(255,255,255,0) 20%),
linear-gradient(to bottom, #ef0015 20%, #b2000c 100%);
border-radius: 140px 140px 80px 80px;
}

同时有前后遮挡关系的通过:before和:after伪元素的background-image来实现。

PS: 此种手法对并不完全支持旧版IE