侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

使用CSS3代码绘制可爱的Hello Kitty猫

前端  /  管理员 发布于 7年前   393

感觉这个 Hello Kitty 画的还不错,心血来潮也用 CSS3 画了个 Hello Kitty,现在在这里记录一下详细的绘制过程。想要源码、素材、在线演示的同学可以直接拉到最下面。我们先看下原图:

结构分解

从上图可以看出,Hello Kitty 由脸蛋、耳朵、红色蝴蝶结、眼睛、鼻子和六根胡须构成,所以 DOM 结构也相对简单:

CSS Code复制内容到剪贴板
  1. <div class="hello-kitty-div">   
  2.     <!-- 脸蛋 -->   
  3.     <div class="face"></div>   
  4.     <!-- 左耳 -->   
  5.     <div class="left-ear"></div>   
  6.     <div class="left-ear-clean"></div>   
  7.     <div class="left-ear-beautify"></div>   
  8.     <!-- 右耳 -->   
  9.     <div class="right-ear"></div>   
  10.     <div class="right-ear-clean"></div>   
  11.     <!-- 蝴蝶结 -->   
  12.     <div class="bowknot-outside-left-top-container">   
  13.         <div class="bowknot-outside-left-top"></div>   
  14.     </div>   
  15.     <div class="bowknot-outside-left-bottom-container">   
  16.         <div class="bowknot-outside-left-bottom"></div>   
  17.     </div>   
  18.     <div class="bowknot-outside-right-top-container">   
  19.         <div class="bowknot-outside-right-top"></div>   
  20.     </div>   
  21.     <div class="bowknot-outside-right-bottom-container">   
  22.         <div class="bowknot-outside-right-bottom"></div>   
  23.     </div>   
  24.     <div class="bowknot-inside-left"></div>   
  25.     <div class="bowknot-inside-right"></div>   
  26.     <div class="bowknot-inside-center"></div>   
  27.     <!-- 左眼 -->   
  28.     <div class="left-eye"></div>   
  29.     <!-- 右眼 -->   
  30.     <div class="right-eye"></div>   
  31.     <!-- 鼻子 -->   
  32.     <div class="nose"></div>   
  33.     <!-- 左胡须 -->   
  34.     <div class="left-moustache-1"></div>   
  35.     <div class="left-moustache-2"></div>   
  36.     <div class="left-moustache-3"></div>   
  37.     <!-- 右胡须 -->   
  38.     <div class="right-moustache-1"></div>   
  39.     <div class="right-moustache-2"></div>   
  40.     <div class="right-moustache-3"></div>   
  41. </div>   

开始绘制

可以利用 Photoshop 的参考线精确的计算出元素的 left、top、width、height、border-width 以及四个角的水平 radius 值和垂直 radius 值,有偏差的地方再微调一下基本就可以了。

脸蛋

CSS Code复制内容到剪贴板
  1. .hello-kitty-div .face {   
  2.     left: 107px;   
  3.     top: 77px;   
  4.     width: 747px;   
  5.     height: 566px;   
  6.     border-top: 35px solid black;   
  7.     border-bottom: 31px solid black;   
  8.     border-left: 29px solid black;   
  9.     border-right: 30px solid black;   
  10.     border-top-left-radius: 355px 333px;   
  11.     border-top-rightright-radius: 355px 333px;   
  12.     border-bottom-left-radius: 370px 285px;   
  13.     border-bottom-rightright-radius: 330px 255px;   
  14.     background-color: white;   
  15.     z-index: 100;   
  16. }   

左耳

CSS Code复制内容到剪贴板
  1. .hello-kitty-div .left-ear {   
  2.     left: 112px;   
  3.     top: 61px;   
  4.     width: 250px;   
  5.     height: 250px;   
  6.     border-top: 33px solid black;   
  7.     border-bottom: 30px solid black;   
  8.     border-left: 28px solid black;   
  9.     border-right: 30px solid black;   
  10.     border-top-left-radius: 138px 100px;   
  11.     border-bottom-left-radius: 334px 310px;   
  12.     background-color: white;   
  13.     transform: rotate(23deg);   
  14.     z-index: 99;   
  15. }   

让耳朵和脸蛋连为一体:

CSS Code复制内容到剪贴板
  1. .hello-kitty-div .left-ear-clean {   
  2.     left: 146px;   
  3.     top: 96px;   
  4.     width: 250px;   
  5.     height: 250px;   
  6.     border-top-left-radius: 138px 100px;   
  7.     border-bottom-left-radius: 360px 310px;   
  8.     background-color: white;   
  9.     transform: rotate(23deg);   
  10.     z-index: 101;   
  11. }  

再稍加点缀,美化一下:

CSS Code复制内容到剪贴板
  1. .hello-kitty-div .left-ear-beautify {   
  2.     left: 149px;   
  3.     top: 221px;   
  4.     width: 60px;   
  5.     height: 30px;   
  6.     border-top-left-radius: 20px 15px;   
  7.     border-top-rightright-radius: 25px 15px;   
  8.     border-bottom-left-radius: 20px 15px;   
  9.     border-bottom-rightright-radius: 25px 15px;   
  10.     background-color: black;   
  11.     transform: rotate(-52deg);   
  12.     z-index: 102;   
  13. }   

右耳

CSS Code复制内容到剪贴板
  1. .hello-kitty-div .rightright-ear {   
  2.     left: 600px;   
  3.     top: 50px;   
  4.     width: 250px;   
  5.     height: 250px;   
  6.     border-top: 33px solid black;   
  7.     border-bottom: 28px solid black;   
  8.     border-left: 30px solid black;   
  9.     border-right: 29px solid black;   
  10.     border-top-left-radius: 220px 170px;   
  11.     border-top-rightright-radius: 90px 57px;   
  12.     border-bottom-rightright-radius: 334px 245px;   
  13.     background-color: white;   
  14.     transform: rotate(-21deg);   
  15.     z-index: 99;   
  16. }   
  17. .hello-kitty-div .rightright-ear-clean {   
  18.     left: 700px;   
  19.     top: 105px;   
  20.     width: 120px;   
  21.     height: 120px;   
  22.     background-color: white;   
  23.     z-index: 101;   
  24. }   

右耳画的比较粗糙,因为马上就要画蝴蝶结了。

蝴蝶结

蝴蝶结分为两个外边,三个圆。外边是整个绘画过程中最难画的地方,用矩形调整 radius 参数很难做到没有偏差,因为它不像是更圆润的矩形,而像是更圆润的三角形。在这里,我们把它分成四块,各个外边各两块,在块内绘制好对应的区域,再利用 overflow: hidden; 来隐藏多余的部分。然后是三个圆,相对简单。
 
代码量实在太多,就不贴出来了,大概思路就这样子。

眼睛,鼻子

眼睛和鼻子相对简单,就不贴代码了。

胡须

因为胡须是弯弯的,所以每根胡须需要两个元素来实现,我们就用 :before 和 :after 吧。

某一根胡须的代码:

CSS Code复制内容到剪贴板
  1. .hello-kitty-div .left-moustache-1:before {   
  2.     content: '\20';   
  3.     display: block;   
  4.     position: absolute;   
  5.     left: 20px;   
  6.     top: 420px;   
  7.     width: 100px;   
  8.     height: 24px;   
  9.     border-top-left-radius: 80px 30px;   
  10.     border-bottom-left-radius: 20px;   
  11.     background-color: black;   
  12.     transform: rotate(-5deg);   
  13.     z-index: 101;   
  14. }   
  15. .hello-kitty-div .left-moustache-1:after {   
  16.     content: '\20';   
  17.     display: block;   
  18.     position: absolute;   
  19.     left: 131px;   
  20.     top: 418px;   
  21.     width: 60px;   
  22.     height: 24px;   
  23.     border-top-rightright-radius: 100px 30px;   
  24.     border-bottom-rightright-radius: 20px;   
  25.     background-color: black;   
  26.     transform: rotate(2deg);   
  27.     z-index: 101;   
  28. }   

现在,整个 Hello Kitty 就画完了,有没有觉得很可爱?~~(ฅ>ω<*ฅ)~~。

完整源码及素材:https://github.com/chnhyg/css3-hello-kitty

在线演示:http://chnhyg.coding.me/css3-hello-kitty


  • 上一条:
    CSS特殊性、继承与层叠
    下一条:
    浅谈CSS 权值 层叠 重要性(!important)
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 使用go + gin + jwt + qrcode实现网站生成登录二维码在app中扫码登录功能(0个评论)
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客