【CSS】饼图(双色)

作者: 德育处主任 | 来源:发表于2019-01-25 07:35 被阅读0次
微信订阅号:Rabbit_svip 微信订阅号:Rabbit_svip

这是本节用纯CSS做出来的效果。当然,最后还会用JS模拟接收后台数据来控制饼图的比例。

本节的核心思想是通过CSS做出上面两种效果。

要做到上图的效果,首先要有以下基础知识:

【CSS】渐变背景(background-image)
【CSS】椭圆、半圆、1/4圆



现在画饼图的方法非常多,可以用 echarts.js、G2.js、chart.js、flotr2等 JS 库,也可以用SVG,也可以用Canvas来画。

上述的方法本节都不会讲到。本节只讲解如何用 CSS 画出基本饼图。

用CSS画饼图的核心思想如下图所示

微信订阅号:Rabbit_svip

蓝色是最底层的圆,并设置了overflow: hidden;
红色代表另一个比例(比率),放在蓝色圆的子层。

核心思路:把圆形的两个占比部分指定两种颜色,然后用伪元素覆盖上去,通过旋转来决定比率。



先来演示一下上面最简单的圆。

【方法 1-1】
HTML代码

<div class="pie"></div>

CSS代码

.pie {
  width: 200px;
  height: 200px;
  background: #1d365d;
  border-radius: 50%;
  background-image: linear-gradient(to right, transparent 50%, #ff2d51 0);
}

这里用了背景渐变的方式,很轻巧的就把效果做出来了。

微信订阅号:Rabbit_svip

当然,也可以用伪元素的方式来写。



方法 1-2】
HTML代码

<div class="pie"></div>

CSS代码

.pie {
  width: 200px;
  height: 200px;
  background: #1d365d;
  border-radius: 50%;
  overflow: hidden;
}
.pie::before {
  content: '';
  display: block;
  margin-left: 50%;
  height: 100%;
  background: #ff2d51;
}

也能达到几乎相同的效果。效果图我就不上了。

需要注意的是,用伪元素写的话,主元素要设置overflow: hidden;
又或者给伪元素设置适合的 border-radius。

border-radius: 0 100% 100% 0 / 50%;


如果饼图的比例不是1:1,是更加复杂的比例,就要用【方法1-1】配合伪元素来做了。
逻辑如下图所示:

微信订阅号:Rabbit_svip

我们可以通过 rotate() 变形属性让这个伪元素旋转起来。

比如要显示10%的比率,可以指定旋转值为36deg(1.2 x 360 = 36)。当然,写成 0.1turn 会显得更加直观一些。

设置旋转之前,要先设置好旋转的中心点(transform-origin: 0 50%;)。

HTML代码

<div class="pie"></div>

CSS代码

.pie {
  width: 200px;
  height: 200px;
  background-color: #1d365d;
  border-radius: 50%;
  background-image: linear-gradient(to right, transparent 50%, #ff2d51 50%);
}

.pie::before {
  content: '';
  display: block;
  margin-left: 50%;
  height: 100%;
  background-color: inherit;
  border-radius: 0 100% 100% 0 / 50%;
  transform-origin: left;
  transform: rotate(.1turn);
}
微信订阅号:Rabbit_svip

还没完!

此时这个饼图在 0 - 500% 的比率时是能正常显示的,但如果超过 50 % 结果就变成如下图所示

微信订阅号:Rabbit_svip

通过观察可以发现上图是这样的

微信订阅号:Rabbit_svip

当超过50%时,应该换另一种思路。

伪元素应该一直在右边,然后把伪元素的颜色改成底圆右边的颜色。

当伪元素的比率是51% - 100%的时候,就用当前比率 减去 50。

微信订阅号:Rabbit_svip

这样就能做出 50%- 100% 比率的饼图了。

HTML代码

<div class="pie"></div>

CSS代码

.pie {
  width: 200px;
  height: 200px;
  background-color: #1d365d;
  border-radius: 50%;
  background-image: linear-gradient(to right, transparent 50%, #ff2d51 50%);
}

.pie::before {
  content: '';
  display: block;
  margin-left: 50%;
  height: 100%;
  background-color: #ff2d51;
  border-radius: 0 100% 100% 0 / 50%;
  transform-origin: left;
  transform: rotate(.1turn);
}
微信订阅号:Rabbit_svip

以上就是用 纯CSS 画饼图是思路。

如果需要在中间加上数字来显示占比,可以在底圆设置position: relative;
然后在底圆的元素里面再添加一个 div 元素,调整该 div 元素的样式即可。



上面的思路是完完全全可以画一个简单的饼图的。但通常页面是活的,数据是能改变的。当数据是动态的改变的时候,就只能借助JS来动态显示了。

完整代码

相关文章

  • 【CSS】饼图(双色)

    这是本节用纯CSS做出来的效果。当然,最后还会用JS模拟接收后台数据来控制饼图的比例。 本节的核心思想是通过CSS...

  • 前端学习笔记1

    【CSS3——简单的饼图】 @keyframes spin{ to{transform: rotate(.5tu...

  • CSS、SVG、Canvas制作饼图

    实现 一、CSS 1、border实现饼图 限于占比1/4,1/2,3/4需求的饼图可以这样实现 源码: 2、ba...

  • PS网页设计配图之道:首图的设计技巧

    一、双色冰淇淋渐变 首图当作全屏出血大图处理时,你可以将图片调色成为双色渐变,有点像我们吃的双色冰淇淋球,选一组你...

  • echats 饼图

    昨天做的饼状图,legend部分的format函数做的不够美观,以后改进: css样式如下:

  • 读书会第70期

    双11晚上,我们的线上读书会。学习了。调整中间信念的技术,饼图技术。 饼图技术主要应用于个体的内归因或者是外归因的...

  • vue+elementUi+echarts 折线图组件

    echarts官网 效果 ? 此图并非折线图饼图联动 折线图饼图联动组件飞机票 ?饼图点击事件再饼图组件中 饼图组...

  • PieChart方法记录

    设置饼图的文字是在饼图内还是饼图外

  • 背景效果-css-v1.0.0

    条纹背景 双条纹 多条纹 CSS标准规定:如果某个色标的位置值比整个列表中在它之前的色标的位置值都要小,则该色标的...

  • canvas画饼图(四) 饼图动画

    饼图的动画饼图的动画主要有两个:一个是刚开始的饼图由小到大,鼠标到饼图上面饼图,饼图变大或者变小 实现思路饼图变大...

网友评论

    本文标题:【CSS】饼图(双色)

    本文链接:https://www.haomeiwen.com/subject/kpwpjqtx.html