代碼以下css
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
#hhn {
width: 500px;
height: 500px;
position: relative;
background: rgba(0,0,0,0.5);
}
</style>
</head>
<body>
<div id="hhn"></div>
</body>
<script src="../libs/d3.js"></script>
<script src="../libs/jquery.js"></script>
<script>
var chartCon = $('#hhn');html
var domInfo = [{
id : 'circle1',
value : 32,
left : '5%',
top : '5%',
text : '通訊'
},{
id : 'circle2',
value : 68,
left : '35%',
top : '5%',
color : 'rgba(199, 164, 14, 0.5)',
text : '物流'
},{
id : 'circle3',
value : 32,
left : '65%',
top : '5%',
text : '半導體'
},{
id : 'circle4',
value : 32,
left : '5%',
top : '53%',
text : '智能製造'
},{
id : 'circle5',
value : 68,
left : '35%',
top : '53%',
color : 'rgba(199, 164, 14, 0.5)',
text : '網絡信息'
},{
id : 'circle6',
value : 32,
left : '65%',
top : '53%',
text : '其餘'
}];jquery
var dom;
$(domInfo).each(function(i,v){
chartCon.append('<div id='+v.id+' style="position:absolute;left:'+v.left+';top:'+v.top+';width:150px;height:150px;"></div>');
dom = document.getElementById(v.id);
$('<span>').css({
position: 'absolute',
width: '100%',
height: '20%',
textAlign:'center',
color: '#bbbcc0',
fontSize: 20,
top: '105%'
}).text(v.text).appendTo($(dom));
buildCircle(dom,v.value,v.color,v.id);
});
function buildCircle(el, value, vColor,vId) {數組
if (!d3.arc) d3.arc = d3.svg.arc;
if (!d3.pie) d3.pie = d3.layout.pie;網絡
var svg = d3.select(el).append('svg')//給每一個div添加svg元素
.attr('width', '100%')
.attr('height', '100%')
.attr('viewBox', '0 0 100 100');app
var defs = svg.append('defs');dom
var id = 'color_' + Math.random();
var linear = defs.append('linearGradient')
.attr('x1', 0)
.attr('y1', 0)
.attr('x2', 0)
.attr('y2', 1)
.attr('id', id);xss
linear.append('stop')
.attr('stop-color', vColor || 'rgba(2,135,188,0.5)')
.attr('offset', 0);svg
linear.append('stop')
.attr('stop-color', vColor || 'rgba(2,135,188,0.5)')
.attr('offset', 1);ui
var imgSrc = '';
svg.append('image')
.attr('width', 100)
.attr('height', 100)
.attr('x', 0)
.attr('y', 0)
.attr('xlink:href', imgSrc);
var data = [value, 100 - value];//圓環的數據
var pie = d3.pie()
.startAngle(0)
.sort(function(d, i) {
return d == value ? 1 : -1;
})
.endAngle(-Math.PI * 2);
var arcData = pie(data);//生成圓環數據的數組對象
var arc = d3.arc()
.innerRadius(39)
.outerRadius(50);
//.cornerRadius(6);
var group = svg.append('g')
.attr('transform', 'translate(50, 50)');
group.selectAll('path')
.data([arcData[0]])
.enter()
.append('path')
.attr('class','path' + vId)
.style('fill', 'rgba(0,0,0,0)')
.attr('d', arc);
var i = 0;
function move(){
if(i < 100){
requestAnimationFrame(move);
}else {
return;
}
$('.path' + vId).remove();//每次生成的時候要先刪除原來的元素
i+=1;
data = [value * i / 100, 100 - value * i / 100];
pie = d3.pie()
.startAngle(0)
.sort(function(d, k) {
return d == value * i / 100 ? 1 : -1;
})
.endAngle(-Math.PI * 2);
arcData = pie(data);
group.selectAll('path')
.data([arcData[0]])
.enter()
.append('path')
.attr('class','path' + vId)
.style('fill', 'url(#' + id + ')')
.attr('d', arc);
text.text(value * i / 100 + '%')
}
var text = group.append('text') .text(value + '%') .attr('class','cirtext') .attr('x', '0') .attr('y', '0') .attr('text-anchor', 'middle') .attr('dy', '0.5em') .style('fill', '#ffffff') .style('cursor', 'pointer') .style('font-size', 27); move(); $('.cirtext').hover(function(){ $(this).css('transform','scale(1.2)') },function(){ $(this).css('transform','scale(1)') }); }</script></html>