博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从一滴水说起,谈谈CSS形状的生成思路
阅读量:6455 次
发布时间:2019-06-23

本文共 2659 字,大约阅读时间需要 8 分钟。

水是生命之源、生产之要、生态之基。兴水利、除水害,事关人类生存、社会进步,历来是治国安邦的大事。巴拉巴拉~不扯淡了,

来看看下面这张图,额,为了扣题,就管她叫水滴吧(虽然是倒的),从这开始,让我们用css来生成她~

clipboard.png

1.首先把她理解成一个圆与一个三角组合而成,这样,就有了第一种组合法

.box1 {        width: 100px;        height: 100px;        background-color: red;        border-radius: 50%;        position: relative;    }    .box1::after {        position: absolute;        content: '';        width: 50%;        height: 50%;        background-color: #000;        /*     transform: rotate(45deg) translate(-50%, -50%);        left: 50%;        top: 50%;*/        transform: rotate(45deg);        left: 25%;        top: 60%;    }

简单粗暴,一个圆加一个旋转的方块露出的三角,在这里还尝试了下用translate来尝试定位,虽然失败了(不好定位,没旋转的时候很好用,且能使用基于自身的百分比值来定位,可方便的实现垂直居中)。

2.还有种思路,一个竖着的椭圆,把她的左下右下想把法去掉,然后就有了以下两种尝试

.box2 {        width: 100px;        height: 100px;        background-color: red;        border-radius: 50%;        position: relative;    }    .box2::after {        position: absolute;        content: '';        width: 100%;        height: 100%;        background-color: red;        background: linear-gradient(-45deg,#fff  67%, transparent 0) right, linear-gradient(45deg, #fff 67%, transparent 0) left;  background-size: 50% 100%;        background-repeat: no-repeat;        top: 50%;    }

再这里抱个歉,最终效果我没调成,果然一边看直播一边写demo就是没效率,话说96B跑的真快啊

先拿一个圆,再拿一个豁了一个三角的长方形给挡住,差不多是这意思~

.box3 {    width: 100px;    height: 100px;    background: linear-gradient(-45deg, transparent 33%, red 0) right, linear-gradient(45deg, transparent 33%, red 0) left;    background-size: 50% 100%;    background-repeat: no-repeat;    border-radius: 50% 50%;    position: relative;}

这个是上面的改进版,直接对自身使用径向渐变 ,把左右两角设为透明,最终效果也没调成,囧

3.顺着上面的思路,自然想到了能直接对圆进行切割的clip-path属性虽然兼容堪忧

.box4 {    width: 100px;    height: 100px;    position: relative;    background-color: red;    -webkit-clip-path: inset(0 0 0 0 round 50% 50% 0 50%);    -o-clip-path: inset(0 0 0 0 round 50% 50% 0 50%);    clip-path: inset(0 0 0 0 round 50% 50% 0 50%);    transform: rotate(45deg);}

照理说直接切割应该能切出来,但我没弄出来,都是直播的锅,这里我取了个巧,弄了个三个角取圆,一个角直角,最后旋转的方法。

附个clip-path生成器,虽然不能生成本文的水滴。

4.其实都能想到了,3里面为什么不直接用border-radius生成圆角呢,兼容还好点,于是

.box1 {    width: 100px;    height: 100px;    background-color: red;    border-radius: 50% 50% 0; /*top;leftright;bottom*/    transform: rotate(45deg);   }

我也不是谦虚,其实我第一个想出来的方法就是这个,上面的就是想凑点字数,代码简介,易于理解,我网上找了下好像也没人过这个,好顶赞~

总结:

想要一个形状,我们可以遮,切,组合,旋转,这么多种方法,结合伪元素、动画属性,真是其乐无穷~

当然了可以直接base64或者用图片
上面demo放这了,顺序不对请不要介意,话说有空得搞个demo页了。

附:CSS生成云朵

.demo {     height: 50px;     width: 50px;     box-shadow: #eee 65px -15px 0 -5px, #eee 25px -25px, #eee 30px 10px, #eee 60px 15px 0 -10px, #eee 85px 5px 0 -5px;     border-radius: 50%; }

自身是圆,生成自身的阴影再偏移,许多个阴影组合而出的云。

可以在这里看到,啊,当然不是我写的,哭~

转载地址:http://xhfzo.baihongyu.com/

你可能感兴趣的文章
Webstorm常用快捷键备忘
查看>>
js滚动加载到底部
查看>>
关于mac远程链接window服务器以及实现共享文件
查看>>
Redis慢查询,redis-cli,redis-benchmark,info
查看>>
Virtualbox 虚拟机网络不通
查看>>
java概念基础笔记整理
查看>>
CC_UNUSED_PARAM 宏含义的解释
查看>>
leetcode124二叉树最大路径和
查看>>
AngularJS笔记整理 内置指令与自定义指令
查看>>
shell与正则表达式
查看>>
第三篇:白话tornado源码之请求来了
查看>>
表示数值的字符串
查看>>
JQUERY AJAX请求
查看>>
html css 伪样式
查看>>
超级账本Fabric区块链用弹珠游戏Marbles 部署
查看>>
整理Java基础知识--选择与判断
查看>>
Linux查看程序端口占用情况
查看>>
jar包冲突案例分析.md
查看>>
控制圈复杂度的9种重构技术总结
查看>>
当软件项目全部能靠自己搞定了,也能接几万元的软件项目时,未必适合创业...
查看>>