gpt4 book ai didi

javascript - 径向图上的拉斐尔夏娃动画

转载 作者:行者123 更新时间:2023-11-29 20:01:57 25 4
gpt4 key购买 nike

谁能看看这个,看看为什么第一个图表的计数不起作用。

$(document).ready(function() {

display_chart(54,'overall');
display_chart(55,'test');

});


function display_chart(amount,div){

var paper = Raphael(document.getElementById(div), 500, 500);
paper.customAttributes.arc = function(xloc, yloc, value, total, R) {
var alpha = 360 / total * value,
a = (90 - alpha) * Math.PI / 180,
x = xloc + R * Math.cos(a),
y = yloc - R * Math.sin(a),
path;
if (total == value) {
path = [
["M", xloc, yloc - R],
["A", R, R, 0, 1, 1, xloc - 0.01, yloc - R]
];
} else {
path = [
["M", xloc, yloc - R],
["A", R, R, 0, +(alpha > 180), 1, x, y]
];
}
return {
path: path
};
};

var backCircle = paper.circle(150, 100, 70).attr({
"stroke": "#d0e8cf",
"stroke-width": 25
});

var theArc = paper.path().attr({
"stroke": "#66cc66",
"stroke-width": 25,
arc: [50, 100, 0, 100, 70]
});


//event fired on each animation frame
eve.on("raphael.anim.frame.*", onAnimate);

//text in the middle
theText = paper.text(150, 100, "0%").attr({
"font-size": 36,
"font-face" : "Droid Sans",
"fill": "#666666",
"font-weight": "bold"
});

//the animated arc
theArc.rotate(180, 100, 100).animate({
arc: [50, 100, amount, 100, 70]
}, 1900, function() {
//when the animation is done unbind
eve.unbind("raphael.anim.frame.*", onAnimate);
});

function onAnimate() {
var howMuch = theArc.attr("arc");
theText.attr("text", Math.floor(howMuch[2]) + "%");
}

}

http://jsfiddle.net/pVcSb/

最佳答案

您需要使用“var”关键字声明您的变量“theText”

var theText = ...

使用“use strict”来避免这种错误

http://jsfiddle.net/pVcSb/1/

关于javascript - 径向图上的拉斐尔夏娃动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13935534/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com