转自:http://goaler.xicp.net/ShowLog.asp?ID=429
演示:http://goaler.xicp.net/Demo/asp_vml_pic1.asp
方法一
<%dimtotal(7,3) total(1,0)="中国经营报" total(2,0)="招聘网" total(3,0)="51Job" total(4,0)="新民晚报" total(5,0)="新闻晚报" total(6,0)="南方周末" total(7,0)="羊城晚报" total(0,1)="#FF0000,1.5,1,2,公司1"'参数1线条的颜色,参数2线条的宽度,参数3线条的类型,参数4转折点的类型,参数5线条名称 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 total(0,2)="#0000FF,1,2,3,公司2" total(1,2)=400 total(2,2)=500 total(3,2)=1040 total(4,2)=1600 total(5,2)=522 total(6,2)=813 total(7,2)=980 total(0,3)="#004D00,1,1,3,公司3" total(1,3)=900 total(2,3)=890 total(3,3)=1240 total(4,3)=1300 total(5,3)=722 total(6,3)=833 total(7,3)=1280 %><htmlxmlns: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> <metahttp-equiv="Content-Type"content="text/html;charset=gb2312"> <title></title> <style> TD{FONT-SIZE:9pt} </style></head> <bodytopmargin=5leftmargin=0scroll=AUTO> <%calltable2(total,100,90,600,250,3)%> </body> </html> <% functiontable2(total,table_x,table_y,all_width,all_height,line_no) '参数含义(传递的数组,横坐标,纵坐标,图表的宽度,图表的高度,折线条数) '纯ASP代码生成图表函数2——折线图 '作者:龚鸣(Passwordgm)QQ:25968152MSN:[email protected]:[email protected] '本人非常愿意和ASP,VML,FLASH的爱好者在HTTP://topclouds.126.com进行交流和探讨 '版本1.0最后修改日期2003-8-11 '非常感谢您使用这个函数,请您使用和转载时保留版权信息,这是对作者工作的最好的尊重。 line_color="#69f" left_width=70 total_no=ubound(total,1) temp1=0 fori=1tototal_no forj=1toline_no iftemp1<total(i,j)thentemp1=total(i,j) next next temp1=int(temp1) iftemp1>9then temp2=mid(cstr(temp1),2,1) iftemp2>4then 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) endif else iftemp1>4thentemp3=10elsetemp3=5 endif temp4=temp3 response.write"<v:rectid='_x0000_s1027'alt=''style='position:absolute;left:"&table_x+left_width&"px;top:"&table_y&"px;width:"&all_width&"px;height:"&all_height&"px;z-index:-1'fillcolor='#9cf'stroked='f'><v:fillrotate='t'angle='-45'focus='100%'type='gradient'/></v:rect>" fori=0toall_height-1stepall_height/5 response.write"<v:lineid='_x0000_s1027'alt=''style='position:absolute;left:0;text-align:left;top:0;flip:y;z-index:-1'from='"&table_x+left_width+length&"px,"&table_y+all_height-length-i&"px'to='"&table_x+all_width+left_width&"px,"&table_y+all_height-length-i&"px'strokecolor='"&line_color&"'/>" response.write"<v:lineid='_x0000_s1027'alt=''style='position:absolute;left:0;text-align:left;top:0;flip:y;z-index:-1'from='"&table_x+(left_width-15)&"px,"&table_y+i&"px'to='"&table_x+left_width&"px,"&table_y+i&"px'/>" response.write"" response.write"<v:shapeid='_x0000_s1025'type='#_x0000_t202'alt=''style='position:absolute;left:"&table_x&"px;top:"&table_y+i&"px;width:"&left_width&"px;height:18px;z-index:1'>" response.write"<v:textboxinset='0px,0px,0px,0px'><tablecellspacing='3'cellpadding='0'width='100%'height='100%'><tr><tdalign='right'>"&temp4&"</td></tr></table></v:textbox></v:shape>" temp4=temp4-temp3/5 next response.write"<v:lineid='_x0000_s1027'alt=''style='position:absolute;left:0;text-align:left;top:0;flip:y;z-index:-1'from='"&table_x+left_width&"px,"&table_y+all_height&"px'to='"&table_x+all_width+left_width&"px,"&table_y+all_height&"px'/>" response.write"<v:lineid='_x0000_s1027'alt=''style='position:absolute;left:0;text-align:left;top:0;flip:y;z-index:-1'from='"&table_x+left_width&"px,"&table_y&"px'to='"&table_x+left_width&"px,"&table_y+all_height&"px'/>" dimline_code redimline_code(line_no,5) fori=1toline_no line_temp=split(total(0,i),",") line_code(i,1)=line_temp(0) line_code(i,2)=line_temp(1) line_code(i,3)=line_temp(2) line_code(i,4)=line_temp(3) line_code(i,5)=line_temp(4) next forj=1toline_no fori=1tototal_no-1 x1=table_x+left_width+all_width*(i-1)/total_no y1=table_y+(temp3-total(i,j))*(all_height/temp3) x2=table_x+left_width+all_width*i/total_no y2=table_y+(temp3-total(i+1,j))*(all_height/temp3) response.write"<v:lineid=""_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="""&line_code(j,1)&"""strokeweight="""&line_code(j,2)&""">" selectcaseline_code(j,3) case1 case2 response.write"<v:strokedashstyle='11'/>" case3 response.write"<v:strokedashstyle='dash'/>" case4 response.write"<v:strokedashstyle='dashDot'/>" case5 response.write"<v:strokedashstyle='longDash'/>" case6 response.write"<v:strokedashstyle='longDashDot'/>" case7 response.write"<v:strokedashstyle='longDashDotDot'/>" caseelse endselect response.write"</v:line>"&CHR(13) selectcaseline_code(j,4) case1 case2 response.write"<v:rectid=""_x0000_s1027""style='position:absolute;left:"&x1-2&"px;top:"&y1-2&"px;width:4px;height:4px;z-index:2'fillcolor="""&line_code(j,1)&"""strokecolor="""&line_code(j,1)&"""/>"&CHR(13) case3 response.write"<v:ovalid=""_x0000_s1026""style='position:absolute;left:"&x1-2&"px;top:"&y1-2&"px;width:4px;height:4px;z-index:1'fillcolor="""&line_code(j,1)&"""strokecolor="""&line_code(j,1)&"""/>"&CHR(13) endselect next selectcaseline_code(j,4) case1 case2 response.write"<v:rectid=""_x0000_s1027""style='position:absolute;left:"&x2-2&"px;top:"&y2-2&"px;width:4px;height:4px;z-index:2'fillcolor="""&line_code(j,1)&"""strokecolor="""&line_code(j,1)&"""/>"&CHR(13) case3 response.write"<v:ovalid=""_x0000_s1026""style='position:absolute;left:"&x2-2&"px;top:"&y2-2&"px;width:4px;height:4px;z-index:1'fillcolor="""&line_code(j,1)&"""strokecolor="""&line_code(j,1)&"""/>"&CHR(13) endselect next fori=1tototal_no response.write"<v:lineid='_x0000_s1027'alt=''style='position:absolute;left:0;text-align:left;top:0;flip:y;z-index:-1'from='"&table_x+left_width+all_width*(i-1)/total_no&"px,"&table_y+all_height&"px'to='"&table_x+left_width+all_width*(i-1)/total_no&"px,"&table_y+all_height+15&"px'/>" response.write"" response.write"<v:shapeid='_x0000_s1025'type='#_x0000_t202'alt=''style='position:absolute;left:"&table_x+left_width+all_width*(i-1)/total_no&"px;top:"&table_y+all_height&"px;width:"&all_width/total_no&"px;height:18px;z-index:1'>" response.write"<v:textboxinset='0px,0px,0px,0px'><tablecellspacing='3'cellpadding='0'width='100%'height='100%'><tr><tdalign='left'>"&total(i,0)&"</td></tr></table></v:textbox></v:shape>" next tb_height=30 response.write"<v:rectid='_x0000_s1025'style='position:absolute;left:"&table_x+all_width+20&"px;top:"&table_y&"px;width:100px;height:"&line_no*tb_height+20&"px;z-index:1'/>" fori=1toline_no response.write"<v:shapeid='_x0000_s1025'type='#_x0000_t202'alt=''style='position:absolute;left:"&table_x+all_width+25&"px;top:"&table_y+10+(i-1)*tb_height&"px;width:60px;height:"&tb_height&"px;z-index:1'>" response.write"<v:textboxinset='0px,0px,0px,0px'><tablecellspacing='3'cellpadding='0'width='100%'height='100%'><tr><tdalign='left'>"&line_code(i,5)&"</td></tr></table></v:textbox></v:shape>" response.write"<v:rectid='_x0000_s1040'alt=''style='position:absolute;left:"&table_x+all_width+80&"px;top:"&table_y+10+(i-1)*tb_height+4&"px;width:30px;height:20px;z-index:1'fillcolor='"&line_code(i,1)&"'><v:fillcolor2='"&line_code(i,1)&"'rotate='t'focus='100%'type='gradient'/></v:rect>" next endfunction %> |
<% Height=200'//图表高度 posX=390-Width/2'//相对浏览器的X位置 scaleX=50'//最好为Width值的倍数 countX=Cint(Width/scaleX) data="50,50|100,120|200,150|300,50|450,100"'//要输入折线的点阵(竖线分隔每个组,逗号分隔每个组中的X和Y值) TempData=Split(data,"|")
<html> <body> <html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office"> <!--总体框架--> <!--X轴刻度--> <!--Y轴刻度--> <!--画点连线--> <% For i=0 to TempDataCount %> </body> |