ASP.NET中实现可动态更新Flash统计图

开发 后端
使用AjaxControlToolkit的UpdatePanelAnimation实现UpdatePanel的显示效果,使用jQuery实现div的滑动效果,使用flash统计图(饼状图、柱状图....),这其中最麻烦的就是用Flash了,本文将介绍ASP.NET中实现可动态更新Flash统计图。

怎么在自己的ASP.NET页面插入可动态更新Flash统计图呢?网上的资源倒是不少(Fusioncharts、amCharts……),
但我觉得效果最炫的还是amcharts的统计图,还可以与用户交互

可动态更新Flash统计图效果图:

(柱状图)


(饼状图)

(股票图)


(怎么样?效果够炫吧?赶紧去官网体验一下吧,会比你想象的用起来还要好~还可以自己设置很多的效果)

amcharts官网上各种各样的都可以下载,而且可以免费使用,唯一不足的就是免费版会显示它公司的链接,不过这是可以破解的,

下载amcharts_key.txt放到flash的相同目录下即可。

我所使用的flash是两个不同的版本,一个是直接在官网下载的柱状图、另一个不知道的哪下的饼状图,不过也是amcharts的,但貌似是经过破解的,只有一个xml文件(一般来说都应该有两个,一个主要设置内容,一个主要设置外观)如下图:

     
准备工作:统计图的swf文件、相关的xml数据文件、swfobject1.5(现在2.x都有了,不过感觉1.5用着舒服些)
先说说从官网下载下来的使用方法吧。直接以代码呈现:(关于swfobject请查看官方文档)

  1.  <script type="text/javascript" src="js/swfobject.js"></script> 
  2.  <div id="flashcontent"> 
  3.      <strong>You need to upgrade your Flash Player</strong> 
  4.  </div> 
  5.  <script type="text/javascript"> 
  6.  // <![CDATA[  
  7.      var rand = Rand();  
  8.      var so = new SWFObject("amcolumn.swf", "column", "360", "300", "8", "#FFFFFF");  
  9.      so.addVariable("settings_file", encodeURIComponent("amcolumn_settings.xml?"+Math.random()));  
  10.     so.addVariable("data_file", encodeURIComponent("amcolumn_data.xml?"+Math.random()));  
  11.     so.write("flashcontent");  
  12. // ]]> 
  13. </script> 

首先引用swfobject.js,不然编译器会罢工的噢~ : )

然后就是一个div,也可以是span,里面有一句"You need to upgrade your Flash Player”,你肯定猜得到在flash未加
载时就会显示这句话,这是为什么呢?(破有小沈阳的味道)请继续往下看,SWFObject(注意大小写哦)里的***句就引用了想要加载的flash路径,然后下面两句关联上xml文件,如果要动态改变flash的话就必须在xml后加上一个随机变量,否则flash只会在你重新运行或者清空缓存之后改变,***一个so.write就是用flash替换掉div中的内容。

下面是改变内容的代码:(因为完全不熟悉xml,自己瞎琢磨出的一个方法,仅作参考)

  1. using System.Xml;  
  2. XmlDocument doc = new XmlDocument();  
  3. doc.Load(Server.MapPath("amcolumn_data.xml"));   
  4. XmlNodeList nodelist = doc.GetElementsByTagName("value"); //获取所有标签名为value的节点  
  5. nodelist.Item(4).InnerText = "4000";  //设置想要修改的节点的串联值  
  6. doc.Save(Server.MapPath("amcolumn_data.xml")); //保存到xml 

好了,这样就大功告成了~

然后再说说我的另外一个flash的用法吧,这个就麻烦多了,中外的网站都给翻遍了(有点夸张,不过我确实是从晚上11点直到早上5点半才把它给解决),开始说了,这个flash只有一个xml如果用前面的方法想要实现动态的话是不可能的,因为这个flash是从内部读取xml的,在外面怎么改都不能动态显示,我***还想通过禁用缓存的方法来解决,但也是不可能的,我甚至想了一个更绝的办法:直接拿修改后的xml去覆盖windows临时文件夹的xml。

但还是行不通,***实在不行了就只能把flash给反编译了,不过幸好flash的代码不那么麻烦,没找多久久找到了那个载入的函数

  1. function load(url)  
  2. {  
  3.       xml.load(url);  

然后我直接在url后加上了随机变量

  1. function load(url)  
  2. {  
  3.       xml.load(url+“?"+Math.random());  

这样ASP.NET中实现可动态更新Flash统计图就OK了

本文来自Darryn博客园文章《在ASP.NET中使用可动态更新的flash统计图

【编辑推荐】

  1. ASP.NET控件学习总结
  2. 有关ASP.NET MVC框架的一些基础知识
  3. 再谈ASP.NET缓存机制:开发效率与优化的平衡
  4. 如何避免ASP.NET缓存占用系统资源
  5. 点评一下ASP.NET的WEB控件
责任编辑:彭凡 来源: 博客园
相关推荐

2009-07-28 10:01:16

ASP.NET Exc

2009-08-04 18:05:37

动态编译ASP.NET

2009-07-29 13:43:52

UpdatePanelASP.NET

2009-08-02 11:48:58

ASP.NET水晶报表ASP.NET

2009-07-28 15:29:03

实现HTTP请求ASP.NET

2009-07-21 15:40:59

Asp.Net动态页面

2009-08-04 18:10:35

ASP.NET动态编译

2009-08-04 15:58:06

ASP.NET动态控件

2009-04-01 12:00:43

ASP.NETMVC

2009-07-28 13:48:28

ASP.NET树形图

2010-12-29 09:02:30

动态构建语句ASP.NET

2009-07-22 17:45:35

ASP.NET教程

2009-01-04 13:27:10

URL RewriteIISASP.NET

2009-07-30 15:50:49

ASP.NET中网站访

2009-07-27 15:25:40

aspx页面ASP.NET

2009-07-27 09:31:06

定义JavaScripASP.NET

2009-07-28 17:17:19

ASP.NET概述

2009-08-03 14:22:33

什么是ASP.NET

2009-07-24 10:10:22

ASP.NET

2009-07-24 16:17:42

WebRequestEASP.NET
点赞
收藏

51CTO技术栈公众号