当前位置:首页 » 《随便一记》 » 正文

css绘制一个Pinia小菠萝

21 人参与  2023年03月26日 11:05  分类 : 《随便一记》  评论

点击全文阅读


效果如下:
在这里插入图片描述
pinia小菠萝分为头部和身体,头部三片叶子,菠萝为身体
在这里插入图片描述


头部

先绘制头部的盒子,将三片叶子至于头部盒子中
先绘制中间的叶子,利用border-radius实现叶子的效果,可以借助工具来快速实现圆角的预想效果

https://9elements.github.io/fancy-border-radius/

在这里插入图片描述

<div class="center_lafe"></div>
.center_lafe{     width: 100px;     height: 200px;     background: linear-gradient(-130deg,#61d572,#52ce63);     border-radius: 50% 50% 50% 50% / 100% 100% 0% 0% ;     &::before{          content: '';          width: 100px;          height: 200px;          position: absolute;          border-radius: 50% 50% 50% 50% / 100% 100% 0% 0% ;          background: linear-gradient(-180deg,rgba(255,255,255,0.2) 30%,transparent);    }}

在这里插入图片描述
再绘制两侧的叶子,方法和绘制中间的叶子一样

<div class="left_lafe"></div><div class="right_lafe"></div>
.left_lafe{    width: 100px;    height: 100px;    background: linear-gradient(-130deg,#86e798,#52ce63);    border-radius: 5% 95% 50% 50% / 5% 50% 50% 95% ;    position: absolute;    left: 50px;    bottom: -16px;    transform: rotate(5deg);}.right_lafe{    width: 100px;    height: 100px;    background: linear-gradient(-130deg,#86e798,#52ce63);    border-radius: 95% 5% 50% 50% / 50% 5% 95% 50% ;    position: absolute;    right: 20px;    bottom: -30px;    transform: rotate(5deg);}

在这里插入图片描述
两篇叶子的层级在中间叶子和菠萝身体之下,所以两片叶子的被覆盖的地方有一层阴影用来表示层级,阴影用伪元素配合渐变实现,下面是左侧叶子的阴影:绘制一个和左侧叶子一样的形状,利用渐变和颜色透明度实现

.left_lafe::before{      content: '';      width: 100px;      height: 100px;      position: absolute;      border-radius: 5% 95% 50% 50% / 5% 50% 50% 95% ;      background: linear-gradient(-25deg,rgba(51, 51, 51,0.3),transparent);}

在这里插入图片描述
右侧叶子同理,看一下头部叶子的整体效果:
在这里插入图片描述


身体

开始绘制小菠萝身体部分
身体部分利用border-radius实现,身体部分的层级高于叶子
在这里插入图片描述

<div class="piniaBody"></div>
.piniaBody{   width: 300px;   height: 320px;   background: #ccc;   border-radius: 50% 50% 48% 48% / 65% 65% 38% 38% ;   background: linear-gradient(to bottom,#ffe56c,#ffc73b);   margin-top: -20px;   z-index: 10;   position: relative;}

在这里插入图片描述


额头

绘制额头上的X图案,其实就是绘制一侧的斜线,另一侧同样的写法,更改位置和角度即可。

 <div class="forehead"></div>
.forehead{      width: 70px;      height: 70px;      position: absolute;      left: 50%;      top: 30px;      transform: translate(-50%);      &::before,&::after{          content: '';          width: 100%;          height: 8px;          position: absolute;          background: #ffc73b;          border-radius: 6px;          left: 45%;          top: 40%;          transform: translateX(-50%) rotate(50deg);      }      &::after{          content: '';          left: 55%;          top: 40%;          transform: translateX(-50%) rotate(-50deg);     }}

在这里插入图片描述


眼睛

眼睛部分利用三个圆形分别堆叠即可,分别是眼白、黑眼球、高光

<div class="left_eyesBox"></div>
.left_eyesBox{        width: 50px;        height: 50px;        background: #fff;        border-radius: 50%;        position: relative;        &::before{           content: '';           position: absolute;           width: 30px;           height: 30px;           background: black;           border-radius: 50%;           left: 50%;           top: 50%;           transform: translate(-50%,-50%);        }        &::after{           content: '';           width: 12px;           height: 12px;           background: #fff;           border-radius: 50%;           position: absolute;           left: 25%;           top: 35%;        }}

在这里插入图片描述

眼睛下面有一个眼影,这里新建一个div,圆角50%,层级在眼睛之下。

<div class="eyeshadow"></div>
.eyeshadow{       width: 40px;       height: 20px;       background: #eaadcc;       position: relative;       top: 40px;       left: -10px;       z-index: -1;       border-radius: 50%;}

在这里插入图片描述
右眼的写法和左眼一致,把左眼拿过来更改一下位置即可。


嘴巴

嘴巴部分:先绘制一个椭圆,椭圆的背景色为透明色,给椭圆设置阴影,阴影向下偏移5px,只保留阴影的颜色就可以得到嘴巴的效果了
在这里插入图片描述

<div class="mouth"></div>
.mouth{     width: 40px;     height: 20px;     position: absolute;     left: 50%;     bottom: 20px;     border-radius: 50%;     transform: translate(-50%) scale(1);     box-shadow: 0px 5px 0px 0px black;}

在这里插入图片描述


底部

小菠萝底部的X图案跟额头的X图案绘制方法大致相同,例如:左侧横线旋转45deg,右侧横线旋转-45deg,即可得到一个交叉的Xwidth就是横线的长度,调整左右侧横线长度的比例即可得到不规则的X图案,剩下的只需要调整斜线的位置和比例即可,左右的X图案绘制方法是一样的。
在这里插入图片描述

<div class="left_jaw"></div><div class="right_jaw"></div>
.left_jaw,.right_jaw{      width: 90px;      height: 70px;      position: absolute;      bottom: 40px;      &::before{         content: '';         width: 100%;         height: 8px;         position: absolute;         background: #ecb732;         border-radius: 6px;         left: 45%;         top: 40%;         transform: translateX(-50%) rotate(50deg);      }      &::after{         content: '';         width: 100%;         height: 8px;         position: absolute;         background: #ecb732;         border-radius: 6px;         left: 55%;         top: 40%;         transform: translateX(-50%) rotate(-50deg);     }}.left_jaw{      left: 30px;      &::after{         width: 70%;      }}.right_jaw{       right: 30px;       &::before{          width: 70%;       }}

在这里插入图片描述
到这里我们的小菠萝就绘制完成了
最后看一下官网的原图:
在这里插入图片描述

技巧总结:

1、利用border-radius绘制大部分不规则的椭圆
2、高光利用背景色层级叠加实现
3、不规则的交叉图案使用translate调整旋转位置
4、元素的层级表现利用线性渐变颜色透明度来实现
5、利用z-index调整画面层级表现


案例源码:https://gitee.com/wang_fan_w/css-diary

如果觉得这篇文章对你有帮助,欢迎点赞、收藏、转发哦~


点击全文阅读


本文链接:http://zhangshiyu.com/post/56590.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 苔藓爬满旧日诺言全书+后续+结局顾砚廷慕晚夏免费苔藓爬满旧日诺言全书+后续+结局顾砚廷慕晚夏全书全
  • [我掉蛇女马甲后,点天灯假死丈夫悔疯了]免费试读_婆婆丁若菱蛇女精彩节选推荐
  • 他日若是同淋雪结局+番外(夏尔若林闻舟)他日若是同淋雪结局+番外结局_夏尔若林闻舟列表_笔趣阁(他日若是同淋雪结局+番外)
  • 他心非石反转剧情试读片段_安茗宝宝心掏后续更新+番外
  • 许星森纪冰雪(日暮青山绿渐隐许星森纪冰雪结局+番外)_(许星森纪冰雪)列表_笔趣阁(日暮青山绿渐隐许星森纪冰雪结局+番外)
  • 全文潮痕蚀月光(池清禾***宸)列表_全文潮痕蚀月光
  • 「江月随人处处圆」小说无删减版在线免费阅读_[陆晨小姐孟苒]精彩章节免费试读
  • 阮雾梨闻砚辞阮见微结局+番外全书+后续+结局(闻砚辞阮雾梨)列表_阮雾梨闻砚辞阮见微结局+番外(闻砚辞阮雾梨)阮雾梨闻砚辞阮见微结局+番外全书+后续+结局在线
  • 潮痕蚀月光结局+番外池清禾***宸(潮痕蚀月光结局+番外)全书免费池清禾***宸_潮痕蚀月光结局+番外池清禾***宸列表_笔趣阁(池清禾***宸)
  • 苔藓爬满旧日诺言一口气读完全书+后续全书+后续+结局(慕晚夏顾砚廷)列表_苔藓爬满旧日诺言一口气读完全书+后续(慕晚夏顾砚廷)苔藓爬满旧日诺言一口气读完全书+后续全书+后续+结局在线
  • 「孕弟」反转剧情碎片化试读_[耀祖弟弟子宫]小说精彩节选试读
  • 旧梦随风去结局+番外(姜予宁沈昭寒)列表_旧梦随风去结局+番外(姜予宁沈昭寒)全书+后续+结局在线

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1