echarts图片保存
一.js:
function updateChart(versionList,rateList) {
option = {
title: {
text: '拖动频次'
},
tooltip : {
trigger: 'axis',
axisPointer : { // 坐标轴指示器,坐标轴触发有效
type : 'shadow' // 默认为直线,可选为:'line' | 'shadow'
}
},
legend: {
itemWidth:15,
itemHeight:15,
data:['拖动频次[拖动次数/小时]'],
},
animation : false,
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
xAxis : [
{
type : 'category',
data : versionList,
axisTick: {
alignWithLabel: true
}
}
],
yAxis : [
{
type : 'value',
name:'次/小时',
axisLabel: {
formatter: '{value}',
}
},
],
series : [
{
name:'拖动频次[拖动次数/小时]',
type:'bar',
barWidth: '50%',
itemStyle:{
normal:{
color:'rgba(58,95,205,1)',
borderType : 'dashed',
barBorderRadius:[10, 10, 10, 10],
}
},
label: {
normal: {
show: true,
position: 'top',
textStyle: {
color: 'black'
}
}
},
data:rateList
}
]
};
chart.setOption(option, true);
var projectId = GetQueryString('projectId');
picLoad(chart.getDataURL(),"/Btm20LCDDragfrequency"+projectId+".png");
}
注意: animation : false, 否则图片不能保存
function picLoad(dataPic,picName){
$.ajax({
type : 'POST',
url : '/ajax/loadPic',
data : {
"data" :dataPic,
"name" : picName
},
contentType : "application/x-www-form-urlencoded",
success : function(data) {
}
});
}
解释:
1.chart.getDataURL()方法获取base64编码,获取的结果是:
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABI4AAAEsCAYAAAClh/jbAAA ... 在"base64,"之后的才是图片信息
二.后台
@RequestMapping(value = "/loadPic", method = RequestMethod.POST, produces = {"application/json;charset=UTF-8"})
public @ResponseBody Map<String, Object> reg(HttpServletRequest request, HttpServletResponse response) {
Map<String, Object> result = new HashMap<String, Object>();
String name = request.getParameter("name");
String[] picData = request.getParameter("data").split(",");
try {
byte[] n = new BASE64Decoder().decodeBuffer(picData[1]);
String path = Thread.currentThread().getContextClassLoader().getResource("").getPath();
path = path + "folderPath.properties";
Properties prop = new Properties();
prop.load(new FileInputStream(path));
String filePath = prop.getProperty("UploadPicImagePath");
File fp = new File(filePath);
if (!fp.exists()) {
fp.mkdirs();
}
OutputStream out = new FileOutputStream(new File(filePath+name));
out.write(n);
out.flush();
out.close();
result.put("code", 200);
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
logger.info(name+" save success");
return result;
}
三.获取图片
@Override
public boolean sendFingerReport(Integer projectId, Integer versionId, String userGroup,
Btm20LCDEmailConfig emailConfig) throws Exception {
Map<String, Object> emailMap = new HashMap<String, Object>();
// 版本
Version version = this.versionService.getVersionById(versionId);
emailMap.put("version", version);
emailMap.put("projectId", projectId);
String path = Thread.currentThread().getContextClassLoader().getResource("").getPath();
path = path + "folderPath.properties";
Properties prop = new Properties();
prop.load(new FileInputStream(path));
String filePath = prop.getProperty("UploadPicImagePath");
File f1 = new File(filePath + "/Btm20LCDAPPBrigthDrag" + projectId + ".png");
if (f1.exists()) {
emailMap.put("Btm20LCDAPPBrigthDrag", filePath + "/Btm20LCDAPPBrigthDrag" + projectId + ".png");
}
// 收件人
String receiver = "";
if (emailConfig != null && !CheckUtils.isNullOrBlank(emailConfig.getReciverId())) {
TmGroup tmGroup = this.tmGroupService.selectTmGroupById(emailConfig.getReciverId());
if (!CheckUtils.isNullOrBlank(tmGroup) && !CheckUtils.isNullOrBlank(tmGroup.getMemberArr())) {
String[] groupMembers = tmGroup.getMemberArr().split(",");
for (int i = 0; i < groupMembers.length; i++) {
receiver += this.personInfoService.selectPersonInfoById(Integer.parseInt(groupMembers[i]))
.getEmail() + ",";
}
}
}
String mailText = templateEmailService.getMailText("/btm20/email/btm20LcdMail.ftl", emailMap);
Email email = new Email();
email.setEmail(true);// 标记收件人是不是邮箱
email.setSubject(emailConfig.getSubject());
email.setTo(receiver);
email.setCc(copyTo);
email.setContent(mailText);
boolean send = EmailServerTerminal.send(email,"btm20");
return send;
}
echarts图片保存的更多相关文章
- Java - PhantomJS + EChartsConvert实现ECharts图片保存到服务端
1.所需工具 1>phantomjs:官网下载http://phantomjs.org/download.html 国内镜像http://npm.taobao.org/dist/phantomj ...
- ECharts外部调用保存为图片操作及工作流接线mouseenter和mouseleave由于鼠标移动速度过快导致问题解决办法
记录两个项目开发中遇到的问题,一个是ECharts外部调用保存为图片操作,一个是workflow工作流连接曲线onmouseenter和onmouseleave事件由于鼠标移动过快触发问题. 一.外部 ...
- php 获取远程图片保存到本地
php 获取远程图片保存到本地 使用两个函数 1.获取远程文件 2.把图片保存到本地 /** * 获取远程图片并把它保存到本地 * $url 是远程图片的完整URL地址,不能为空. */ functi ...
- 用qt代码怎样编写图片保存格式[qt4.6]
用qt代码怎样编写图片保存格式 qt提供了多个保存图片的接口,比较常用的接口如下 bool QPixmap::save ( const QString & fileName, const ch ...
- iOS 将图片保存到本地
//将图片保存到本地 + (void)SaveImageToLocal:(UIImage*)image Keys:(NSString*)key { NSUserDefaults* prefer ...
- C# 图片保存到数据库和从数据库读取图片并显示
图片保存到数据库的方法: public void imgToDB(string sql) { //参数sql中要求保存的imge变量名称为@images //调 ...
- file_put_contents() 图片保存 函数成功之后返回值
今天弄图片保存时,用到file_put_contents()来保存图片,运行了几次,发下一直没有数据出来,以为是这个函数没操作成功 于是查看了下这个函数的用法和返回值,发现我输出的返回都正确,后来才发 ...
- iOS9中将图片保存到照片中的某个相册的方法说明
iOS9中将图片保存到照片中的某个相册的方法说明 在App中很经常遇到的就是用户点击某张图片后将图片保存到本地,下面介绍下iOS中保存图片的一些东西 1.首先,在iOS中把图片保存到系统照片是比较简单 ...
- 24位和8位BMP图片保存纯C代码
BMP图片大家都知道,可以通过查看BMP图片结构使用纯C就可以打开,编辑,处理,保存图片.非常方便使用. 具体BMP结构可以参考:wingdi.h头文件.今天主要在进行删减代码,需要把多余的代码删除, ...
随机推荐
- 【夯实PHP基础】PHPUnit -- PHP测试框架
本文地址 分享提纲: 1.概述 2.安装 3.编写第一个测试用例 4.PHPUnit高级 5.参考 1.概述 1)[测试框架] 它是一款轻量级的PHP测试框架,是一个xUnit的体系结构的单元测试框架 ...
- Nginx 安装配置
Nginx("engine x")是一款是由俄罗斯的程序设计师Igor Sysoev所开发高性能的 Web和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. ...
- Loj#6183. 看无可看
Loj#6183. 看无可看 题目描述 首先用特征根求出通项公式\(A_n=p\cdot 3^n+q\cdot(-1)^n\).通过给定的\(f_0,f_1\)可以解出\(p,q\). 然后我们要求的 ...
- 设计模式のBuilderPattern(创建者模式)----创建模式
一.产生背景 要组装一台电脑,它的组装过程基本是不变的,都可以由主板.CPU.内存等按照某个稳定方式组合而成.然而主板.CPU.内存等零件本身都是可能多变的.将内存等这种易变的零件与电脑的其他部件分离 ...
- [matlab] 23.matlab自带kmeans函数 实现聚类
clc,clear all; point=[1.40000000000000,0.200000000000000;1.40000000000000,0.200000000000000;1.300000 ...
- Jenkins控制台显示乱码
方案: 解决控制台中文乱码问题: 点击左侧“系统管理”——右侧选择“系统设置”——“全局属性”,选择第一项:Environment variables,键值对列表,点击增加: 键:LANG 值:zh. ...
- 【vue】vue +element 搭建项目,vue-cli 如何打包上线
以自己的项目为例 第一步:手动修改config文件夹中的index.js文件中的build对象,将 assetsPublicPath 中的 “/” ,改为 “你实际的加载路径” 如图: 第二步:执行( ...
- Xmind8 破解
链接: https://pan.baidu.com/s/1IaNyngxJnKDQ0dNqPasA7w 提取码: g3q2 步骤1: 下载安装XMind 8 . 百度网盘下载: https://pan ...
- jenkins+mail邮件配置
1.配置过程中出现的问题,“501 mail from address must be same as authorization user” 解决方案 2.还有一个问题,在配置jenkins的系统配 ...
- 在DreamView中支持一辆新车
Support a new Vehicle in DreamView In order to support a new vehicle in DreamView, please follow the ...