运用CSS实现皮卡丘
前言
当我学完css和js后,冒出来一个设法。本人去实现一个招人喜欢的卡通人物。于是我就去codepen寻素材,终究选中了皮卡丘,如下图。
预备工作
在开端写皮卡丘此前,我先视察了皮卡丘的整个页面。发明假如要很好的实现这个皮卡丘你不克不及像写传统网页那样从左到右规划,而是要从中心规划,由于摆布两边对称。理分明了思绪之后此刻开端编写页面构造。
<p class="skin"> <p class="eye left"></p> <p class="eye right"></p> <p class="nose"> <p class="yuan"></p> </p> <p class="mouth "> <p class="up"> <p class="lip left"></p> <p class="lip right"></p> </p> <p class="down"> <p class="yuan1"> <p class="yuan2"></p> </p> </p> </p> <p class="mouth "></p> <p class="face left"> <img src="src/img/flash.gif" alt="flash"> </p> <p class="face right"> <img src="src/img/flash.gif" alt="flash"> </p> </p>
页面构造如上图所示,当我们编写完html构造,就可以动手去写css。
CSS的实现
在这个地方我们可以临时先停一下,再次理清思绪。这个皮卡丘的最难点的部分在哪里?在于皮卡丘嘴巴上的弧线乃至下面椭圆形的舌头。
在实现皮卡丘嘴巴上的弧线时,我发生了两个设法。第一用一个标签包裹实现这个弧线,第二离别用两个标签去包裹实现这两个弧线。终究我选中了第二种。在这里我视察皮卡丘嘴巴上的弧线发明这个弧线就是圆角矩形的四分之一,加上扭转就可以实现这两个弧线。
详细实现如下
.mouth .up { position: relative; top: -20px; z-index: 1; }.mouth .up .lip { border: 3px solid black; height: 30px; width: 100px; background: #ffe600; border-top-color: transparent; border-right-color: transparent; position: relative; position: absolute; left: 50%; margin-left: -50px; }.mouth .up .lip.left { border-radius: 0 0 0 35px; transform: rotate(-20deg) translateX(-53px); }.mouth .up .lip.right { border-radius: 0 0 35px 0; transform: rotate(20deg) translateX(53px); }.mouth .up .lip::before { content: ''; display: block; width: 7px; height: 30px; position: absolute; bottom: 0; background: #ffe600; }.mouth .up .lip.left::before { right: -6px; }.mouth .up .lip.right::before { left: -6px; }
第一个大难点已经解决,接下来解决第二个难点。怎样实现皮卡丘的下嘴唇。
视察皮卡丘的舌头我发明这实际上是一个椭圆的一部分或者圆角矩形的一部分,那我就需要截取一部分的椭圆或者圆角矩形就能实现皮卡丘的舌头。第二个解决点如何实现皮卡丘舌头粉色的部分,有了上面的思绪之后,沿着这个思绪连续想,实际上这就是两个圆角矩形或者椭圆形的接壤处实现的。
画的不是太好各位客官见谅了。
详细的代码的实现如下
.mouth .down { height: 180px; position: absolute; top: 5px; width: 100%; overflow: hidden; }.mouth .down .yuan1 { border: 3px solid black; width: 150px; height: 1000px; position: absolute; bottom: 0; left: 50%; margin-left: -75px; border-radius: 75px/300px; background: #9b000a; overflow: hidden; }.mouth .down .yuan1 .yuan2 { width: 200px; height: 300px; background: #ff485f; position: absolute; bottom: -160px; left: 50%; margin-left: -100px; border-radius: 100px; }
这两个难点解决了差不多就完成了整个皮卡丘的一半,剩下的就可以本人去完成了。
结尾
当我写完了皮卡丘的css之后只能感慨于css的奇妙,也让我愈加深刻的懂得了css。在此此前我认为css很简便,但是真正做皮卡丘的时候,还是特殊特殊难,这个难在于需要你用许许多多的办法去实现你想要的结果,这就需要很好的根基乃至设法,在此感激引导我的各位教师和同学了。
引荐教程:《CSS》
以上就是使用CSS实现皮卡丘的具体内容,更多请关注百分百源码网其它相关文章!