当前位置: 代码迷 >> Web前端 >> 运用highcharts生成统计图
  详细解决方案

运用highcharts生成统计图

热度:192   发布时间:2012-09-09 09:27:54.0
使用highcharts生成统计图

关于怎么使用highcharts的文章网络上并不多见,所以呢花了点时间学了下,现在就给大家分享下我的经验。

1.开发准备

highcharts的js开发包,json开发包,jquery开发包

这里着重使用json,这是我观察demo例子发现的,至于怎么从后台拿到json就要使用jquery的ajax请求和后台交互。

2.使用servlet取得相关数据并拼接json字符串

package org.lxh;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.*;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import net.sf.json.JSONArray;
import net.sf.json.JSONObject;

public class GetData extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void doGet(HttpServletRequest request,
			HttpServletResponse response) throws ServletException, IOException {
		this.doPost(request, response);
	}

	protected void doPost(HttpServletRequest request,
			HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		response.setCharacterEncoding("UTF-8");
		// 添加模拟数据
		// 添加3个学生
		List<StudentInfo> students = new ArrayList<StudentInfo>();
		StudentInfo stuident1 = new StudentInfo();
		stuident1.setName("黎明");
		List<Integer> allgrade = new ArrayList<Integer>();
		allgrade.add(90);
		allgrade.add(95);
		allgrade.add(80);
		allgrade.add(85);
		stuident1.setGrade(allgrade);
		students.add(stuident1);
		StudentInfo stuident2 = new StudentInfo();
		stuident2.setName("潘玮柏");
		List<Integer> allgrade2 = new ArrayList<Integer>();
		allgrade2.add(60);
		allgrade2.add(95);
		allgrade2.add(70);
		allgrade2.add(50);
		stuident2.setGrade(allgrade2);
		students.add(stuident2);

		StudentInfo stuident3 = new StudentInfo();
		stuident3.setName("李宇春");
		List<Integer> allgrade3 = new ArrayList<Integer>();
		allgrade3.add(68);
		allgrade3.add(93);
		allgrade3.add(78);
		allgrade3.add(59);
		stuident3.setGrade(allgrade3);
		students.add(stuident3);

		//JSONObject json = new JSONObject();
		JSONArray array = new JSONArray();
		//JSONArray gradeData = new JSONArray();
		JSONArray Data;
		JSONObject member = null;

		member = new JSONObject();
		Iterator<StudentInfo> it = students.iterator();
		while (it.hasNext()) {
			StudentInfo info = it.next();
			member.put("name", info.getName());

			Data = new JSONArray();
			List<Integer> grades = info.getGrade();
			Iterator<Integer> iterator = grades.iterator();
			while (iterator.hasNext()) {
				Data.add(iterator.next());
				
			}
			member.put("data", Data);
			array.add(member);

		}
		String str=array.toString();
        System.out.println(str);
		//json.put("series", array);
		//System.out.println(json.toString());
		PrintWriter pw = response.getWriter();
		//pw.print(json.toString());
		pw.print(str);
		pw.close();

	}

}

这里的数据都是我自己弄的测试数据,说到这里可能会有数据全是动态的情况也就是说在图表上x轴和y轴的数据都是动态的,这样子就需要嵌套jquery的ajax请求了。以学生成绩为例我们就需要分别拼接x轴和y轴的数据了。这个大家灵活控制就好了。

 3.前台显示数据

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="js/jquery.js"></script>
<script src="js/highcharts.js"></script>
<script src="js/exporting.js"></script>

<script type="text/javascript">
$(function () {
    var chart;
   // var total;
   
    
    $(document).ready(function() {
    	
    	$.ajax({
	        type: "POST",
	        dataType: "JSON",
	        url: "GetData",
	        success: function (msg) {
	            
	        	/*var str=JSON.stringify(msg);*/
	    
	        
	        	/*var total=JSON.parse(str);*/
	        	var total=msg;
	        	chart = new Highcharts.Chart({
	            	
	                chart: {
	                    renderTo: 'container',
	                    
	                    type: 'column'
	                },
	                title: {
	                    text: '学生成绩'
	                },
	                subtitle: {
	                    text: '09软件305班'
	                },
	                xAxis: {
	                    categories: [
	                        '第一周',
	                        '第二周',
	                        '第三周',
	                        '第四周',
	                    ]
	                },
	                yAxis: {
	                    min: 0,
	                    title: {
	                        text: '成绩 (分)'
	                    }
	                },
	                legend: {
	                    layout: 'vertical',
	                    backgroundColor: '#FFFFFF',
	                    align: 'left',
	                    verticalAlign: 'top',
	                    x: 100,
	                    y: 70,
	                    floating: true,
	                    shadow: true
	                },
	                tooltip: {
	                    formatter: function() {
	                    	
	                        return ''+
	                            this.x +': '+ this.y +' mm';
	                    }
	                },
	                plotOptions: {
	                    column: {
	                        pointPadding: 0.2,
	                        borderWidth: 0
	                    }
	                },
	                series: total
	            });
	        	
	        	
	        	
	           
	        }
    	});
	    
        
    });
    
});
		</script>	
</head>
<body>



<div id="container" style="min-width: 400px; height: 400px; margin: 0 auto"></div>
</body>
</html>

界面很简单吧就是把数据的地方换成从后台取出来的json就OK了。差不多每种类型的图表都是这样弄,我这里的x轴我把数据写死了,大家可以弄成动态的,原理都是一样的。

来看下效果图吧

很简单吧,只要后台json没有拼接错就很好弄了。