最近工作使用了HighCharts,要用到保存成图片功能,但是是内部使用,不允许连接外网,于是就学习了下highcharts生成本地图片。

highcharts有一个exporting.js来负责导出成图片功能。

1.先在页面引用两个js。我使用的是exporting.src.js,方便查看源码,这里需要修改一点点东西。

要显示中文的话,需要在exporting.src.js最末尾处加上以下设置,或者直接修改初始化的默认值。

Highcharts.setOptions({
  lang: {
    printChart: "打印图表",
    downloadJPEG: "下载JPEG 图片",
    downloadPDF: "下载PDF文档",
    downloadPNG: "下载PNG 图片",
    downloadSVG: "下载SVG 矢量图",
    exportButtonTitle: "导出图片"
  }
});

2.打开exporting.src.js,找到defaultOptions.exporting属性里的url,这里发送了一个请求到highcharts官网,然后处理成图片之后再返回回来,并不是使用js生成的图片。

将官方的请求地址修改成我们代码的地址。

它这里是生成了一个form发送了请求之后又清除了这个form,发送的数据就是svg数据,以及文件名宽度等数据信息。

highcharts的图表就是使用svg格式显示的。

附一个svg数据格式的介绍:

http://baike.baidu.com/link?url=QLNwuVWHvxtBw075wHb6IztcTa4k2TTLE96-ZJKIjVpYOHDyv-1Pxhzb-m1F8yu7KDALj_F0Gh3FYEUNLM3PJxX1n5QuTdOEnjemhpDG04_

3.然后打开nuget,添加SVG Rendering Library。

没有nuget的可以到http://svg.codeplex.com/去下载dll。

4.添加了引用之后在代码中创建一个公用方法,添加以下代码。

这个是根据svg的xml数据生成一个图片的方法,需要使用到上面第三步添加的东西。

     public static Bitmap CreateSvgBitmap(string SvgStr, int Width)
{
SvgDocument svgDoc; // Create a MemoryStream from SVG string.
using (MemoryStream streamSvg = new MemoryStream(Encoding.UTF8.GetBytes(SvgStr)))
{
svgDoc = SvgDocument.Open<SvgDocument>(streamSvg);
} // Scale SVG document to requested width.
svgDoc.Transforms = new SvgTransformCollection();
float scalar = (float) Width / (float)svgDoc.Width;
svgDoc.Transforms.Add(new SvgScale(scalar, scalar));
svgDoc.Width = new SvgUnit(svgDoc.Width.Type, svgDoc.Width * scalar);
svgDoc.Height = new SvgUnit(svgDoc.Height.Type, svgDoc.Height * scalar);
return svgDoc.Draw();
}

5.然后写控制器请求以及返回代码数据,因为提交请求里有xml数据mvc会自动拦截,需要添加 ValidateInput(false)标记下。

返回的时候需要添加这段代码,表示返回的是附件,否则页面就直接跳转了。

Response.Headers.Add("Content-Disposition", string.Format("attachment; filename={0}", filename));

我这里功能只需要导出图片格式的,所以去掉了其他格式。

     [ValidateInput(false)]
public FileContentResult ExportCharts(string filename, string type, string svg)
{
if (string.IsNullOrEmpty(svg))
return null; int width = ;
MemoryStream fileStream = new MemoryStream();
Bitmap img = ChartsUtils.CreateSvgBitmap(svg,width);
switch (type)
{
case "image/jpeg":
img.Save(fileStream, ImageFormat.Jpeg);
break;
case "image/png":
img.Save(fileStream, ImageFormat.Png);
break;
case "image/svg+xml":
StreamWriter writer = new StreamWriter(fileStream);
writer.Write(svg);
writer.Flush();
break;
default:
throw new InvalidOperationException(string.Format("ContentType '{0}' is invalid.", type));
}
fileStream.Flush();
Response.Headers.Add("Content-Disposition", string.Format("attachment; filename={0}", filename));
return File(fileStream.ToArray(), type);
}

6.最后,功能完成。

附上git上的一个官方参考代码地址。

https://github.com/imclem/Highcharts-export-module-asp.net
												

HighChats报表使用C#mvc导出本地图片的更多相关文章

  1. KindEditor上传本地图片在ASP.NET MVC的配置

    http://www.cnblogs.com/upupto/archive/2010/08/24/1807202.html 本文解决KindEditor上传本地图片在ASP.NET MVC中的配置. ...

  2. JAVA将Excel中的报表导出为图片格式(一)问题背景

    如题所示,先抛出一个问题,如何使用JAVA将Excel中的报表导出为图片格式? 首先说一下这个问题的背景,也就是为什么博主会碰到这个问题 随着微信,易信之流大行其道,企业内部的办公交流.绩效考评甚至考 ...

  3. ASP.NET MVC 导出Word报表

    最近要做MVC导出Word报表功能.查了查资料发现一个好用的插件就是Aspose.Word.这个插件也很有名气,也很好用. 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private ...

  4. 个人永久性免费-Excel催化剂功能第102波-批量上传本地图片至网络图床(外网可访问)

    自我突破,在100+功能后,再做有质量的功能,非常不易,相对录制视频这些轻松活,还是按捺不住去写代码,此功能虽小,但功课也做了不少,希望对真正有需要的群体带来一些惊喜. 背景介绍 图床的使用,一般是写 ...

  5. mvc导出excel 之 新

    前段时间做的mvc导出excel 老大说要进行优化,我原来导出是用npoi插件进行导出,格式是将数据放入到datatable中,然后进行导出. 说要优化的时候就想着将datatable数据导出格式改为 ...

  6. 【吉光片羽】MVC 导出Word的两种方式

    1.直接将Html转成Word.MVC自带FileResult很好用.Html中我们也可以嵌入自己的样式. html: <div id="target"> <st ...

  7. jsp引入本地图片

    jsp引入本地图片 通用解决方法: 在tomcat的server.xml配置文件中,在<host></host>标签中间添上一句 <!-- docBase : 磁盘绝对路 ...

  8. SpringBoot之显示本地图片范例

    controller // 扫描指定目录下的图片进行展示 @RequestMapping("/showPics") public ModelAndView showPics(Mod ...

  9. TinyMCE的使用(包括汉化及本地图片上传功能)

    TinyMCE我就不多介绍了,这是下载地址:https://www.tinymce.com/download/ 下载下来是英文版,要汉化也很简单.首先去网上随便下载个汉化包,然后把汉化包解压后的lan ...

随机推荐

  1. 利用 Excel 公式进行数据整理

    一个考勤机里导出来的数据明细: A3公式:=IF(MOD(ROW(Sheet1!U5),2)=1,Sheet1!U5,INDIRECT("Sheet1!U"&ROW(She ...

  2. Win32API界面库 - Project wheels 工程基础部分完成

    离上次发博文过去了好久,先是要忙一个机器人的项目,然后就是部门的事情和考试周复习,然后就到了考试周,趁着复习的间隙,拾起了寒假时候抄的界面库,修掉了从前的bug. bug1 控件显示问题 当初抄这个库 ...

  3. SpringMVC 中获取所有的路由配置。

    ApplicationContext context = TMSContextLookup.getApplicationContext(); String[] controllerList = con ...

  4. php读取出字符串中的img标签中的图片路径

    php读取出字符串中的img标签中的图片路径 $pageContents = '字符串,带img标签'; $pageContents = str_replace('\"','"', ...

  5. 创建线程方式-GCD

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  6. python序列化: json & pickle & shelve 模块

    一.json & pickle & shelve 模块 json,用于字符串 和 python数据类型间进行转换pickle,用于python特有的类型 和 python的数据类型间进 ...

  7. 纸上谈兵:排序算法简介及C实现

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 排序算法(Sorting Algorithm)是计算机算法的一个组成部分. 排序的 ...

  8. Backbone笔记(续)

    Backbone Bockbone 总览 Backbone 与 MVC 模式:解决某一类问题的通用方案 - 套路 MVC:一种架构模式,解耦代码,分离关注点 M(Model) - 数据模型 V(Vie ...

  9. Servlet的异常处理

    Servlet 异常处理 当一个 Servlet 抛出一个异常时,Web 容器在使用了 exception-type 元素的 web.xml 中搜索与抛出异常类型相匹配的配置. 您必须在 web.xm ...

  10. EmptyRecycle() 清空回收站

    //在uses下面引用 function SHEmptyRecycleBinA(Wnd:HWND;str:PChar;WRD:DWORD):Integer;stdcall; external 'SHe ...