使用 Extjs 将 SVG 转换为 PNG 的 Python 脚本

标签 python extjs charts extjs4.1

我正在尝试通过使用 Python 脚本将 SVG 转换为 PNG 来保存图表。 所以我开始将 svg 数据存储在一个变量中:

var svgdata = Ext.draw.engine.SvgExporter.generate(chart.surface);

当我执行 alert(svgdata) 时,我可以看到这个输出是正确的。

但是当我像这样将它发送到服务器时:

Ext.draw.engine.ImageExporter.defaultUrl = "data/svg_to_png.py?svgdata="+svgdata;

已发送的 svgdata 如下所示:

<?xml version=

我是 extjs 的新手,请在这方面帮助我。将 svg 数据发送到我的 python 脚本并呈现 png 图像的正确方法是什么?

这是我的 python 脚本:

import cairo
import cgi
import rsvg
print "Content-type: image/png\n\n"

arguments = cgi.FieldStorage()
img =  cairo.ImageSurface(cairo.FORMAT_ARGB32, 640,480)
ctx = cairo.Context(img)
handler= rsvg.Handle(None, str(arguments["svgdata"]))
handler.render_cairo(ctx)
img.write_to_png("svg.png")

请帮帮我!

最佳答案

<div style="display:none;">
    <iframe id="file_download_iframe" src="blank.html"></iframe>
</div>

您的服务器上需要一个空白的 html 页面才能在所有浏览器中正常工作。 blank.html 页面基本上是一个空页面,以满足 ifram 中始终有一个页面的要求。

那么你还需要一个隐藏在某处的基本表单:

<div style="display:none;">
    <form
        id = "file_download_iframe_form"
        name = "file_download_iframe_form"
        target = "file_download_iframe"
        method = "post"
        action = "data/svg_to_png.py"
    >
        <input type="hidden" id="svgdata" name="svgdata"/>
    </form>
</div>

然后有一个像这样的 javascript 函数:

function getImage(svgdata){
    var form = document.getElementById("file_download_iframe_form");
    document.getElementById("svgdata").value = svgdata;
    form.submit();
};

关于使用 Extjs 将 SVG 转换为 PNG 的 Python 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16339568/

相关文章:

java - 将包含图表的 docx 转换为 PDF

python - Conv2dTranspose 产生错误的输出形状

python - py2exe到exe文件,它可以在我的电脑上运行但在其他电脑上显示DLL加载失败

python - 在顶级 conftest 之外添加 pytest 选项的方法?

javascript - 如何整合 Meteor 和 Ext.js?

javascript - 带有 ExtJs 的多选组合框

javascript - 将 Chart JS 2 上的条形图扩展为一种新型图表

python - 试图找出一个数字中有多少位是另一个数字的倍数

javascript - ExtJS:将项目动态添加到视口(viewport)区域

charts - Stackdriver Dashboard - 无法使用基于日志的自定义指标保存仪表板