最近工作使用了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. 51nod 1290 Counting Diff Pairs 莫队 + bit

    一个长度为N的正整数数组A,给出一个数K以及Q个查询,每个查询包含2个数l和r,对于每个查询输出从A[i]到A[j]中,有多少对数,abs(A[i] - A[j]) <= K(abs表示绝对值) ...

  2. Linxu 安装Scala

    在安装Scala的时候遇到以下错: Exception in thread "main" java.lang.NoClassDefFoundError: scala.tools.n ...

  3. bootstrap-图文混排 media

    <!-- media 图文混排 media-left(right) 图片的区域 在左边显示(右边) media-body 内容区域 media-heading 内容区域里的标题 media-mi ...

  4. typedef struct 结构体

    typedef struct _TTTT_ {   int    i;  }TT_TT; 定义变量如下: struct _TTTT_  NewTT;方法1 TT_TT NewTT;方法2 是声明和定义 ...

  5. jspSmartUpload上传下载全攻略

    http://blog.itpub.net/92037/viewspace-788900/

  6. restfull api

    REST 表示状态传输.这是一个体系结构样式,可用于设计网络服务,可以被各种客户端消耗.核心思想是,不使用如CORBA,RPC或SOAP复杂的机制在机器之间进行连接,简单的 HTTP 用于使它们之间调 ...

  7. win7访问ubuntu所在分区

    用ext2explore就可以了

  8. .bashrc文件是干什么的(转)

    使用man bash命令查看到的联机帮助文件中的相关解释如下:.bashrc - The individual per-interactive-shell startup file. 这个文件主要保存 ...

  9. CSS子元素居中(父元素宽高已知,子元素未知)

    <style> .container{width:400px; height:400px; position:relative;} .center{position:absolute; l ...

  10. Android IOS WebRTC 音视频开发总结(六七)-- 在线教育虽火要做好其实不容易

    本文主要介绍在线教育这个行业,文章最早发表在我们的微信公众号上,支持原创,详见这里, 欢迎关注微信公众号blackerteam,更多详见www.rtc.help 最近很多朋友在咨询在线教育的事(其实之 ...