HighChats报表使用C#mvc导出本地图片
最近工作使用了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导出本地图片的更多相关文章
- KindEditor上传本地图片在ASP.NET MVC的配置
http://www.cnblogs.com/upupto/archive/2010/08/24/1807202.html 本文解决KindEditor上传本地图片在ASP.NET MVC中的配置. ...
- JAVA将Excel中的报表导出为图片格式(一)问题背景
如题所示,先抛出一个问题,如何使用JAVA将Excel中的报表导出为图片格式? 首先说一下这个问题的背景,也就是为什么博主会碰到这个问题 随着微信,易信之流大行其道,企业内部的办公交流.绩效考评甚至考 ...
- ASP.NET MVC 导出Word报表
最近要做MVC导出Word报表功能.查了查资料发现一个好用的插件就是Aspose.Word.这个插件也很有名气,也很好用. 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private ...
- 个人永久性免费-Excel催化剂功能第102波-批量上传本地图片至网络图床(外网可访问)
自我突破,在100+功能后,再做有质量的功能,非常不易,相对录制视频这些轻松活,还是按捺不住去写代码,此功能虽小,但功课也做了不少,希望对真正有需要的群体带来一些惊喜. 背景介绍 图床的使用,一般是写 ...
- mvc导出excel 之 新
前段时间做的mvc导出excel 老大说要进行优化,我原来导出是用npoi插件进行导出,格式是将数据放入到datatable中,然后进行导出. 说要优化的时候就想着将datatable数据导出格式改为 ...
- 【吉光片羽】MVC 导出Word的两种方式
1.直接将Html转成Word.MVC自带FileResult很好用.Html中我们也可以嵌入自己的样式. html: <div id="target"> <st ...
- jsp引入本地图片
jsp引入本地图片 通用解决方法: 在tomcat的server.xml配置文件中,在<host></host>标签中间添上一句 <!-- docBase : 磁盘绝对路 ...
- SpringBoot之显示本地图片范例
controller // 扫描指定目录下的图片进行展示 @RequestMapping("/showPics") public ModelAndView showPics(Mod ...
- TinyMCE的使用(包括汉化及本地图片上传功能)
TinyMCE我就不多介绍了,这是下载地址:https://www.tinymce.com/download/ 下载下来是英文版,要汉化也很简单.首先去网上随便下载个汉化包,然后把汉化包解压后的lan ...
随机推荐
- nginx,php相关
nginx安装 http://www.nginx.cn/install php安装 https://segmentfault.com/a/1190000004123048#articleHeader5 ...
- a+=b 是什么意思?
a+=b或者-=,*=等等就是相当于a=a+b;简写而已,没什么特殊含义此外还有a++/a--相当于a=a+1/a=a-1
- firefox与IE对js和CSS的区别(转http://log-cd.javaeye.com/blog/548665)
? "700px" : document.body.clientWidth>1000 ? "1000px" : "auto");// ...
- [Git].gitignore失效的原因
使用git管理源代码已经成为现在开源社区的一大选择. 开发的人都知道,在源代码管理中,我们需要监控和备份的是代码,而不是开发过程中生成的exe和dll文件.//即使在某些时候,我们需要某些dll,我们 ...
- java之注解Annotation
元注解:负责注解其他注解,java5提供的4个meta-annotation元注解 @Target 规定注解修饰的范围 ElementType.CONSTRUCTOR:构造器声明 ElementTyp ...
- openldap加密传输sssd
http://blog.father.gedow.net/2015/09/29/sssd-ldap-sudo/ yum -y install openldap-clients sssd authcon ...
- Mybatis保存数据时事务问题
今天不小心在sqlplus中用for update ,然后事务没提交,结果在项目中一直保存不进去数据,找了很久发现是sqlplus中的事务没提交,哎,这种问题真得避免啊,一定要细心啊!
- JS --正则表达式验证、实战之邮箱模式
JS验证格式:提高用户体验,验证文本. 需要防止程序员的代码结构更改攻击,因为web段的代码有可能会被更改,更改后JS有可能会验证不住那么,C#端在JS段通过验证的情况下,还需要进行二次验证 < ...
- C/C++操作MySQL数据库——增、删、改、查
1.数据库链接 int cppDatebase::DatabaseConnect(sBit8 *uName,sBit8 *pWord,sBit8 *dbName) { dbHandle = mysql ...
- openjudge ROADS
726:ROADS 总时间限制: 1000ms 内存限制: 65536kB 描述 N cities named with numbers 1 ... N are connected with one- ...