这些图片都是用一个DIV绘制出来的,其实原理并不复杂。
这些图片都是由css绘制出来的,通过background-image叠加实现,
如蘑菇头的实现,通过 radial-gradient 径向渐变 , linear-gradient 线性渐变相互叠加实现,如:
1
2
3
4
5
6
7
8
9
10
11
12
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( 30 deg, 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