html代码:

<canvas id="clickCanvas2"  width="180" height="180" data-total="100" data-curr="75"></canvas>

js代码:

$(function(){
          
                $("#clickCanvas1”).canvasChart({  
                    borderColor: "#24a8e6"  
                });
         
        });

// canvas画圆函数开始
 (function($, window, undefined) {  
      
         $.fn.canvasChart = function(options) {  
      
           var defaults = { };  
           var settings = $.extend({}, defaults, options);
       
           var canvas = $(this).get(0);  
           var total =  $(this).attr("data-total");  
           var curr = $(this).attr("data-curr");  
           var constrast = parseFloat(curr/total).toFixed(2); //比例  
           var context = null;  
      
           if ( !canvas.getContext) {  
             return;  
           }  
      
           // 定义开始点的大小  
           var startArc = Math.PI/2;  
           // 根据占的比例画圆弧  
           var endArc = (Math.PI * 2) * (constrast);  
      
           context = canvas.getContext("2d");  
           context.translate(90,90);  
      
           // 绘制背景圆  
           context.save(); // 保存当前状态 包含 颜色  路径  变形  
           context.beginPath(); // 定义一个子路径开始  
           context.strokeStyle = "#e9e9e9"; //线的颜色  
           context.lineWidth = "2";// 线的大小  
           context.arc(0, 0, 85, 0, Math.PI * 2, true);// 画一个圆  
           context.closePath();// 关闭子路径  
           context.stroke();  
      
           context.restore();// 还原上一个save保存的状态  
      
           // 绘制比例圆  
           context.save();  
           context.rotate(-startArc + Math.PI/180*2);  
           context.beginPath();  
           context.strokeStyle = settings.borderColor;  
           context.lineWidth = "4";  
           context.arc(0, 0, 83, 0, (curr % total == 0 ? Math.PI*2 : (endArc-Math.PI/180*3)), false);  
           context.stroke();  
      
           context.restore();  
      
           // 判断如果是百分百就不用画开始点和结束点的圆了  
           if ( curr % total == 0) {  
             return;  
           }  
      
           // 绘制开始时圆点  
           context.save();  
           context.rotate(-startArc);  
           context.beginPath();  
           context.fillStyle = settings.borderColor;  
           context.arc(83, 2, 2, 0, (Math.PI * 2) , false);  
           context.fill();  
      
           context.restore();  
      
           // 绘制结束时圆点  
           context.save();  
           context.rotate(endArc-startArc);  
           context.beginPath();  
           context.fillStyle = settings.borderColor;  
           context.arc(83, -2, 2, 0, (Math.PI * 2) , false);  
           context.fill();  
      
           context.restore();  
      
         }  
      
       })($, window);

 // canvas画圆函数结束

canvas 画圈 demo的更多相关文章

  1. canvas画箭头demo

    效果图: 代码: <!DOCTYPE html> <html> <title>canvas画箭头demo</title> <body> &l ...

  2. HTML5 之Canvas 绘制时钟 Demo

    <!DOCTYPE html> <html> <head> <title>Canvas 之 时钟 Demo</title> <!--简 ...

  3. 深夜,用canvas画一个时钟

    深夜,用canvas画一个时钟 查看demo 这几天准备阿里巴巴的笔试,可以说已经是心力交瘁,自从阿里和蘑菇街的内推被刷掉之后,开始越来越怀疑起自己的能力来,虽然这点打击应该是微不足道的.毕竟校招在刚 ...

  4. 兼容IE浏览器的canvas画线和圆圈

    1.新建test.html文件,代码如下: <!DOCTYPE html><html><head>    <meta charset="utf-8& ...

  5. python基础练习题(题目 画圈,学用circle画圆形。)

    day37 --------------------------------------------------------------- 实例056:画圈 题目 画图,学用circle画圆形. 分析 ...

  6. 使用javascript和canvas画月半弯

    使用javascript和canvas画月半弯,月半弯好浪漫!浏览器须支持html5 查看效果:http://keleyi.com/a/bjad/8xqdm0r2.htm 以下是代码: <!do ...

  7. 踩个猴尾不容易啊 Canvas画个猴子

    踩个猴尾不容易啊  Canvas画个猴子 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&qu ...

  8. canvas画随机闪烁的星星

    canvas画一颗星星: 规则的星星有内切圆和外切圆,每两个点之间的角度是固定的,因此可得到星星的每个点的坐标,画出星星. function drawStars(x,y,radius1,radius2 ...

  9. canvas画时钟

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...

随机推荐

  1. iOS-数据加密-MD5加密

    数据加密 iOS开发中关于数据加密算法使用最多的就是MD5和Base64,但是开发者中最喜欢的也就是MD5,所以今天就简单介绍一下MD5在吗去使用, 当然关于数据加密还是看公司使用什么,公司使用什么我 ...

  2. Uiautomator 2.0之UiDevice新增API学习小记

    1. InstrumentationRegistry类 1.1. 类说明: 一个暴露的注册实例,持有instrumentation运行的进程和参数,还提供了一种简便的方法调用instrumentati ...

  3. VXLAN 概念(Part II)- 每天5分钟玩转 OpenStack(109)

    上一节我们介绍了 VXLAN 的封装格式以及 VTEP.今天我们将通过例子讨论 VXLAN 封装和转发包的过程,以及 Linux 对 VXLAN 的原生支持. VXLAN 包转发流程 VXLAN 在 ...

  4. 记一次ASP.NET MVC性能优化(实际项目中)

    前言 在开发中为了紧赶项目进度而未去关注性能的问题,在项目逐渐稳定下来后发现性能令人感到有点忧伤,于是开始去关注这方面,本篇为记录在开发中遇到的问题并解决,不喜勿喷.注意:以下问题都是在移动端上出现, ...

  5. 浅析inline-block--使用inline-block创建布局

    inline-block前端程序猿们肯定不陌生,它是display属性的一个取值. 之所以称之为inline-block.是因为它兼具行内元素(inline-element)和块级元素(block-e ...

  6. 在Windows环境中开始Docker的学习和体验

    研究docker有一段时间了,当然我主要的使用环境还是在Linux中,确实很方便. 但也有不少朋友希望使用Windows来工作学习,这里介绍一下在Windows中如何快速开始Docker的学习和体验吧 ...

  7. MAT使用--转

    原文地址: [1]http://ju.outofmemory.cn/entry/172684 [2]http://ju.outofmemory.cn/entry/129445 MAT使用入门 MAT简 ...

  8. iOS 如何自定义UISearchBar 中textField的高度

    iOS 如何自定义UISearchBar 中textField的高度 只需设置下边的方法就可以 [_searchBar setSearchFieldBackgroundImage:[UIImage i ...

  9. VS Code - Debugger for Chrome调试JavaScript的两种方式

    VS Code - Debugger for Chrome调试JavaScript的两种方式 最近由于出差的缘故,博客写的不是很多,一直想写一篇VS Code - Debugger for Chrom ...

  10. 【406错误】 The resource identified by this request is only capable of generating responses with characteristics not acceptable according to the request "accept" headers.

    今天遇到一个奇怪的错误,关于Springmvc的,我明明在Controller方法中写了@ResponseBody,返回一个Map,结果报了406错误. 结果发现,少了一个jar包: 加上去就没事了.