Highcharts导出代码Java版

添加包:

avalon-framework-api.jar
avalon-framework-impl.jar
batik-svg-dom.jar
batik-bridge.jar
batik-awt-util.jar
batik-gvt.jar
batik-transcoder.jar
batik-extension.jar
batik-ext.jar
commons-logging.jar
commons-io.jar
fop-0.95-1.jar
js.jar
pdf-transcoder.jar
xalan.jar
xerces.jar
xml-apis-ext.jar
xml-apis.jar
xmlgraphics-commons.jar

servlet-api.jar



转自:http://hi.baidu.com/god0156/blog/item/812747e82b5da0c52f2e2198.html

 

Highcharts是一个用纯JavaScript编写的图表库,提供了一个交互式的图表添加到您的网站或Web应用程序的简单方法。Highcharts目前支持线,样条,面积,areaspline,柱形图,条形图,饼图和散点图类型。

同时Highcharts提供将图表导出为图片或者PDF格式文件,只需要在页面中载入exporting.js文件。

由于生成的图表是SVG格式,所以导出时需要将数据发送到服务器端来进行转换。在exporting.js中默认导出地址是http://export.highcharts.com/,另外在demo中也提供了php版本。

本文是介绍如何在java web application中来实现导出功能。

首选需要在lib中加入batik jar包,如果是使用maven来管理项目,则在库中只能找到1.6的版本,同时需要另外下载一个包(xml-apis-ext.jar)。

public class ExportHighFreqChartServlet extends javax.servlet.http.HttpServlet implements javax.servlet.Servlet {
    public ExportHighFreqChartServlet() {
 super();
    }
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
 doPost(request, response);
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServerException, IOException {
 String type = request.getParameter("type");
 String svg = request.getParameter("svg");
 String filename = request.getParameter("filename");
 filename = filename==null?"chart":filename;
 ServletOutputStream out = response.getOutputStream();
 if (null != type && null != svg) {
     svg = svg.replaceAll(":rect", "rect");
     String ext = "";
     Transcoder t = null;
     if (type.equals("image/png")) {
  ext = "png";
  t = new PNGTranscoder();
     } else if (type.equals("image/jpeg")) {
  ext = "jpg";
  t = new JPEGTranscoder();
     } else if (type.equals("application/pdf")) {
                ext = "pdf";
                t = new PDFTranscoder();
           }
     response.addHeader("Content-Disposition", "attachment; filename="+ filename + "."+ext);
     response.addHeader("Content-Type", type);
     if (null != t) {
  TranscoderInput input = new TranscoderInput(new StringReader(svg));
  TranscoderOutput output = new TranscoderOutput(out);
  try {
      t.transcode(input, output);
  } catch (TranscoderException e) {
      out.print("Problem transcoding stream. See the web logs for more details.");
      e.printStackTrace();
  }
     } else if (ext.equals("svg")) {
  out.print(svg);
     }  else {
  out.print("Invalid type: " + type);
     }
 } else {
     response.addHeader("Content-Type", "text/html");
     out.println("Usage:\n\tParameter [svg]: The DOM Element to be converted.
            \n\tParameter [type]: The destination MIME type for the elment to be transcoded.");
 }
 out.flush();
 out.close();
    }
}

程序比较简单,接收页面传递的参数type、svg、filename,根据导出格式不同new不同的transcoder。

batik 1.6版本中好像没有提供对pdf格式导出的支持,所有如果程序报错,就把导出为pdf的功能去掉。

filename和export url都有默认值,可以在生成chart的配置中指定filename和我们自己的export url。在new Highcharts.Chart({})中加入下面代码

exporting:{
    filename:'class-booking-chart',
    url:'http://export.highcharts.com/'
}

其他基本就可以直接将demo的数据修改为自己需要的。

 

 

本文来自http://www.hencuo.com/archives/109

//可以设置下编码,解决中文乱码问题
response.setContentType(“text/html; charset=” + encoding);
//并用OutputStreamWriter包装ServletOutputStream转换iso-8859-1为UTF-8可输出中文内容
OutputStreamWriter writer = new OutputStreamWriter(out, “UTF-8″);

else if (ext.equals(“svg”)) {
// image/svg+xml
writer.append(svg);
writer.flush();
}

posted on 2011-07-18 18:39 hijackwust 阅读(6105) 评论(4)  编辑  收藏

评论

# re: Highcharts导出代码Java版 2012-08-03 16:32 Fandy

我想问下你们的type和svg参数是怎么传进去的,我的type和svg为空......  回复  更多评论   

# re: Highcharts导出代码Java版 2013-03-27 19:48 烟烟烟

@Fandy
我也遇到这样的问题,exporting.js里面export方法,修改一下参数类型为json,把e.post改成$.post。  回复  更多评论   

# re: Highcharts导出代码Java版 2013-09-05 17:49 paye

@烟烟烟
有完整的js吗?  回复  更多评论   

# re: Highcharts导出代码Java版 2014-05-17 23:18 zuidaima

highcharts代码下载:http://www.zuidaima.com/share/search.htm?key=highcharts  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航:
 
<2013年9月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

导航

统计

常用链接

留言簿(6)

随笔档案(57)

友情链接

搜索

最新评论

阅读排行榜

评论排行榜