- 浏览: 516849 次
- 性别:
- 来自: 宁波
-
文章分类
- 全部博客 (137)
- JQuery component (3)
- Web编程控件 (7)
- java (19)
- database (9)
- Web Service (6)
- XML (2)
- FTP (2)
- SSH2 (18)
- javascript (3)
- arcgis (7)
- geoserver (1)
- Openscales (2)
- FME (6)
- HttpClient (3)
- portal (6)
- oracle goldengate (7)
- oracle (3)
- 命令锦集 (1)
- web容器 (3)
- NB博客链接 (2)
- 设计模式 (0)
- ext (2)
- 小工具 (12)
- Flex (1)
- LINUX (1)
- Android (1)
- Maven 入门 (2)
- 负载均衡 (1)
- openlayers (2)
- Flexkkjk (0)
最新评论
-
lgh1992314:
ApplicationContext context = We ...
Spring中的ContextLoaderListener使用 -
lgh1992314:
ContextLoaderServletSpring3.0后删 ...
Spring中的ContextLoaderListener使用 -
gaoqiangjava:
...
Spring中的ContextLoaderListener使用 -
liude33:
好资料啊,网上这方面的资料好少。
goldengate 学习资料 -
AKka:
在实体类中加上@Transient 注解后,为什么还会在数据库 ...
JPA注解 转
fusioncharts是一个基于Flash的图表组件,可以用来提供数据驱动的动态图标,fusioncharts可用于任何网页脚本语言如, HTML格式,JSP技术等等。提供交互式和强大的动态图标,fusioncharts充分利用流体美丽的Flash为模板,使用XML作为其数据接口,创造紧凑,互动和真正的动态图表
现结合 jquery 封装成组件,方便调用。
该组件包括
jquery-1.3.2.min.js; (jquery核心类库)
jquery.flash.js: (flash 类)
flashdemo.js (js与html 分离)
flashdemo.html
swf 文件(Column3D.swf、Line.swf、Pie3D.swf)
运行效果图:
具体实现如下:
jquery.flash.js
注意点:swf文件路径的配置353行
$.extend({ /*参数说明 dataSource : url请求(返回json对象) charttype: 图表类型 柱状、饼图、折线等 containerDiv: 装载flash容器的div params: 参数数组设置图表的横纵名称等 */ loadCharts:function(dataSource,charttype,containerDiv,params) { // 加载fusioncharts 对象 if(typeof infosoftglobal == "undefined") var infosoftglobal = new Object(); if(typeof infosoftglobal.FusionChartsUtil == "undefined") infosoftglobal.FusionChartsUtil = new Object(); infosoftglobal.FusionCharts = function(swf, id, w, h, debugMode, registerWithJS, c, scaleMode, lang, detectFlashVersion, autoInstallRedirect){ if (!document.getElementById) { return; } this.initialDataSet = false; // Create container objects this.params = new Object(); this.variables = new Object(); this.attributes = new Array(); // Set attributes for the SWF if(swf) { this.setAttribute('swf', swf); } if(id) { this.setAttribute('id', id); } if(w) { this.setAttribute('width', w); } if(h) { this.setAttribute('height', h); } // Set background color if(c) { this.addParam('bgcolor', c); } // Set Quality this.addParam('quality', 'high'); // Add scripting access parameter this.addParam('allowScriptAccess', 'always'); // Pass width and height to be appended as chartWidth and chartHeight this.addVariable('chartWidth', w); this.addVariable('chartHeight', h); // Whether in debug mode debugMode = debugMode ? debugMode : 0; this.addVariable('debugMode', debugMode); // Pass DOM ID to Chart this.addVariable('DOMId', id); // Whether to registed with JavaScript registerWithJS = registerWithJS ? registerWithJS : 0; this.addVariable('registerWithJS', registerWithJS); // Scale Mode of chart scaleMode = scaleMode ? scaleMode : 'noScale'; this.addVariable('scaleMode', scaleMode); // Application Message Language lang = lang ? lang : 'EN'; this.addVariable('lang', lang); // Whether to auto detect and re-direct to Flash Player installation this.detectFlashVersion = detectFlashVersion?detectFlashVersion:1; this.autoInstallRedirect = autoInstallRedirect?autoInstallRedirect:1; // Ger Flash Player version this.installedVer = infosoftglobal.FusionChartsUtil.getPlayerVersion(); if (!window.opera && document.all && this.installedVer.major > 7) { // Only add the onunload cleanup if the Flash Player version // supports // External Interface and we are in IE infosoftglobal.FusionCharts.doPrepUnload = true; } } infosoftglobal.FusionCharts.prototype = { setAttribute: function(name, value){ this.attributes[name] = value; }, getAttribute: function(name){ return this.attributes[name]; }, addParam: function(name, value){ this.params[name] = value; }, getParams: function(){ return this.params; }, addVariable: function(name, value){ this.variables[name] = value; }, getVariable: function(name){ return this.variables[name]; }, getVariables: function(){ return this.variables; }, getVariablePairs: function(){ var variablePairs = new Array(); var key; var variables = this.getVariables(); for(key in variables){ variablePairs.push(key +"="+ variables[key]); } return variablePairs; }, getSWFHTML: function() { var swfNode = ""; if (navigator.plugins && navigator.mimeTypes && navigator.mimeTypes.length) { // netscape plugin architecture swfNode = '<embed type="application/x-shockwave-flash" src="'+ this.getAttribute('swf') +'" width="'+ this.getAttribute('width') +'" height="'+ this.getAttribute('height') +'" '; swfNode += ' id="'+ this.getAttribute('id') +'" name="'+ this.getAttribute('id') +'" '; var params = this.getParams(); for(var key in params){ swfNode += [key] +'="'+ params[key] +'" '; } var pairs = this.getVariablePairs().join("&"); if (pairs.length > 0){ swfNode += 'flashvars="'+ pairs +'"'; } swfNode += '/>'; } else { // PC IE swfNode = '<object id="'+ this.getAttribute('id') +'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="'+ this.getAttribute('width') +'" height="'+ this.getAttribute('height') +'">'; swfNode += '<param name="movie" value="'+ this.getAttribute('swf') +'" />'; var params = this.getParams(); for(var key in params) { swfNode += '<param name="'+ key +'" value="'+ params[key] +'" />'; } var pairs = this.getVariablePairs().join("&"); if(pairs.length > 0) {swfNode += '<param name="flashvars" value="'+ pairs +'" />';} swfNode += "</object>"; } return swfNode; }, setDataURL: function(strDataURL){ // This method sets the data URL for the chart. // If being set initially if (this.initialDataSet==false){ this.addVariable('dataURL',strDataURL); // Update flag this.initialDataSet = true; }else{ // Else, we update the chart data using External Interface // Get reference to chart object var chartObj = infosoftglobal.FusionChartsUtil.getChartObject(this.getAttribute('id')); chartObj.setDataURL(strDataURL); } }, setDataXML: function(strDataXML){ // If being set initially if (this.initialDataSet==false){ // This method sets the data XML for the chart INITIALLY. this.addVariable('dataXML',strDataXML); // Update flag this.initialDataSet = true; }else{ // Else, we update the chart data using External Interface // Get reference to chart object var chartObj = infosoftglobal.FusionChartsUtil.getChartObject(this.getAttribute('id')); chartObj.setDataXML(strDataXML); } }, setTransparent: function(isTransparent){ // Sets chart to transparent mode when isTransparent is true // (default) // When no parameter is passed, we assume transparent to be true. if(typeof isTransparent=="undefined") { isTransparent=true; } // Set the property if(isTransparent) this.addParam('WMode', 'transparent'); else this.addParam('WMode', 'Opaque'); }, render: function(elementId){ // First check for installed version of Flash Player - we need a // minimum // of 8 if((this.detectFlashVersion==1) && (this.installedVer.major < 8)){ if (this.autoInstallRedirect==1){ // If we can auto redirect to install the player? var installationConfirm = window.confirm("You need Adobe Flash Player 8 (or above) to view the charts. It is a free and lightweight installation from Adobe.com. Please click on Ok to install the same."); if (installationConfirm){ window.location = "http://www.adobe.com/shockwave/download/download.cgi?P1_Prod_Version=ShockwaveFlash"; }else{ return false; } }else{ // Else, do not take an action. It means the developer has // specified a message in the DIV (and probably a link). // So, expect the developers to provide a course of way to // their // end users. // window.alert("You need Adobe Flash Player 8 (or above) to // view the charts. It is a free and lightweight // installation // from Adobe.com. "); return false; } }else{ // Render the chart var n = (typeof elementId == 'string') ? document.getElementById(elementId) : elementId; n.innerHTML = this.getSWFHTML(); // Added <FORM> compatibility // Check if it's added in Mozilla embed array or if already // exits if(!document.embeds[this.getAttribute('id')] && !window[this.getAttribute('id')]) window[this.getAttribute('id')]=document.getElementById(this.getAttribute('id')); // or else document.forms[formName/formIndex][chartId] return true; } } } /* ---- detection functions ---- */ infosoftglobal.FusionChartsUtil.getPlayerVersion = function(){ var PlayerVersion = new infosoftglobal.PlayerVersion([0,0,0]); if(navigator.plugins && navigator.mimeTypes.length){ var x = navigator.plugins["Shockwave Flash"]; if(x && x.description) { PlayerVersion = new infosoftglobal.PlayerVersion(x.description.replace(/([a-zA-Z]|\s)+/, "").replace(/(\s+r|\s+b[0-9]+)/, ".").split(".")); } }else if (navigator.userAgent && navigator.userAgent.indexOf("Windows CE") >= 0){ // If Windows CE var axo = 1; var counter = 3; while(axo) { try { counter++; axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash."+ counter); PlayerVersion = new infosoftglobal.PlayerVersion([counter,0,0]); } catch (e) { axo = null; } } } else { // Win IE (non mobile) // Do minor version lookup in IE, but avoid Flash Player 6 crashing // issues try{ var axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7"); }catch(e){ try { var axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6"); PlayerVersion = new infosoftglobal.PlayerVersion([6,0,21]); axo.AllowScriptAccess = "always"; } catch(e) { if (PlayerVersion.major == 6) { return PlayerVersion; } } try { axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash"); } catch(e) {} } if (axo != null) { PlayerVersion = new infosoftglobal.PlayerVersion(axo.GetVariable("$version").split(" ")[1].split(",")); } } return PlayerVersion; } infosoftglobal.PlayerVersion = function(arrVersion){ this.major = arrVersion[0] != null ? parseInt(arrVersion[0]) : 0; this.minor = arrVersion[1] != null ? parseInt(arrVersion[1]) : 0; this.rev = arrVersion[2] != null ? parseInt(arrVersion[2]) : 0; } // ------------ Fix for Out of Memory Bug in IE in FP9 ---------------// /* Fix for video streaming bug */ infosoftglobal.FusionChartsUtil.cleanupSWFs = function() { var objects = document.getElementsByTagName("OBJECT"); for (var i = objects.length - 1; i >= 0; i--) { objects[i].style.display = 'none'; for (var x in objects[i]) { if (typeof objects[i][x] == 'function') { objects[i][x] = function(){}; } } } } // Fixes bug in fp9 if (infosoftglobal.FusionCharts.doPrepUnload) { if (!infosoftglobal.unloadSet) { infosoftglobal.FusionChartsUtil.prepUnload = function() { __flash_unloadHandler = function(){}; __flash_savedUnloadHandler = function(){}; window.attachEvent("onunload", infosoftglobal.FusionChartsUtil.cleanupSWFs); } window.attachEvent("onbeforeunload", infosoftglobal.FusionChartsUtil.prepUnload); infosoftglobal.unloadSet = true; } } /* Add document.getElementById if needed (mobile IE < 5) */ if (!document.getElementById && document.all) { document.getElementById = function(id) { return document.all[id]; }} /* Add Array.push if needed (ie5) */ if (Array.prototype.push == null) { Array.prototype.push = function(item) { this[this.length] = item; return this.length; }} /* Function to return Flash Object from ID */ infosoftglobal.FusionChartsUtil.getChartObject = function(id) { var chartRef=null; if (navigator.appName.indexOf("Microsoft Internet")==-1) { if (document.embeds && document.embeds[id]) chartRef = document.embeds[id]; else chartRef = window.document[id]; } else { chartRef = window[id]; } if (!chartRef) chartRef = document.getElementById(id); return chartRef; } /* Aliases for easy usage */ var getChartFromId = infosoftglobal.FusionChartsUtil.getChartObject; var FusionCharts = infosoftglobal.FusionCharts; // 验证参数 if( dataSource == null ||dataSource == "" || charttype == null || charttype == "" || containerDiv == null || containerDiv ==""){ alert("数据源,统计图类型和装载容器为必填项,请输入!"); return false; } if(params == null) params = new Object(); // 初始化参数 initialize(params); // 发送请求 $.getJSON(dataSource, function(data){ var dataXML = "<chart caption='"+ params.caption +"' xAxisName='"+ params.xAxisName + "' yAxisName='"+params.yAxisName + "' baseFont='Arial' baseFontSize='12' baseFontColor='000000'"+ "showValues='0' decimals='0' formatNumberScale='0'>"; $.each(data.items,function(i,v){ for(var key in v){ dataXML += "<set label='"+key+"' value='"+v[key]+"' />"; //dataXML += "<set label='学生' value='80' />"; } }); dataXML += "</chart>"; showChart(dataXML,charttype,containerDiv,params); }); // initialize param function initialize(params){ params.caption = params.caption != null && params.caption != "" ? params.caption : "统计图"; params.xAxisName = params.xAxisName != null && params.xAxisName != "" ? params.xAxisName : "名称"; params.yAxisName = params.yAxisName != null && params.yAxisName != "" ? params.yAxisName : "数量"; params.width = params.width != null && params.width != "" ? params.width : "100%"; params.height = params.height != null && params.height != "" ? params.height : "100%"; params.chartId = params.chartId != null && params.chartId != "" ? params.chartId : "chart_id"; } // show chart function showChart(dataXML,charttype,containerDiv,params){ charttype = charttype == "Column3D" ? "Column3D" : charttype == "Pie3D" ? "Pie3D" : "Line"; // swf文件路径 var charturl = "javascripts/swf/"; var myChart = new FusionCharts(charturl+charttype+".swf",params.chartId,params.width,params.height,"0","0"); myChart.setDataXML(dataXML); myChart.render(containerDiv); } } });
flashdemo.html
flash 加载容器div
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" dir="ltr" lang="zh-CN"> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <title>flash demo</title> <script type="text/javascript" src="javascripts/jquery-1.3.2.min.js"></script> <script type="text/javascript" src="javascripts/jquery.flash.js"></script> <script type="text/javascript" src="javascripts/flashdemo.js"></script> </head> <body> <div id="chartdiv"></div> </body> </html>
end...
flashdemo.js
dom加载完成后执行
$(function(){ //图表相关属性设置 var params = new Object(); params.caption = "统计图"; params.xAxisName = "名称"; params.yAxisName = "数量"; params.chartId = "chart_da"; params.width = "100%"; params.height = "100%"; /*参数说明 参数1 : url请求(返回json对象 如{'学生':80,'教师':5}) 参数2: 图表类型 Column3D、Pie3D、Line等 参数3: 装载flash容器的div 参数4: 参数数组设置图表的横纵名称等 */ $.loadCharts('action',"Column3D","chartdiv",params); //$.loadCharts('',"Pie3D","chartdiv",params); });
评论
1 楼
shot_big
2012-08-17
//图表相关属性设置
var params = new Object();
params.caption = "统计图";
params.xAxisName = "名称";
params.yAxisName = "数量";
params.chartId = "chart_da";
params.width = "100%";
params.height = "100%";
/*参数说明
参数1 : url请求(返回json对象 如{'学生':80,'教师':5})
参数2: 图表类型 Column3D、Pie3D、Line等
参数3: 装载flash容器的div
参数4: 参数数组设置图表的横纵名称等
*/
var $ww={'学生':80,'教师':5};
$.loadCharts($ww,"Column3D","chartdiv",params);
为什么我这样调用不行?
var params = new Object();
params.caption = "统计图";
params.xAxisName = "名称";
params.yAxisName = "数量";
params.chartId = "chart_da";
params.width = "100%";
params.height = "100%";
/*参数说明
参数1 : url请求(返回json对象 如{'学生':80,'教师':5})
参数2: 图表类型 Column3D、Pie3D、Line等
参数3: 装载flash容器的div
参数4: 参数数组设置图表的横纵名称等
*/
var $ww={'学生':80,'教师':5};
$.loadCharts($ww,"Column3D","chartdiv",params);
为什么我这样调用不行?
发表评论
-
象山需求
2014-11-27 23:51 0急急急 -
jquery 展开缩放功能
2014-02-21 22:09 0地址:http://www.w3cfuns.com/thre ... -
jquery 分页组件
2013-12-27 22:41 0快快快 -
临时文件
2011-07-26 22:13 0jls -
JQuery插件——jquery tools
2010-05-31 09:29 1639Jquery Tools是一组基于Jquery ... -
JQuery插件——通用分页组件
2010-05-28 17:46 14908在实际项目开发中,通用的分页组件是必不可少的。下 ...
相关推荐
"图片文件上传回显jQuery插件——插件四"正是针对这一需求设计的工具,它简化了开发者实现这一功能的复杂度,使得图片预览和上传变得更加便捷。 jQuery是一个广泛使用的JavaScript库,它简化了DOM操作、事件处理、...
在这个“jquery插件——多级菜单”项目中,我们可能看到以下关键技术点: 1. **CSS样式和布局**:多级菜单的呈现通常依赖于CSS来实现层次感。通过设置适当的`display`属性(如`none`和`block`),我们可以控制菜单...
**jQuery 插件——手风琴效果** 在Web开发中,jQuery是一个广泛使用的JavaScript库,它简化了DOM操作、事件处理、动画制作等任务。手风琴效果是jQuery插件中常见的一种交互式UI设计,它允许用户通过点击展开或折叠...
这里我们关注的“jQuery插件——评分_ui_cookie_放大图”主题,涵盖了几个关键的知识点,包括jQuery插件开发、评分系统实现、用户界面(UI)设计、Cookie管理和图片预览功能。 首先,jQuery插件是jQuery生态系统中...
**jQuery 插件 Imgbox 知识点详解** 在网页设计和开发中,展示图片时,经常需要提供一种方式让用户可以放大查看细节。jQuery 插件 Imgbox 正是为了解决这一需求而诞生的。它允许用户点击缩略图,以弹出窗口的形式...
jquery插件 提示框 用法: 注意:因为没有使用css文件,而且在jquery.tooltip.js里通过对象的形式定义css,所以使用时,需要修改jquery.tooltip.js里的图片路径。
此插件可将所给字符串进行处理,是该字符串能够在鼠标以上时跳动起来,是一种文字特效的插件
效果描述: 在网页中我们经常要用到拖拽效果,无论是pc客户端还是手机页面 今天再次给大家推荐一个非常好用的插件 ...保证页面引入jQuery以及本插件的基础上,然后将你需要拖动的div的class如此一下
效果描述: 在网页中我们经常要用到拖拽效果,无论是pc客户端还是手机页面 今天再次给大家推荐一... 保证页面引入jQuery以及本插件的基础上,然后将你需要拖动的div的class如此一下 例如:$(".lanren").Tdrag();
3. **交互性增强**:Flash-jQuery插件使得Flash与JavaScript之间的通信更加顺畅,允许用户在不离开页面的情况下与Flash内容进行交互,例如传递数据、响应用户事件等。 4. **兼容性优化**:考虑到部分用户可能禁用了...
《jQuery点击图片放大插件——实现简单高效的网页交互体验》 在Web开发中,提供良好的用户体验是至关重要的,其中图片的展示方式就是一种常见的优化点。"jQuery点击图片放大插件"正是为了解决这个问题而设计的,它...
描述中的重复信息“jquery图表插件大全收集jquery图表插件大全收集jquery图表插件大全收集”可能是强调这个资源的全面性,意味着用户可以在这里找到大量关于jQuery图表插件的信息和实例。 标签“jquery图表插件大全...
这样做的目的是确保jQuery库在Validation插件之前加载,因为Validation依赖于jQuery。 ```html <script src="path/to/jquery.min.js"> <script src="path/to/jquery.validate.min.js"> ``` 接着,你可以为需要验证...
《jQuery插件与Flash上传:实现高效自定义扩展的上传功能》 在Web开发中,文件上传是一项必不可少的功能,尤其在交互丰富的Web应用中。jQuery作为一款强大的JavaScript库,为开发者提供了许多便利。然而,HTML5的...
《jQuery游戏——小鸟飞行》是一款基于JavaScript库jQuery开发的简单互动游戏,旨在通过模拟小鸟飞行的场景,让玩家体验到游戏的乐趣,同时也提供了一个学习jQuery交互效果和动画制作的实践平台。这款游戏通常由HTML...
在 JavaScript 部分,我们通过 `$("#pagination").jqueryPage()` 初始化分页组件,并传递一些关键参数,如总页数、当前页数、每页显示的条数以及点击页码后的回调函数。`clickCallback` 函数会在用户点击分页链接时...
jQuery验证码插件是一种用于网页表单验证用户输入的工具,主要目的是防止自动化脚本或机器人进行非法操作,如恶意注册、频繁提交等。这个插件是基于流行的JavaScript库jQuery构建的,它为开发者提供了一种简便的方式...
总结,jqPlot作为一款强大的jQuery图表插件,不仅提供了丰富的图表类型和自定义选项,还具备良好的扩展性和兼容性,使得开发者能够方便地创建出符合需求的交互式图表。通过深入学习和实践,开发者可以充分利用jqPlot...
**jQuery.downCount.js插件详解** 在Web开发中,倒计时功能经常被用于各种应用场景,比如活动开始、产品发布、考试倒计时等。jQuery.downCount.js是一款简单易用的jQuery插件,专为实现这种功能而设计。本文将详细...
JQuery作为一款广泛使用的JavaScript库,提供了许多优秀的图表插件来实现这一功能。本篇文章将详细介绍几种实用的JQuery图表插件,包括Flot、Highcharts、jquerychart和jqPlot,并提供相关资源下载和中文帮助文档。 ...