1. [图片] lxdpie.jpg


​2. [文件] lqdpie.html ~ 801B     下载(7)

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html lang="ru">
<head>
  <title></title>
  <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
 
<script type="text/javascript" src="pie.js"></script>
</head>
<body>
   
    <fieldset style='position:relative;width:500px;height:400px;'>
            <legend> 刘强东吃饼</legend>
            <canvas id="p" width="500" height="400"   >Your browser does not support the HTML5 canvas tag.</canvas>
        </fieldset>
 
 
<script>
 
var config = {
    id: 'p',
    type: '%',
 
    data: [
['刘强东',18.4],['老虎基金',22.1],['HHGL',15.8],['DST',11.2],['BAI',9.5],['Fortune ising',5.3],['Kingdom',5.0],['红杉资本',2.0],
 
 ]
};
var p= pie(config);
    p.render();
 
</script>
 
 
</body>
</html>
3. [文件] pie.js ~ 3KB     
(function() {
    var Pie = (function() {
     
        var F = function(conf) {
                this.type=null;
                this.id=null;
                this.total=0;
                this.container=null;
                this.data=[];
                this.init(conf);
                return this;
            };
        F.prototype = {
            defaultBgcolor: ['deeppink', 'mediumslateblue', 'chartreuse', 'goldenrod', "#ffff00", "#2F368F", "#F6A25D", "#2CA8E0", "#77D1F6", '#181818', '#45AB35', "#336699", "#5fD1F6"],
 
            init: function(options) {
                for (var p in options) {
                    this[p] = options[p];
                }
                this.container = document.getElementById(this.id);
            },
            percentize: function() {
 
                if (this.type && this.type == '%') {
                    var sum = 0;
                    for (var i = 0; i < this.data.length; i++) {
                        sum += this.data[i][1];
                        if (this.data[i + 1] && (sum + this.data[i + 1][1]) > 100) {
                            break;
                        }
                    }
                    if (i != this.data.length) {
                        this.data = this.data.splice(0, i + 1);
                    }
                    if (sum != 100) {
                        this.data.push(['?', Math.ceil(100 - sum), '#282828']);
                    }
                } else {
                    var sum = 0;
 
                    for (var i = 0; i < this.data.length; i++) {
                        sum += this.data[i][1];
                    }
                    if (0 == this.total) {
                        this.total = sum;
                    }
                    
                    if (this.total - sum > 0) {
 
                        this.data.push(['?', this.total - sum, '#282828']);
                    }http://www.enterdesk.com/special/shouhui/​
 
                    for (var i = 0; i < this.data.length; i++) {
                        this.data[i][1] = Math.round((this.data[i][1] / this.total) * 100);
                    }手绘图片
                    
                }
  
 
            },
            renderPie: function() {
                var x = this.container.clientWidth * .33;
                var y = this.container.clientHeight * .5;
                var radius = (x > y) ? y : x;
                var ctx = this.container.getContext("2d");
                var startPoint = 0;
                for (var i = 0; i < this.data.length; i++) {
                    if (null == this.data[i][2]) {
                        this.data[i][2] = this.defaultBgcolor[i % this.defaultBgcolor.length];
                    }
                    ctx.fillStyle = this.data[i][2];
                    ctx.beginPath();
                    ctx.moveTo(x, y);
                    ctx.arc(x, y, radius, startPoint, startPoint + Math.PI * 2 * (this.data[i][1] / 100), false);
                    ctx.fill();
                    startPoint += Math.PI * 2 * (this.data[i][1] / 100);
                }
                return true;
            },
            renderLabel: function() {
                var table = ['<table  >'];
                for (var i = 0; i < this.data.length; i++) {
                    table.push('<tr><td bgcolor="');
                    table.push(this.data[i][2]);
                    table.push('">&nbsp;&nbsp;</td><td>');
                    table.push(this.data[i][0]);
                    table.push("</td><td align=right>");
                    if (this.type && this.type == '%') {
                        table.push(this.data[i][1] + "%");
                    } else {
                        table.push(Math.ceil(this.total * this.data[i][1] / 100));
                    }
                    table.push("</td></tr>");
                }
                table.push("</table>");
                this.container.insertAdjacentHTML("afterEnd", '<div   >  ' + table.join("") + '</div>');
            },
            render: function() {
                this.percentize();
                this.renderPie();
                this.renderLabel();
                return true;
            }
        };
        var Pie = function(conf) {
                return new F(conf);
            },
            r;
 
 
 
 
 
        return Pie;
 
    })();
 
 
    window.pie = Pie;
})(window);

html5 canvas画饼的更多相关文章

  1. HTML5 Canvas 画虚线组件

    前段时间由于项目需要,用到了HTML5 Canvas画图,但是没有画虚线的方法,自己写了一个HTML5 画虚线的组件. dashedLine.js if (window.CanvasRendering ...

  2. HTML5 Canvas 画钟表

    画钟表是2D画图的老生常谈,我也不能免俗弄了一个.代码如下: <!DOCTYPE html> <html lang="utf-8"> <meta ht ...

  3. CSS3进度条 和 HTML5 Canvas画圆环

    看到一些高大上的进度条插件,然后想自己用CSS写.经过搜索资料之后,终于成功了.为了以后方便拿来用,或者复习.将代码贴出. HTML代码: 只需要两个div,外面的为一个有border的div id为 ...

  4. html5 canvas画不出图像的原因

    很久没写博客了,今年过年的时候,家里出了意外,现在心里依然很难受.6月份之前一直忙着写毕业论文,答辩完6月初回公司继续上班,今天刚好周末有空,就写下之前碰到一个问题. 做一个图像查看器(基于Chrom ...

  5. 基于HTML5 Canvas的饼状图表实现教程

    昨天我们分享了一款基于HTML5的线性图表应用,效果非常不错,可以看在线DEMO或者实现教程.今天我们继续来分享一款基于HTML5的网页图表,它也是利用Canvas绘制的,但是和前面不同的是,这款图表 ...

  6. html5 canvas画流程图

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  7. HTML5 Canvas画数字时钟

    先不说废话,没代码算个蛋. 一些地方注释都写得比较清楚,不过这只是部分,因为只有秒针,但是时针,分针的逻辑都是一致的. 代码中有些坐标不知道为什么较不准,看看就好

  8. html5 canvas画进度条

    这个ie8的兼容是个问题,ie8 的innerHTML有问题啊,添加两个附件吧 <!DOCTYPE html> <html> <head> <meta cha ...

  9. html5 canvas 画hello ketty

    <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ...

随机推荐

  1. 每天5道面试题(二)java基础

    说出Servlet的生命周期,并说出Servlet和CGI的差别 Servlet被server实例化后,容器执行其init方法,请求到达时执行其service方法,service方法自己主动派遣执行与 ...

  2. Java reference的种类及使用场景

    Java 中一共有 4 种类型的引用 : StrongReference. SoftReference. WeakReference 以及 PhantomReference (传说中的幽灵引用).这  ...

  3. vue Object.freeze() 优化

    参考自:https://segmentfault.com/a/1190000006191558 Object.freeze()是ES5新增的特性,可以冻结一个对象,防止对象被修改. vue 1.0.1 ...

  4. spring(16)------spring的数据源配置

    在spring中,通过XML的形式实现数据源的注入有三种形式. 一.使用spring自带的DriverManagerDataSource 使用DriverManagerDataSource配置数据源与 ...

  5. 【Python】ModuleNotFoundError: No module named 'matplotlib.pyplot'

    安装好matplotlib后,很激动的建立了一个文件夹matplotlib,并且在其下面建立了,mpl_squraes.py文件,代码编辑完成以后,点击运行,报错如下: 仔细分析了之后,发现是文件夹名 ...

  6. mac环境下清理系统垃圾clearMyMac 3.9 破解版

    mac环境下清理系统垃圾clearMyMac 3 轻轻松松清理好几十G的垃圾文件 下载地址 链接: https://pan.baidu.com/s/1XZbZwzhgQCnzpvQDvyQrRA 密码 ...

  7. 深入Asyncio(十)异步解析式

    Async Comprehensions 目前已经学会了如何在Python中进行异步迭代,接下来的问题是这是否适用于解析式?答案是OJBK!该支持在PEP 530中提及,建议去读一下. >> ...

  8. cesium学习--初识

    一.Cesium 官方介绍:CesiumJS是一个开源的JavaScript库,用于世界级的3D地球仪和地图.任务是为静态和时间动态的内容创建领先的3D地球和地图,具有最好的性能.精度.视觉质量.平台 ...

  9. 目标检测之hog(梯度方向直方图)---hog简介0

    梯度直方图特征(HOG) 是一种对图像局部重叠区域的密集型描述符, 它通过计算局部区域的梯度方向直方图来构成特征.Hog特征结合SVM分类器已经被广泛应用于图像识别中,尤其在行人检测中获得了极大的成功 ...

  10. OpenStack 使用Ceph 配置指导

    概述 Ceph 作为分布式文件系统,不但具有高可靠性.高扩展性.高性能. 也是统一存储系统.支持对象存储.块存储.文件存储,本文介绍怎样使用Ceph 块存储作为OpenStack的Glance.Nov ...