純ASP代碼組建圖表餅圖

來源:互聯網
上載者:User

<%dim total(7,1) 
total(1,0)="啟迪論壇" 
total(2,0)="招聘網" 
total(3,0)="51Job" 
total(4,0)="新民晚報" 
total(5,0)="新聞晚報" 
total(6,0)="南方周末" 
total(7,0)="羊城晚報" 

total(1,1)=200 
total(2,1)=1200 
total(3,1)=900 
total(4,1)=600 
total(5,1)=1222 
total(6,1)=413 
total(7,1)=800 

%><html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office"> 
<!--[if !mso]> 
<style> 
v\:* { behavior: url(#default#VML) } 
o\:* { behavior: url(#default#VML) } 
.shape { behavior: url(#default#VML) } 
</style> 
<![endif]--> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title></title> 
<style> 
TD { FONT-SIZE: 9pt} 
</style></head> 
<body topmargin=5 leftmargin=0 scroll=AUTO> 
範例一 
<%call table3(total,100,40,250,250,"A")%> 
<Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br><Br>範例二 
<%call table3(total,300,450,250,250,"B")%> 
</body> 
</html> 

<% 
function table3(total,table_x,table_y,all_width,all_height,table_type) 
'參數含義(傳遞的數組,橫座標,縱座標,圖表的寬度,圖表的高度,圖表的類型) 
'純ASP代碼組建圖表函數3——餅圖 
'非常感謝您使用這個函數,請您使用和轉載時保留著作權資訊,這是對作者工作的最好的尊重。 
tb_height=30 

dim tb_color(7,2) 
tb_color(1,1)="#d1ffd1" 
tb_color(2,1)="#ffbbbb" 
tb_color(3,1)="#ffe3bb" 
tb_color(4,1)="#cff4f3" 
tb_color(5,1)="#d9d9e5" 
tb_color(6,1)="#ffc7ab" 
tb_color(7,1)="#ecffb7" 

tb_color(1,2)="#00ff00" 
tb_color(2,2)="#ff0000" 
tb_color(3,2)="#ff9900" 
tb_color(4,2)="#33cccc" 
tb_color(5,2)="#666699" 
tb_color(6,2)="#993300" 
tb_color(7,2)="#99cc00" 

total_no=ubound(total,1) 
totalpie=0 
for i=1 to total_no 
totalpie=totalpie+total(i,1) 
next 

PreAngle=0 
for i=1 to total_no 
response.write "<v:shape id='_x0000_s1025' alt='' style='position:absolute;left:"&table_x&"px;top:"&table_y&"px;width:"&all_width&"px;height:"&all_height&"px;z-index:1' coordsize='1500,1400' o:spt='100' adj='0,,0' path='m750,700ae750,700,750,700,"&int(23592960*PreAngle)&","&int(23592960*total(i,1)/totalpie)&"xe' fillcolor='"&tb_color(i,1)&"' strokecolor='#FFFFFF'><v:fill color2='"&tb_color(i,2)&"' rotate='t' focus='100%' type='gradient'/><v:stroke joinstyle='round'/><v:formulas/><v:path o:connecttype='segments'/></v:shape>"&CHr(13) 
PreAngle=PreAngle+total(i,1)/totalpie 
next 

if table_type="A" then 
response.write "<v:rect id='_x0000_s1025' style='position:absolute;left:"&table_x+all_width+20&"px;top:"&table_y+20&"px;width:100px;height:"&total_no*tb_height+20&"px;z-index:1'/>" 
for i=1 to total_no 
response.write "<v:shape id='_x0000_s1025' type='#_x0000_t202' alt='' style='position:absolute;left:"&table_x+all_width+25&"px;top:"&table_y+30+(i-1)*tb_height&"px;width:60px;height:"&tb_height&"px;z-index:1'>" 
response.write "<v:textbox inset='0px,0px,0px,0px'><table cellspacing='3' cellpadding='0' width='100%' height='100%'><tr><td align='left'>"&total(i,0)&"</td></tr></table></v:textbox></v:shape>" 
response.write "<v:rect id='_x0000_s1040' alt='' style='position:absolute;left:"&table_x+all_width+80&"px;top:"&table_y+30+(i-1)*tb_height+3&"px;width:30px;height:20px;z-index:1' fillcolor='"&tb_color(i,1)&"'><v:fill color2='"&tb_color(i,2)&"' rotate='t' focus='100%' type='gradient'/></v:rect>" 
'顯示比例數 
' response.write "<v:shape id='_x0000_s1025' type='#_x0000_t202' alt='' style='position:absolute;left:"&table_x+all_width+110&"px;top:"&table_y+30+(i-1)*tb_height&"px;width:60px;height:"&tb_height&"px;z-index:1'>" 
' response.write "<v:textbox inset='0px,0px,0px,0px'><table cellspacing='3' cellpadding='0' width='100%' height='100%'><tr><td align='left'>"&formatnumber(total(i,1)*100/totalpie,2,-1)&"%</td></tr></table></v:textbox></v:shape>" 
next 
end if 

if table_type="B" then 
pie=3.14159265358979 
TempPie=0 
for i=1 to total_no 
TempAngle=pie*2*(total(i,1)/(TotalPie*2)+TempPie) 
x1=table_x+all_width/2+cos(TempAngle)*all_width*3/8 
y1=table_y+all_height/2-sin(TempAngle)*all_height*3/8 
x2=table_x+all_width/2+cos(TempAngle)*all_width*3/4 
y2=table_y+all_height/2-sin(TempAngle)*all_height*3/4 
if x2>table_x+all_width/2 then 
x3=x2+20 
x4=x3 
else 
x3=x2-20 
x4=x3-100 
end if 
response.write "<v:oval id='_x0000_s1027' style='position:absolute;left:"&x1-2&"px;top:"&y1-2&"px;width:4px;height:4px; z-index:2' fillcolor='#111111' strokecolor='#111111'/>"&CHR(13) 
response.write "<v:line id='_x0000_s1025' alt='' style='position:absolute;left:0;text-align:left;top:0;z-index:1' from='"&x1&"px,"&y1&"px' to='"&x2&"px,"&y2&"px' coordsize='21600,21600' strokecolor='#111111' strokeweight='1px'></v:line>" 
response.write "<v:line id='_x0000_s1025' alt='' style='position:absolute;left:0;text-align:left;top:0;z-index:1' from='"&x2&"px,"&y2&"px' to='"&x3&"px,"&y2&"px' coordsize='21600,21600' strokecolor='#111111' strokeweight='1px'></v:line>" 
response.write "<v:shape id='_x0000_s1025' type='#_x0000_t202' alt='' style='position:absolute;left:"&x4&"px;top:"&y2-10&"px;width:100px;height:20px;z-index:1'>" 
response.write "<v:textbox inset='0px,0px,0px,0px'><table cellspacing='3' cellpadding='0' width='100%' height='100%'><tr><td align='left'>"&total(i,0)&" "&formatnumber(total(i,1)*100/totalpie,2,-1)&"%</td></tr></table></v:textbox></v:shape>" 
TempPie=TempPie+total(i,1)/TotalPie 
next 
end if 

end function 
%>

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.