如何解决Zingchart通过Java调用getimagedata API
我尝试导出zingchart图像以在Java的base64对象中获取它。
我想在js中像这样使用getimageapi:
function exportImgChart(idChart) {
zingchart.exec('idChart','getimagedata',{
filetype: 'png',callback : function(imagedata) {
console.log(imagedata);
document.getElementById('output_image').src = imagedata;
}
});}
但是我不知道如何从Java代码中调用它?我把我的js函数像这样:
public void getimageChart(AjaxRequestTarget target,String idChart) {
String js = messageformat.format("exportImgChart({0});",//
StringUtils.wrap(this.getMarkupId(),"'") //
);
target.appendJavaScript(js);
//how to get image base 64 here ?
}
我的Java框架是Wicket
感谢您的帮助!
杰夫
解决方法
之所以调用
getImageChart(AjaxRequestTarget,String)
是因为从浏览器到服务器进行了一些Ajax调用。
然后在服务器端构造一个字符串,该字符串将将与响应一起发送到浏览器。 target.appendJavaScript(js);
不会立即发送。它只是说“'js'将成为响应的一部分”,但是一旦getImageChart()
并且其他方法完全执行后,响应就会刷新到浏览器。
您不能在target.appendJavaScript(js)
之后获得base64编码的图像。要获取base64数据,您需要在JavaScript函数exportImgChart()
中对服务器进行新的Ajax调用。这个新的Ajax调用很可能会调用新的回调方法,例如onBase64Image()
或其他名称。
有关更多信息,请参见以下答案:https://stackoverflow.com/a/42612027/497381
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。