canvas繪制環(huán)形進(jìn)度條
更新時間:2017年02月23日 16:50:09 作者:missFanny
本文主要介紹了canvas繪制環(huán)形進(jìn)度條的示例代碼,具有很好的參考價值,下面跟著小編一起來看下吧
效果如下:

代碼如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="maximum-scale=1.0,minimum-scale=1.0,user-scalable=0,width=device-width,initial-scale=1.0"/>
<meta name="format-detection" content="telephone=no,email=no,date=no,address=no">
<title>canvas繪制環(huán)形進(jìn)度條</title>
<style type="text/css">
.chartbox{width: 100px;margin: 100px auto;}
.myChart{width:100px;height: 100px;}
</style>
</head>
<body>
<div class="chartbox">
<canvas class="myChart" id="myChart" width="100%" height="100%" data-total="100" data-curr="29.45"></canvas>
</div>
<script typet="text/javascript" src="http://libs.baidu.com/jquery/1.9.1/jquery.min.js"></script>
<script type="text/javascript">
(function($, window, undefined) {
$.fn.ringChart = 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;
}
// 定義開始點(diǎn)的大小
var startArc = Math.PI*1.5;
// 根據(jù)占的比例畫圓弧
var endArc = (Math.PI * 2) * constrast;
context = canvas.getContext("2d");
// 圓心文字
context.font="28px Arial";
context.fillStyle = '#ff801a';
context.textBaseline = 'middle';
var text=(Number(curr/total)*100).toFixed(0)+"%";
var tw=context.measureText(text).width;
context.fillText(text,50-tw/2,50);
// 繪制背景圓
context.save();
context.beginPath();
context.strokeStyle = "#e7e7e7";
context.lineWidth = "4";
context.arc(50, 50, 44, 0, Math.PI * 2, false);
context.closePath();
context.stroke();
context.restore();
// 若為百分零則不必再繪制比例圓
if ( curr / total == 0) {
return;
}
// 繪制比例圓
context.save();
context.beginPath();
context.strokeStyle = "#ff801a";
context.lineWidth = "4";
context.arc(50, 50, 44, startArc, (curr % total == 0 ? startArc : (endArc+startArc)), false);
context.stroke();
context.restore();
}
})($, window);
$("#myChart").ringChart();
</script>
</body>
</html>
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
JS使用window.requestAnimationFrame()對列表切片進(jìn)行渲染
這篇文章主要為大家介紹了JS使用requestAnimationFrame對列表切片進(jìn)行渲染,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
ES6知識點(diǎn)整理之String字符串新增常用方法示例
這篇文章主要介紹了ES6知識點(diǎn)整理之String字符串新增常用方法,結(jié)合實例形式分析了ES6字符串String includes,startsWith,endsWith等方法相關(guān)使用技巧,需要的朋友可以參考下2019-07-07
淺談javascript中的prototype和__proto__的理解
這篇文章主要介紹了淺談javascript中的prototype和__proto__的理解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04

