使用Open Flash Chart(OFC)制作图表(Struts2处理)
- package xxx.app.action.chart;
- import java.util.ArrayList;
- import java.util.List;
- import java.util.Map;
- import javax.servlet.http.HttpServletResponse;
- import org.apache.struts2.ServletActionContext;
- import jofc2.model.Chart;
- import jofc2.model.axis.Label;
- import jofc2.model.axis.XAxis;
- import jofc2.model.axis.YAxis;
- import jofc2.model.elements.LineChart;
- import xxx.app.action.BaseAction;
- public class OfcChartAction extends BaseAction {
- private Chart ofcChart;
- public Chart getOfcChart() {
- return ofcChart;
- }
- public String showChart() throws Exception{
- //y轴数据集合-使用数量
- List<Number> dataSet = new ArrayList<Number>();
- //x轴数据集合-浏览器类型
- List<Label> xLabel = new ArrayList<Label>();
- //获取需要显示的数据集
- List browserList = getServMgr().getVisitStatService().getBrowserStat();
- for (int i = 0; i < browserList.size(); i++) {
- Map map = (Map) browserList.get(i);
- //填充x轴
- dataSet.add((Integer) map.get("statCount"));
- //填充y轴
- xLabel.add(new Label((String) map.get("statVar")));
- }
- //设置X轴内容
- XAxis labels = new XAxis();
- labels.addLabels(xLabel);
- //设置Y轴显示值域:Range的三个参数含义为:坐标最小值,最大值和步进值
- YAxis range = new YAxis();
- range.setRange(0, 200, 10);
- //OFC折线图设置
- LineChart lineChart = new LineChart(LineChart.Style.NORMAL);
- lineChart.addValues(dataSet);
- lineChart.setColour("#6666FF");
- lineChart.setText("使用者数量");
- //图表设置
- Chart chart = new Chart("用户浏览器使用量分布");
- chart.setXAxis(labels);
- chart.setYAxis(range);
- chart.addElements(lineChart);
- //打印JSON格式的文本
- System.out.print(chart.toString());
- HttpServletResponse response = ServletActionContext.getResponse();
- response.setContentType("application/json-rpc;charset=utf-8");
- response.setHeader("Cache-Control", "no-cache");
- response.setHeader("Expires", "0");
- response.setHeader("Pragma", "No-cache");
- response.getWriter().write(chart.toString());
- return null;
- }
- }
Service中获取数据我们使用Spring的JdbcTemplate进行。
- //获取记录的浏览器信息
- private static final String SQL_GET_BROWER_STAT = "select statVar,statCount from nd_stats where statType='browser'";
- /**
- * 获取记录的浏览器信息
- */
- public List getBrowserStat() {
- return jt.queryForList(SQL_GET_BROWER_STAT);
- }
写好Action,我们简单配置一下,因为我们只是得到JSON文本,所以不必配置跳转,只需配置请求即可。
- <action name="ofcChart" class="xxx.app.action.chart.OfcChartAction">
- </action>
页面的JS代码也很简单。如下即可:
- <script type="text/javascript" src="${base}/js/swfobject.js"></script>
- <script type="text/javascript">
- var flashvars = {"data-file":"${base}/manage/stat/ofcChart!showChart.action"};
- var params = {menu: "false",scale: "noScale",wmode:"opaque"};
- swfobject.embedSWF("${base}/swf/open-flash-chart.swf", "chart", "600px", "400px", "9.0.0",
- "expressInstall.swf",flashvars,params);
- </script>
- <div id="chart">
- </div>
这里需要多说几句,首先是路径,不能错了,错了就请求不到数据了。Swfobject.js是页面使用JS方式配置Flash显示的,比较方便,所有使用它了。设置一个div用于Flash的显示,这个id是embedSWF的第二个参数,不能忘写了。还有就是请求地址参数的问题,这里我们是方便测试就没有传递参数,而实际开发不可避免传递参数。参数传递时在请求地址后面按普通形式书写即可,只是&这个连接符需要转义,写成%26,其他就没有什么了。
我们得到的结果就是这样的,这是很普通的折线图。但是不比JFreeChart的差哦。
同时在控制台我们得到jofc2为我们生成的JSON文本。
- {"is_thousand_separator_disabled":0,"is_decimal_separator_comma":0,"title":{"tex
- t":"用户浏览器使用量分布"},"y_axis":{"min":0,"steps":10,"max":200},"x_axis":{"la
- bels":{"labels":[{"text":"Safari"},{"text":"MSIE6X"},{"text":"MSIE7X"},{"text":"
- MSIE8X"},{"text":"Firefox"},{"text":"Chrome"},{"text":"Opera"},{"text":"Maxthon"
- },{"text":"Other"}]}},"num_decimals":2,"is_fixed_num_decimals_forced":0,"element
- s":[{"font-size":10,"text":"使用者数量","type":"line","values":[6,2,63,168,1,10,
- 1,0,0],"colour":"#6666FF"}]}
下面我们做柱状图,做个个性点的,用sketch类型。
- //Sketch型柱状图设置
- SketchBarChart sketchChart = new SketchBarChart();
- sketchChart.setColour("#6666FF");
- sketchChart.addValues(dataSet);
- sketchChart.setText("使用者数量");
- //图表设置
- Chart chart = new Chart("用户浏览器使用量分布");
- chart.setXAxis(labels);
- chart.setYAxis(range);
- chart.addElements(sketchChart);
这样我们就得到了下面的显示效果,是不是很卡通,哈哈。
需要注意jofc2将sketch风格的柱状图单独写成了一个类,而使用普通风格的柱状图时不时这么进行的。
- //柱状图Bar的集合
- List<Bar> barList=new ArrayList<Bar>();
- for (int i = 0; i < browserList.size(); i++) {
- Map map = (Map) browserList.get(i);
- //填充Bar,并给出提示
- barList.add(new Bar((Integer) map.get("statCount")).setTooltip("#val#次"));
- //填充y轴
- xLabel.add(new Label((String) map.get("statVar")));
- }
- //柱状图设置
- BarChart barChart=new BarChart(BarChart.Style.GLASS);
- barChart.addBars(barList);
- barChart.setColour("#6666FF");
- barChart.setText("使用者数量");
- //图表设置
- Chart chart = new Chart("用户浏览器使用量分布");
- chart.setXAxis(labels);
- chart.setYAxis(range);
- chart.addElements(barChart);
我们得到如下的柱状图。
最后一种是饼状图,下面我们来画饼。
- //饼状图
- PieChart pieChart = new PieChart();
- for (int i = 0; i < browserList.size(); i++) {
- Map map = (Map) browserList.get(i);
- //填充x轴
- dataSet.add((Integer) map.get("statCount"));
- //饼状图添加块
- pieChart.addSlice((Integer) map.get("statCount"), (String) map.get("statVar"));
- }
- //饼状图设置
- pieChart.setColours("#d01f3c", "#356aa0", "#C79810");
- pieChart.setText("使用者数量");
- pieChart.setRadius(180); //饼图的半径
- pieChart.setTooltip("#val# / #total#<br>#percent#");
- //图表设置
- Chart chart = new Chart("用户浏览器使用量分布");
- chart.setXAxis(labels);
- chart.setYAxis(range);
- chart.addElements(pieChart);
生成的饼状图如下:
OFC接收一个JSON格式的文本用来填充Flash,Flash解析这段文本就生成了漂亮的图表。当然OFC的设置还有很多,可以做出非常炫的效果,这里就不深入研究了,当然就是set一些属性罢了。最后我们还是看一下JFreeChart的吧。
希望对使用者有用,欢迎交流探讨更深入内容。