谈谈一些有趣的CSS题目(27)-- 神奇的 conic-gradient 角向渐变 #19
Comments
|
nice |
|
在写“重复角向渐变 ”的地方代码a和e写反了:repaeting-conic-gradient;包括下面的几个 |
|
@WantedSr 感谢提出 我修改下~ |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
开始使用 conic-gradient 角向渐变
感谢 LeaVerou 大神,让我们可以提前使用上这么美妙的属性。
conic-gradient是个什么?说到conic-gradient,就不得不提的它的另外两个兄弟:linear-gradient: 线性渐变radial-gradient: 径向渐变说这两个应该还是有很多人了解并且使用过的。CSS3 新增的线性渐变及径向渐变给 CSS 世界带来了很大的变化。
而
conic-gradient,表示角向渐变,另外一种渐变方式,给 CSS 世界带来了更多可能。下面进入正文,本文中所有示例,请在高版本 Chrome 内核下预览。
API
看看它最简单的 API:
{ /* Basic example */ background: conic-gradient(deeppink, yellowgreen); }与线性渐变及径向渐变的异同
那么它和另外两个渐变的区别在哪里呢?
linear-gradient线性渐变的方向是一条直线,可以是任何角度radial-gradient径向渐变是从圆心点以椭圆形状向外扩散而从方向上来说,角向渐变的方向是这样的:
划重点:
从图中可以看到,角向渐变的渐变方向和起始点。起始点是图形中心,然后以顺时针方向绕中心实现渐变效果。
使用
conic-gradient实现颜色表盘从上面了解了
conic-gradient最简单的用法,我们使用它实现一个最简单的颜色表盘。conic-gradient不仅仅只是从一种颜色渐变到另一种颜色,与另外两个渐变一样,可以实现多颜色的过渡渐变。由此,想到了彩虹,我们可以依次列出
赤橙黄绿青蓝紫七种颜色:conic-gradient: (red, orange, yellow, green, teal, blue, purple)上面表示,在角向渐变的过程中,颜色从设定的第一个
red开始,渐变到orange,再到yellow,一直到最后设定的purple。并且每一个区间是等分的。我们再给加上
border-radius: 50%,假设我们的 CSS 如下,{ width: 200px; height: 200px; border-radius: 50%; background: conic-gradient(red, orange, yellow, green, teal, blue, purple); }看看效果:
wow,已经有了初步形状了。但是,总感觉哪里不大自然。总之,浑身难受
嗯?问题出在哪里呢?一是颜色不够丰富不够明亮,二是起始处与结尾处衔接不够自然。让我再稍微调整一下。
我们知道,表示颜色的方法,除了
rgb()颜色表示法之外,还有hsl()表示法。这里,我们通过改变色相得到一个较为明亮完整的颜色色系。
也就是采用这样一个过渡
hsl(0%, 100%, 50%)-->hsl(100%, 100%, 50%),中间只改变色相,生成 20 个过渡状态。借助 SCSS ,CSS 语法如下:得到如下效果图,这次的效果很好:
CodePen Demo -- conic-gradinet colors
配合百分比使用
当然,我们可以更加具体的指定角向渐变每一段的比例,配合百分比,可以很轻松的实现饼图。
假设我们有如下 CSS:
{ width: 200px; height: 200px; background: conic-gradient(deeppink 0, deeppink 30%, yellowgreen 30%, yellowgreen 70%, teal 70%, teal 100%); border-radius: 50%; }上图,我们分别指定了 0~30%,30%~70%,70%~100% 三个区间的颜色分别为
deeppink(深红),yellowgreen(黄绿)以及teal(青),可以得到如下饼图:当然,上面只是百分比的第一种写法,还有另一种写法也能实现:
{ background: conic-gradient(deeppink 0 30%, yellowgreen 0 70%, teal 0 100%); }这里表示 :
deeppinkyellowgreenteal而且,先定义的颜色的层叠在后定义的颜色之上。
CodePen Demo -- use proportion in conic-gradient
配合
background-size使用使用了百分比控制了区间,再配合使用
background-size就可以实现各种贴图啦。我们首先实现一个基础角向渐变图形如下:
{ width: 250px; height: 250px; margin: 50px auto; background: conic-gradient(#000 12.5%, #fff 0 37.5%, #000 0 62.5%, #fff 0 87.5%, #000 0); }效果图:
再加上
background-size: 50px 50px;,也就是:{ width: 250px; height: 250px; margin: 50px auto; background: conic-gradient(#000 12.5%, #fff 0 37.5%, #000 0 62.5%, #fff 0 87.5%, #000 0); background-size: 50px 50px; }得到:
CodePen Demo -- conic-gradient wallpaper
重复角向渐变
repeating-conic-gradient与线性渐变及径向渐变一样,角向渐变也是存在重复角向渐变
repaet-conic-gradient的。我们假设希望不断重复的片段是 0~30° 的一个片段,它的 CSS 代码是
conic-gradient(deeppink 0 15deg, yellowgreen 0 30deg)。那么,使用了
repeating-conic-gradient之后,会自动填充满整个区域,CSS 代码如下:{ width: 200px; height: 200px; background: repeating-conic-gradient(deeppink 0 15deg, yellowgreen 0 30deg); border: 1px solid #000; }CodePen Demo -- repeating-conic-gradient
角向渐变动画
基本的一些用法了解完了,看看使用角向渐变可以玩出什么花来。
借助
SCSS的强大,我们可以制作出一些非常酷炫的背景展板。使用 SCSS ,我们随机生成一个多颜色的角向渐变图案:
假设我们的 HTML 结构如下:
CSS/SCSS 代码如下:
简单解释下上面的 SCSS 代码,
randomNum()用于生成随机数,randomNum(255)相当于随机生成 1~255 的随机数;randomConicGradient()用于生成整个conic-gradient()内的参数,也就是每一区间的颜色;vw和vh是比较新的 CSS 单位,一个页面而言,它的视窗的高度就是 100vh,宽度就是 100vw 。OK,刷新页面,得到如下效果图:
卧槽,很酷炫,bling bling 闪闪发光的感觉啊!而且是随机生成的各种颜色,所以每次刷新都有新体验有木有!!
还没完,接下来给它加上旋转动画,蹬蹬蹬,旋转起来大概是这样:
由于 GIF 图大小的限制,只看 GIF 没办法感受到全屏下那种科幻眩晕的感觉,墙裂建议你戳进来看看:
CodePen Demo -- conic-gradient Animation
脑洞时刻
到这里我还是不是很满足。想到了之前的
mix-blend-mode属性。如果多个角向渐变层级叠加,并且运用上
mix-blend-mode会发生什么?好可怕的想法...最终捣鼓出这种非常科幻的效果:
上图使用了 2 个半透明的角向渐变,相对反向进行旋转,并且在底层使用
mix-blend-mode: overlay叠加了一个白黑径向渐变图层。可以看看代码及效果:CodePen Demo -- conic-gradient Animation
在项目中使用
conic-gradient上面的例子酷炫归酷炫,但是在项目中实用性不强。那么角向渐变是否能用于业务中的?答案是肯定的。
看看下面这个图,芝麻信用分背景渐变颜色条,不使用 JS,纯 CSS 借助
conic-gradient如何画出来。假设我们的结构如下:
为了凸显
conic-gradient的实用性,简单将二者合二为一,模拟了一下。看看效果,大功告成,所以说conic-gradient还是有用武之地的:CodePen Demo -- 使用 conic-gradient 实现表盘信用分示例
角向渐变
conic-gradientpolyfill 垫片库看到这里,想必读者们都跃跃欲试这么神奇的属性。
但是,按照惯例,这种 “高科技” 通常兼容性都不怎么滴。
conic-gradient兼容性又如何呢?非常惨烈,CSS 官方对其的描述是:
万幸的是,在文章开头我也提到了,感谢 LeaVerou 大神,让我们可以提前使用上这么美妙的属性。
LeaVerou 提供了一个垫片库,按照本文上述的语法,添加这个垫片库,就可以开心的使用起来啦。
你需要添加如下的 JS ,垫片库会按照 CSS 语法,生成对应的角向渐变图案,并且转化为 BASE64 代码:
好了,本文到此结束,希望对你有帮助 :)
如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。
参考文献
CSS conic-gradient() polyfill
The text was updated successfully, but these errors were encountered: