实例介绍
【实例简介】Canvas仿支付宝芝麻信用仪表盘图表和雷达图表代码
*
* @authors
* @date 2015-08-14 11:31:56
* @version 1.0.3
*/
var Meter = (function () {
var options = {
styles: {
sAngle: 0.93,
eAngle: 2.07,
area: {
radius: 30,
colors: {
'0': '#1266BC',
'0.15': '#67C6F2',
'0.27': '#45F5E6',
'0.75': '#FFDE00',
'0.93': '#F5694B',
'1': '#FF0202'
},
lineWidth: 1,
scaleLength: 9,
scaleWidth: 0.2,
lineColor: '#fff'
},
range: {
color: '#F4674B',
width: 2,
arrow: {
height: 15,
radius: 4
}
},
value: {
margin: -50,
color: '#F4674B',
font: 'bold 52px Microsoft YaHei'
},
title: {
margin: -5,
color: '#F4674B',
font: 'bold 20px Microsoft YaHei'
},
subTitle: {
margin: 25,
color: '#999',
font: '14px Microsoft YaHei'
},
label: {
radius: 28,
color: '#aaa',
background: '#f5f5f5',
font: '12px Microsoft YaHei'
},
inner: {
radius: 97,
color: '#999',
dashedWidth: 3
}
}
};
var element,
context,
styles,
sAngle,
eAngle,
areaStyle,
rangeStyle,
valueStyle,
titleStyle,
subTitleStyle,
labelStyle,
innerStyle;
var extend = function(obj1, obj2){
for(var k in obj2) {
if(obj1.hasOwnProperty(k) && typeof obj1[k] == 'object') {
extend(obj1[k], obj2[k]);
} else {
obj1[k] = obj2[k];
}
}
}
var calcLocation = function(r, end){
return {
x: options.centerPoint.x r * Math.cos(Math.PI * end),
y: options.centerPoint.y r * Math.sin(Math.PI * end)
};
}
var calcValueRange = function(value){
var data = options.data.area,
index = data.length - 1;
for (var i = index; i >= 0; i--) {
if(value >= data[i].min && value < data[i].max){
index = i;
}
};
var r = (eAngle - sAngle)/data.length,
s = r * index sAngle,
e = r * (index 1) sAngle,
o = data[index];
return {
range: (value - o.min)/(o.max - o.min) * (e - s) s,
index: index
};
}
var drawCircle = function(opts, flag) {
var x = opts.x || options.centerPoint.x,
y = opts.y || options.centerPoint.y,
s = opts.start || 0,
e = opts.end || 2;
context.beginPath();
context.moveTo(x, y);
switch(flag){
case 1:
context.setLineDash && context.setLineDash([innerStyle.dashedWidth]);
case 2:
context.arc(x, y, opts.r, Math.PI*s, Math.PI*e);
context.closePath();
context.strokeStyle = opts.style;
context.stroke();
break;
default:
context.arc(x, y, opts.r, Math.PI*s, Math.PI*e);
context.closePath();
context.fillStyle = opts.style;
context.fill();
break;
}
}
var drawArea = function(){
var grad = context.createLinearGradient(0, 0, options.radius*2, 0);
for(var k in areaStyle.colors) {
grad.addColorStop(k, areaStyle.colors[k]);
}
drawCircle({
r: options.radius,
start: sAngle,
end: eAngle,
style: grad
});
drawCircle({
r: options.radius - areaStyle.radius,
style: '#fff'
});
}
var drawValueRange = function(valueRange){
var r = options.radius - areaStyle.radius;
drawCircle({
r: r,
start: sAngle,
end: valueRange.range,
style: labelStyle.background
});
drawCircle({
r: r - labelStyle.radius,
start: sAngle,
end: valueRange.range,
style: rangeStyle.color
});
drawCircle({
r: r - labelStyle.radius - rangeStyle.width,
style: '#fff'
});
}
var fillText = function(opts){
context.font = opts.font;
context.fillStyle = opts.color;
context.textAlign = opts.align || 'center';
context.textBaseline = opts.vertical || 'middle';
context.moveTo(opts.x, opts.y);
context.fillText(opts.text, opts.x, opts.y);
}
var drawInnerContent = function(valueRange, value){
drawCircle({
r: innerStyle.radius,
start: sAngle,
end: eAngle,
style: innerStyle.color
}, 1);
drawCircle({
r: innerStyle.radius - 1,
style: '#fff'
});
var data = options.data;
fillText({
font: valueStyle.font,
color: valueStyle.color,
text: value,
x: options.radius,
y: options.radius valueStyle.margin
});
fillText({
font: titleStyle.font,
color: titleStyle.color,
text: data.title.replace('{t}', data.area[valueRange.index].text).replace('{v}', value),
x: options.radius,
y: options.radius titleStyle.margin
});
fillText({
font: subTitleStyle.font,
color: subTitleStyle.color,
text: data.subTitle,
x: options.radius,
y: options.radius subTitleStyle.margin
});
}
var drawArrow = function(valueRange){
var r = options.radius - areaStyle.radius - labelStyle.radius,
loc = calcLocation(r, valueRange.range),
x = loc.x - 1,
y = loc.y 0.5;
drawCircle({
x: x,
y: y,
r: rangeStyle.arrow.radius,
style: rangeStyle.color
});
var a = calcLocation(r - rangeStyle.arrow.height, valueRange.range),
b = calcLocation(r, valueRange.range - 0.01),
c = calcLocation(r, valueRange.range 0.01);
context.beginPath();
context.moveTo(a.x - 1, a.y 0.5);
context.lineTo(b.x - 1, b.y 0.5);
context.lineTo(c.x - 1, c.y 0.5);
context.closePath();
context.fillStyle = rangeStyle.color;
context.fill();
drawCircle({
x: x,
y: y,
r: rangeStyle.arrow.radius - rangeStyle.width,
style: '#fff'
});
}
var drawLine = function(line) {
context.beginPath();
context.moveTo(line.start.x, line.start.y);
context.lineTo(line.end.x, line.end.y);
context.closePath();
context.strokeStyle = line.style;
context.lineWidth = line.width || 1;
context.stroke();
}
var drawTickMarks = function(){
var scaleLength = areaStyle.scaleLength,
data = options.data.area,
len = scaleLength * data.length,
range = (eAngle - sAngle)/len;
for(var j = 1; j < len; j ){
drawLine({
start: calcLocation(options.radius, sAngle range * j),
end: calcLocation(options.radius - areaStyle.radius, sAngle range * j),
style: areaStyle.lineColor,
width: j % scaleLength == 0 ? areaStyle.lineWidth: areaStyle.scaleWidth
});
}
var lblArr = [];
for(var i = 0; i < data.length; i ){
var o = data[i];
// 如果不需兼容IE9以下则不用join
if(lblArr.join('').indexOf(o.min) == -1) {
lblArr.push(o.min);
}
lblArr.push(o.text);
lblArr.push(o.max);
}
var lblLen = lblArr.length - 1,
lblRange = (eAngle - sAngle)/lblLen,
lblOpt = labelStyle,
lblR = options.radius - areaStyle.radius - lblOpt.radius/2;
for(var k = 0; k <= lblLen; k ){
var loc = calcLocation(lblR, sAngle lblRange * k);
lblOpt.x = loc.x;
lblOpt.y = loc.y;
lblOpt.text = lblArr[k];
fillText(lblOpt);
}
}
var drawing = function(w, h) {
var value = options.data.value,
valueTemp = options.data.area[0].min;
var timer = setInterval(function(){
context.clearRect(0, 0, w, h);
context.fillStyle = "#fff";
context.fillRect(0, 0, w, h);
valueTemp = valueTemp 10 > value ? value: valueTemp 10;
var valueRange = calcValueRange(valueTemp);
drawArea();
drawValueRange(valueRange);
drawInnerContent(valueRange, valueTemp);
drawArrow(valueRange);
drawTickMarks();
if(valueTemp === value) {
clearInterval(timer);
}
}, 10);
}
var exports = {};
exports.setOptions = function(opts){
extend(options, opts);
styles = options.styles;
sAngle = styles.sAngle;
eAngle = styles.eAngle;
areaStyle = styles.area;
rangeStyle = styles.range;
valueStyle = styles.value;
titleStyle = styles.title;
subTitleStyle = styles.subTitle;
labelStyle = styles.label;
innerStyle = styles.inner;
element = typeof options.element == 'string' ? document.getElementById(options.element) : options.element;
context = element.getContext('2d');
return exports;
};
exports.init = function(){
drawing(element.offsetWidth, element.offsetHeight);
return exports;
}
return exports;
})();
【实例截图】
*
* @authors
* @date 2015-08-14 11:31:56
* @version 1.0.3
*/
var Meter = (function () {
var options = {
styles: {
sAngle: 0.93,
eAngle: 2.07,
area: {
radius: 30,
colors: {
'0': '#1266BC',
'0.15': '#67C6F2',
'0.27': '#45F5E6',
'0.75': '#FFDE00',
'0.93': '#F5694B',
'1': '#FF0202'
},
lineWidth: 1,
scaleLength: 9,
scaleWidth: 0.2,
lineColor: '#fff'
},
range: {
color: '#F4674B',
width: 2,
arrow: {
height: 15,
radius: 4
}
},
value: {
margin: -50,
color: '#F4674B',
font: 'bold 52px Microsoft YaHei'
},
title: {
margin: -5,
color: '#F4674B',
font: 'bold 20px Microsoft YaHei'
},
subTitle: {
margin: 25,
color: '#999',
font: '14px Microsoft YaHei'
},
label: {
radius: 28,
color: '#aaa',
background: '#f5f5f5',
font: '12px Microsoft YaHei'
},
inner: {
radius: 97,
color: '#999',
dashedWidth: 3
}
}
};
var element,
context,
styles,
sAngle,
eAngle,
areaStyle,
rangeStyle,
valueStyle,
titleStyle,
subTitleStyle,
labelStyle,
innerStyle;
var extend = function(obj1, obj2){
for(var k in obj2) {
if(obj1.hasOwnProperty(k) && typeof obj1[k] == 'object') {
extend(obj1[k], obj2[k]);
} else {
obj1[k] = obj2[k];
}
}
}
var calcLocation = function(r, end){
return {
x: options.centerPoint.x r * Math.cos(Math.PI * end),
y: options.centerPoint.y r * Math.sin(Math.PI * end)
};
}
var calcValueRange = function(value){
var data = options.data.area,
index = data.length - 1;
for (var i = index; i >= 0; i--) {
if(value >= data[i].min && value < data[i].max){
index = i;
}
};
var r = (eAngle - sAngle)/data.length,
s = r * index sAngle,
e = r * (index 1) sAngle,
o = data[index];
return {
range: (value - o.min)/(o.max - o.min) * (e - s) s,
index: index
};
}
var drawCircle = function(opts, flag) {
var x = opts.x || options.centerPoint.x,
y = opts.y || options.centerPoint.y,
s = opts.start || 0,
e = opts.end || 2;
context.beginPath();
context.moveTo(x, y);
switch(flag){
case 1:
context.setLineDash && context.setLineDash([innerStyle.dashedWidth]);
case 2:
context.arc(x, y, opts.r, Math.PI*s, Math.PI*e);
context.closePath();
context.strokeStyle = opts.style;
context.stroke();
break;
default:
context.arc(x, y, opts.r, Math.PI*s, Math.PI*e);
context.closePath();
context.fillStyle = opts.style;
context.fill();
break;
}
}
var drawArea = function(){
var grad = context.createLinearGradient(0, 0, options.radius*2, 0);
for(var k in areaStyle.colors) {
grad.addColorStop(k, areaStyle.colors[k]);
}
drawCircle({
r: options.radius,
start: sAngle,
end: eAngle,
style: grad
});
drawCircle({
r: options.radius - areaStyle.radius,
style: '#fff'
});
}
var drawValueRange = function(valueRange){
var r = options.radius - areaStyle.radius;
drawCircle({
r: r,
start: sAngle,
end: valueRange.range,
style: labelStyle.background
});
drawCircle({
r: r - labelStyle.radius,
start: sAngle,
end: valueRange.range,
style: rangeStyle.color
});
drawCircle({
r: r - labelStyle.radius - rangeStyle.width,
style: '#fff'
});
}
var fillText = function(opts){
context.font = opts.font;
context.fillStyle = opts.color;
context.textAlign = opts.align || 'center';
context.textBaseline = opts.vertical || 'middle';
context.moveTo(opts.x, opts.y);
context.fillText(opts.text, opts.x, opts.y);
}
var drawInnerContent = function(valueRange, value){
drawCircle({
r: innerStyle.radius,
start: sAngle,
end: eAngle,
style: innerStyle.color
}, 1);
drawCircle({
r: innerStyle.radius - 1,
style: '#fff'
});
var data = options.data;
fillText({
font: valueStyle.font,
color: valueStyle.color,
text: value,
x: options.radius,
y: options.radius valueStyle.margin
});
fillText({
font: titleStyle.font,
color: titleStyle.color,
text: data.title.replace('{t}', data.area[valueRange.index].text).replace('{v}', value),
x: options.radius,
y: options.radius titleStyle.margin
});
fillText({
font: subTitleStyle.font,
color: subTitleStyle.color,
text: data.subTitle,
x: options.radius,
y: options.radius subTitleStyle.margin
});
}
var drawArrow = function(valueRange){
var r = options.radius - areaStyle.radius - labelStyle.radius,
loc = calcLocation(r, valueRange.range),
x = loc.x - 1,
y = loc.y 0.5;
drawCircle({
x: x,
y: y,
r: rangeStyle.arrow.radius,
style: rangeStyle.color
});
var a = calcLocation(r - rangeStyle.arrow.height, valueRange.range),
b = calcLocation(r, valueRange.range - 0.01),
c = calcLocation(r, valueRange.range 0.01);
context.beginPath();
context.moveTo(a.x - 1, a.y 0.5);
context.lineTo(b.x - 1, b.y 0.5);
context.lineTo(c.x - 1, c.y 0.5);
context.closePath();
context.fillStyle = rangeStyle.color;
context.fill();
drawCircle({
x: x,
y: y,
r: rangeStyle.arrow.radius - rangeStyle.width,
style: '#fff'
});
}
var drawLine = function(line) {
context.beginPath();
context.moveTo(line.start.x, line.start.y);
context.lineTo(line.end.x, line.end.y);
context.closePath();
context.strokeStyle = line.style;
context.lineWidth = line.width || 1;
context.stroke();
}
var drawTickMarks = function(){
var scaleLength = areaStyle.scaleLength,
data = options.data.area,
len = scaleLength * data.length,
range = (eAngle - sAngle)/len;
for(var j = 1; j < len; j ){
drawLine({
start: calcLocation(options.radius, sAngle range * j),
end: calcLocation(options.radius - areaStyle.radius, sAngle range * j),
style: areaStyle.lineColor,
width: j % scaleLength == 0 ? areaStyle.lineWidth: areaStyle.scaleWidth
});
}
var lblArr = [];
for(var i = 0; i < data.length; i ){
var o = data[i];
// 如果不需兼容IE9以下则不用join
if(lblArr.join('').indexOf(o.min) == -1) {
lblArr.push(o.min);
}
lblArr.push(o.text);
lblArr.push(o.max);
}
var lblLen = lblArr.length - 1,
lblRange = (eAngle - sAngle)/lblLen,
lblOpt = labelStyle,
lblR = options.radius - areaStyle.radius - lblOpt.radius/2;
for(var k = 0; k <= lblLen; k ){
var loc = calcLocation(lblR, sAngle lblRange * k);
lblOpt.x = loc.x;
lblOpt.y = loc.y;
lblOpt.text = lblArr[k];
fillText(lblOpt);
}
}
var drawing = function(w, h) {
var value = options.data.value,
valueTemp = options.data.area[0].min;
var timer = setInterval(function(){
context.clearRect(0, 0, w, h);
context.fillStyle = "#fff";
context.fillRect(0, 0, w, h);
valueTemp = valueTemp 10 > value ? value: valueTemp 10;
var valueRange = calcValueRange(valueTemp);
drawArea();
drawValueRange(valueRange);
drawInnerContent(valueRange, valueTemp);
drawArrow(valueRange);
drawTickMarks();
if(valueTemp === value) {
clearInterval(timer);
}
}, 10);
}
var exports = {};
exports.setOptions = function(opts){
extend(options, opts);
styles = options.styles;
sAngle = styles.sAngle;
eAngle = styles.eAngle;
areaStyle = styles.area;
rangeStyle = styles.range;
valueStyle = styles.value;
titleStyle = styles.title;
subTitleStyle = styles.subTitle;
labelStyle = styles.label;
innerStyle = styles.inner;
element = typeof options.element == 'string' ? document.getElementById(options.element) : options.element;
context = element.getContext('2d');
return exports;
};
exports.init = function(){
drawing(element.offsetWidth, element.offsetHeight);
return exports;
}
return exports;
})();
好例子网口号:伸出你的我的手 — 分享!
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论