用纯ASP实现完美的WEB柱状图
类别: ASP教程
<%
dim total(7,2)
total(1,1)=200
total(2,1)=800
total(3,1)=1000
total(4,1)=600
total(5,1)=1222
total(6,1)=3213
total(7,1)=8
total(1,2)="中国经营报"
total(2,2)="招聘网"
total(3,2)="51Job"
total(4,2)="新民晚报"
total(5,2)="新闻晚报"
total(6,2)="南方周末"
total(7,2)="羊城晚报"
total_no=7
%>
<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>
<link rel="stylesheet" href="List.css"></head>
<body topmargin=5 leftmargin=0 scroll=no>
<%call table1(total,20,15,470,200)%>
</body>
</html>
以上是调用函数的例子,下面是所调用的函数
<%
function table1(total,thickness,table_space,all_width,all_height)
\'参数含义(传递的数组,柱子的厚度,柱子的间隔,图表的宽度,图表的高度)
\'纯ASP代码生成图表函数1――柱状图
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"
response.write "<table border=0 cellpadding=0 cellspacing=0 style=border-collapse: collapse bordercolor=#111111 width="&all_width&" height="&all_height&">"
response.write "<tr><td width=100% height=* valign=middle><table border=0 cellpadding=0 cellspacing=0 style=border-collapse: collapse bordercolor=\'#111111\' width=\'100%\' height=\'100%\'>"
response.write "<tr align=\'center\'><td width=\'35\' height=\'100%\' valign=\'bottom\'>"
response.write "<table border=\'0\' cellpadding=\'0\' cellspacing=\'0\' style=\'border-collapse: collapse\' bordercolor=\'#111111\' width=\'100%\' height=\'100%\'>"
temp1=0
for i=1 to total_no
if temp1<total(i,1) then temp1=total(i,1)
next
temp1=int(temp1)
if temp1>9 then
temp2=mid(cstr(temp1),2,1)
if temp2>4 then
temp3=(int(temp1/(10^(len(cstr(temp1))-1)))+1)*10^(len(cstr(temp1))-1)
else
temp3=(int(temp1/(10^(len(cstr(temp1))-1)))+0.5)*10^(len(cstr(temp1))-1)
end if
else
if temp1>4 then temp3=10 else temp3=5
end if
if total_no>0 then
for i=temp3 to 1 step -temp3/5
response.write "<tr style=\'font-size:1px;height:1px\'><td></td><td bgcolor=\'#111111\' width=\'20%\'></td></tr>"
response.write "<tr align=right valign=\'top\'><td colspan=\'2\'>"&i&"</td></tr>"
next
response.write "</table>"
response.write "</td><td style=\'font-size:1px;height:1px\' bgcolor=\'#111111\'>1</td><td width=\'"&(all_width-30)&"\' height=\'"&(all_height-30)&"\' valign=\'bottom\' align=\'left\'>"
response.write "<!--[if gte vml 1]>"
z=9
width=30
total_width=280
width=(total_width-total_no*z*2)/(total_no)
m=0
if width>30 then width=30
m=m+1
for i=1 to total_no
response.write "<v:rect id=\'_x0000_s1025\' alt=\'\' style=\'position:relative;left:"
response.write table_space/2+table_space*(i-1)
response.write "pt;top:2px;width:"&width&"pt;height:"&(all_height/1.41)*total(i,1)/temp3&"pt;z-index:1\' fillcolor=\'"&tb_color(i,2)&"\'>"
response.write "<v:fill color2=\'"&tb_color(i,1)&"\' rotate=\'t\' type=\'gradient\'/>"
response.write "<o:extrusion v:ext=\'view\' backdepth=\'"&thickness&"pt\' color=\'"&tb_color(i,2)&"\' on=\'t\'/>"
response.write "<v:textbox inset=\'0,0,0,0\'>"
response.write "<table cellspacing=0 cellpadding=0 width=\'100%\' height=\'100%\'>"
response.write "<tr><td align=\'center\'"
if (all_height/1.41)*total(i,1)/temp3<8 then response.write " style=\'font-size:1px;\'"
response.write ">"&total(i,1)&"</td></tr>"
response.write "</table></v:textbox></v:rect>"
next
response.write "<![endif]--></td></tr>"
response.write "<tr align=\'center\'><td></td><td style=\'font-size:1px;height:1px\' bgcolor=\'#111111\'></td><td style=\'font-size:1px;height:1px\' bgcolor=\'#111111\'></td></td>"
response.write "<tr align=\'center\'><td></td><td></td><td width=\'\' height=\'*\' valign=\'middle\'>"
response.write "<table border=\'0\' cellpadding=\'0\' cellspacing=\'0\' style=\'border-collapse: collapse\' bordercolor=\'#111111\' width=\'100%\' height=\'30\'>"
response.write "<tr align=center valign=\'center\'>"
for i=1 to total_no
response.write "<td width=\'"&(100/total_no)&"%\'>"&total(i,2)&"</td>"
next
else
response.write ""
end if
response.write "</tr></table></td></tr></table></td></tr></table>"
end function
%>
dim total(7,2)
total(1,1)=200
total(2,1)=800
total(3,1)=1000
total(4,1)=600
total(5,1)=1222
total(6,1)=3213
total(7,1)=8
total(1,2)="中国经营报"
total(2,2)="招聘网"
total(3,2)="51Job"
total(4,2)="新民晚报"
total(5,2)="新闻晚报"
total(6,2)="南方周末"
total(7,2)="羊城晚报"
total_no=7
%>
<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>
<link rel="stylesheet" href="List.css"></head>
<body topmargin=5 leftmargin=0 scroll=no>
<%call table1(total,20,15,470,200)%>
</body>
</html>
以上是调用函数的例子,下面是所调用的函数
<%
function table1(total,thickness,table_space,all_width,all_height)
\'参数含义(传递的数组,柱子的厚度,柱子的间隔,图表的宽度,图表的高度)
\'纯ASP代码生成图表函数1――柱状图
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"
response.write "<table border=0 cellpadding=0 cellspacing=0 style=border-collapse: collapse bordercolor=#111111 width="&all_width&" height="&all_height&">"
response.write "<tr><td width=100% height=* valign=middle><table border=0 cellpadding=0 cellspacing=0 style=border-collapse: collapse bordercolor=\'#111111\' width=\'100%\' height=\'100%\'>"
response.write "<tr align=\'center\'><td width=\'35\' height=\'100%\' valign=\'bottom\'>"
response.write "<table border=\'0\' cellpadding=\'0\' cellspacing=\'0\' style=\'border-collapse: collapse\' bordercolor=\'#111111\' width=\'100%\' height=\'100%\'>"
temp1=0
for i=1 to total_no
if temp1<total(i,1) then temp1=total(i,1)
next
temp1=int(temp1)
if temp1>9 then
temp2=mid(cstr(temp1),2,1)
if temp2>4 then
temp3=(int(temp1/(10^(len(cstr(temp1))-1)))+1)*10^(len(cstr(temp1))-1)
else
temp3=(int(temp1/(10^(len(cstr(temp1))-1)))+0.5)*10^(len(cstr(temp1))-1)
end if
else
if temp1>4 then temp3=10 else temp3=5
end if
if total_no>0 then
for i=temp3 to 1 step -temp3/5
response.write "<tr style=\'font-size:1px;height:1px\'><td></td><td bgcolor=\'#111111\' width=\'20%\'></td></tr>"
response.write "<tr align=right valign=\'top\'><td colspan=\'2\'>"&i&"</td></tr>"
next
response.write "</table>"
response.write "</td><td style=\'font-size:1px;height:1px\' bgcolor=\'#111111\'>1</td><td width=\'"&(all_width-30)&"\' height=\'"&(all_height-30)&"\' valign=\'bottom\' align=\'left\'>"
response.write "<!--[if gte vml 1]>"
z=9
width=30
total_width=280
width=(total_width-total_no*z*2)/(total_no)
m=0
if width>30 then width=30
m=m+1
for i=1 to total_no
response.write "<v:rect id=\'_x0000_s1025\' alt=\'\' style=\'position:relative;left:"
response.write table_space/2+table_space*(i-1)
response.write "pt;top:2px;width:"&width&"pt;height:"&(all_height/1.41)*total(i,1)/temp3&"pt;z-index:1\' fillcolor=\'"&tb_color(i,2)&"\'>"
response.write "<v:fill color2=\'"&tb_color(i,1)&"\' rotate=\'t\' type=\'gradient\'/>"
response.write "<o:extrusion v:ext=\'view\' backdepth=\'"&thickness&"pt\' color=\'"&tb_color(i,2)&"\' on=\'t\'/>"
response.write "<v:textbox inset=\'0,0,0,0\'>"
response.write "<table cellspacing=0 cellpadding=0 width=\'100%\' height=\'100%\'>"
response.write "<tr><td align=\'center\'"
if (all_height/1.41)*total(i,1)/temp3<8 then response.write " style=\'font-size:1px;\'"
response.write ">"&total(i,1)&"</td></tr>"
response.write "</table></v:textbox></v:rect>"
next
response.write "<![endif]--></td></tr>"
response.write "<tr align=\'center\'><td></td><td style=\'font-size:1px;height:1px\' bgcolor=\'#111111\'></td><td style=\'font-size:1px;height:1px\' bgcolor=\'#111111\'></td></td>"
response.write "<tr align=\'center\'><td></td><td></td><td width=\'\' height=\'*\' valign=\'middle\'>"
response.write "<table border=\'0\' cellpadding=\'0\' cellspacing=\'0\' style=\'border-collapse: collapse\' bordercolor=\'#111111\' width=\'100%\' height=\'30\'>"
response.write "<tr align=center valign=\'center\'>"
for i=1 to total_no
response.write "<td width=\'"&(100/total_no)&"%\'>"&total(i,2)&"</td>"
next
else
response.write ""
end if
response.write "</tr></table></td></tr></table></td></tr></table>"
end function
%>
- 上一篇: 文章系统中“上篇、下篇”效果的制作
- 下一篇: 在ASP中操作数据库的方法
-= 资 源 教 程 =-
文 章 搜 索