Web开发系列 - FusionCharts

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

去年有好几个项目需要用到图表显示, 原打算使用JFreeChart的, 但感觉其在外观展示与交互性方面都不如一些Flash Chart来得酷, 在网上搜索相关资料时候发现很多人推荐FusionCharts, 自己看了一下效果, 确实挺不错的. 也考虑过使用VML来实现统计图表的显示, 就像我在上一篇博文Web开发系列 - VML介绍VML中所说, VML仅限于IE浏览器, 最终还是决定使用FusionCharts. FusionCharts是一个基于Flash的图表组件,可以用来提供数据驱动的动态图标,FusionCharts可用于任何网页脚本语言如, HTML格式,JSP, Asp.Net, PHP技术等等。提供交互式和强大的动态图标,FusionCharts充分利用流体美丽的Flash为模板,使用XML作为其数据接口,创造紧凑,互动和真正的动态图表. 更多内容可以阅读去年我转载的一篇介绍FusionCharts文章[转载] FusionCharts的研究, 其官方主页为http://www.fusioncharts.com/,  相关例子可以访问http://www.fusioncharts.com/LiveDemos.asp.

   结合自己在JSP项目中用户操作日志统计模块的实现, 来介绍FusionCharts中常见几种图表的实现过程. 当用户点击页面上的统计按钮时, 通过JavaScript对用户输入合法性进行验证判断后提交该请求, 由后台Servlet或Action对数据库中数据按照所需条件进行检索汇总, 得到的结果集按照FusionCharts控件所需的XML格式进行响应输出, 然后通过AJAX技术获取该XML内容给FusionCharts控件使用. 特别值得一提的是, FusionCharts附带的使用文档制作得很好, 非常全面具体, 按照其提供的文档去实现图表非常方便.

首先, 我们需要准备好用到的swf与FusionCharts.js等文件, 在JSP页面头部引入所需的JS文件. 这里AJAX库采用了精简之后的prototype, 大家可以采用自己熟悉擅长的,如JQuery, ext等JS库.

<script type="text/javascript" src="Admin/ecside/js/prototype_mini.js"></script>
<script type="text/javascript" language="javascript" src="Admin/JS/FusionCharts.js"></script>

其次, 提供图表显示所需的容器如一个Div, 这里我们提供了一个ID为chart1div的div

<div id="mbDIV" style="display: none;"></div>
<div id="loginDIV" style="top: 120px;left: 150px;display: none;" class="noprint">
<div id="loginTopDIV">
<div style="float:left;">日志统计情况div>
<div style="float:right;"><a href="javascript:onhidden();">[ 关闭 ]</a></div>
</div>
<div style="padding:15px;" class="noprint">
<div id="chart1div" ></div>
</div>
</div>

最后, 需要书写提交请求以及获取XML形式结果的JavaScript脚本

复制代码
  function  onShow()
ExpandedBlockStart.gif 
{
    
var logType=$('txtLogType').value;
    
var dt1=$('dt1').value;
    
var dt2=$('dt2').value;
    
    
// Define REST web service URL 
    var url = 'CountServlet';
    
// Prepare parameters to send into REST web service
    var pars="status=logCount&txtLogType="+logType+"&dt1="+dt1+"&dt2="+dt2;

    
// Make web service AJAX request via prototype helper, 
    // upon response, call showResponse method        
ExpandedSubBlockStart.gif
    new Ajax.Request( url, { method: 'post', parameters: pars, onComplete: showResponse });
                       
    
//To pass parameters, URLEncode the dataURL. Use escape() in JavaScript 
    //var url = escape("CountServlet?status=logCount&txtLogType="+logType+"&dt1="+dt1+"&dt2="+dt2);
 }

 
  
//  Method invoked when page receives AJAX response from REST web service 
  function  showResponse(originalRequest)    
ExpandedBlockStart.gif 
{
    
var obj=document.getElementById('loginDIV');
    obj.style.top 
= "60px";
    obj.style.left 
= "200px";
    
var logType=document.getElementById('txtLogType').value;
    
var chartSWF;
    
if(logType == "-1")
ExpandedSubBlockStart.gif    
{
        chartSWF
="Admin/Charts/FCF_Column3D.swf";
    }

    
else
ExpandedSubBlockStart.gif    
{
        chartSWF
="Admin/Charts/Pie3D.swf";
    }

   
    chartSWF 
= chartSWF + "?ChartNoDataText=当前查询结果为空";
    
//Create another instance of the chart.
    var chart1 = new FusionCharts(chartSWF, "chart1Id""550""400""0""0");                   
    
var strXML = originalRequest.responseText;
    chart1.setDataXML(strXML);
    chart1.render(
"chart1div");
    show(
"loginDIV");
    show(
"mbDIV")
 }

 
复制代码

FCF_Column3D.swf

< graph  caption ="日志统计情况"  xAxisName ="日志类型"  yAxisName ="Amount"  rotateYAxisName ="0"  decimalPrecision ="0"  
formatNumberScale
="0"  baseFont ="Arial"  baseFontSize ="12" >
< set  name ="用户操作"  value ="70"  color ="AFD8F8"   />  
</ graph >  
 



Pie3D.swf

< graph   showNames = "1"   decimalPrecision = "0"   baseFont = "Arial"   baseFontSize = "12" >
< set   name = "Web客户端用户登录"   value = "10"   />  
< set   name = "Web客户端用户退出"   value = "5"   />  
< set   name = "客户端登录"   value = "12"   />  
< set   name = "客户端退出"   value = "12"   />  
< set   name = "录像回放"   value = "3"   />  
< set   name = "实时监控"   value = "28"   />  
</ graph >  


ScrollColumn2D.swf

复制代码
< chart  caption ="系统日志统计"  xAxisName ="用户"  yAxisName ="次数"  showValues ="0"  palette ="2"  shownames ="1"  legendBorderAlpha ="0"  useRoundEdges ="1"  
animation
="1"  decimalPrecision ="0"  formatNumberScale ="0"  baseFont ="Arial"  baseFontSize ="12" >
 
< categories >
  
< category  label ="管理员"   />  
  
< category  label ="FJSDXHXY"   />  
  
< category  label ="监控中心"   />  
  
< category  label ="维护人员"   />  
  
< category  label ="师大监控中心"   />  
  
</ categories >
  
< dataset  seriesName ="报警"  color ="AFD8F8"  showValues ="0" >
  
< set  value ="68"   />  
  
< set  value ="0"   />  
  
< set  value ="0"   />  
  
< set  value ="0"   />  
  
< set  value ="0"   />  
  
</ dataset >
  
< dataset  seriesName ="用户操作"  color ="8BBA00"  showValues ="0" >
  
< set  value ="4600"   />  
  
< set  value ="0"   />  
  
< set  value ="71"   />  
  
< set  value ="0"   />  
  
< set  value ="0"   />  
  
</ dataset >
</ chart >
复制代码



ScrollLine2D.swf
ContractedBlock.gif ScrollLine2D.swf



园友们相关文章

FusionCharts等产品简介

 

FusionCharts Free 图表库

FusionCharts 的XML标签属性

FusionCharts 组件 全Flash图表

蜡人张 FusionCharts Free


FusionCharts Free(1)

FusionCharts Free(2)

FusionCharts Free(3)

野路子实现的轻量级伪OLAP展示


另外附上C# WinForm开发系列相关文章如下: 

C# WinForm开发系列 - GDI+

C# WinForm开发系列 - ZedGraph

C# WinForm开发系列 - OWC

C# WinForm开发系列 - Chart Controls

C# WinForm开发系列 - Report

C# WinForm开发系列 - Print

C# WinForm开发系列 - 文章索引

Web开发系列 - VML


本文转自peterzb博客园博客,原文链接:http://www.cnblogs.com/peterzb/archive/2009/07/25/1531087.html,如需转载请自行联系原作者。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
6天前
|
数据库 开发者 Python
web应用开发
【9月更文挑战第1天】web应用开发
20 1
|
3天前
|
数据采集 Java 数据挖掘
Java IO异常处理:在Web爬虫开发中的实践
Java IO异常处理:在Web爬虫开发中的实践
|
5天前
|
前端开发 JavaScript 持续交付
Web应用开发的方法
Web应用开发的方法
7 1
|
5天前
|
前端开发 JavaScript 持续交付
web应用开发
web应用开发
10 1
|
6天前
|
Web App开发 数据采集 iOS开发
「Python+Dash快速web应用开发」
这是「Python+Dash快速web应用开发」系列教程的第十六期,本期将介绍如何在Dash应用中实现多页面路由功能。通过使用`Location()`组件监听URL变化,并结合回调函数动态渲染不同页面内容,使应用更加模块化和易用。教程包括基础用法、页面重定向及无缝跳转等技巧,并通过实例演示如何构建个人博客网站。
18 2
WK
|
4天前
|
数据采集 API 开发者
很少有人用python开发web???
Python 是一种流行且广泛使用的编程语言,尤其在 Web 开发领域。它凭借简洁的语法、丰富的框架(如 Django 和 Flask)、强大的库支持及活跃的社区,成为许多开发者和企业的首选。Python 的易学性、高效性及广泛的应用场景(包括 Web API、微服务和数据分析等)使其在 Web 开发中占据重要地位,并将持续发挥更大作用。
WK
14 0
|
7天前
|
数据库 开发者 Java
数据战争:Hibernate的乐观与悲观锁之争,谁将主宰并发控制的王座?
【8月更文挑战第31天】在软件开发中,数据一致性至关重要,尤其是在多用户并发访问环境下。Hibernate 作为 Java 社区常用的 ORM 框架,提供了乐观锁和悲观锁机制来处理并发问题。乐观锁假设数据不易冲突,通过版本号字段 (`@Version`) 实现;悲观锁则假定数据易冲突,在读取时即加锁。选择哪种锁取决于具体场景:乐观锁适合读多写少的情况,减少锁开销;悲观锁适合写操作频繁的场景,避免数据冲突。正确应用这些机制可提升应用程序的健壮性和效率。
17 0
|
7天前
|
Java 测试技术 容器
从零到英雄:Struts 2 最佳实践——你的Web应用开发超级变身指南!
【8月更文挑战第31天】《Struts 2 最佳实践:从设计到部署的全流程指南》深入介绍如何利用 Struts 2 框架从项目设计到部署的全流程。从初始化配置到采用 MVC 设计模式,再到性能优化与测试,本书详细讲解了如何构建高效、稳定的 Web 应用。通过最佳实践和代码示例,帮助读者掌握 Struts 2 的核心功能,并确保应用的安全性和可维护性。无论是在项目初期还是后期运维,本书都是不可或缺的参考指南。
15 0
|
7天前
|
前端开发 开发者 安全
JSF面向对象设计,让你轻松应对复杂业务需求,Web应用开发不再难!
【8月更文挑战第31天】在现代Web应用开发中,JSF(JavaServer Faces)框架凭借其强大的面向对象编程能力广泛应用于数据绑定和事件处理。数据绑定机制使前端与后端模型解耦,提高代码维护性和类型安全性;事件处理机制则增强了应用灵活性并进一步降低耦合度。本文通过示例代码展示了JSF的这些特性及其优势,帮助开发者更好地利用JSF构建高效、灵活的Web应用。然而,JSF也存在组件库较小和学习成本较高的局限,需根据具体需求权衡使用。
17 0
|
7天前
|
开发者 iOS开发 C#
Uno Platform 入门超详细指南:从零开始教你打造兼容 Web、Windows、iOS 和 Android 的跨平台应用,轻松掌握 XAML 与 C# 开发技巧,快速上手示例代码助你迈出第一步
【8月更文挑战第31天】Uno Platform 是一个基于 Microsoft .NET 的开源框架,支持使用 C# 和 XAML 构建跨平台应用,适用于 Web(WebAssembly)、Windows、Linux、macOS、iOS 和 Android。它允许开发者共享几乎全部的业务逻辑和 UI 代码,同时保持原生性能。选择 Uno Platform 可以统一开发体验,减少代码重复,降低开发成本。安装时需先配置好 Visual Studio 或 Visual Studio for Mac,并通过 NuGet 或官网下载工具包。
13 0
下一篇
DDNS