javascriptjquerycanvassvgcanvg

Can't download my svg to png


Can anyone tell me why is my svg to png not downloading? What am I doing wrong? I can't seem to find a solution on how to download my svg to png. Is it my libraries or my code?

function save(){
    $("#editor_save").click(function() {
        // the canvg call that takes the svg xml and converts it to a canvas
        canvg('canvas', $("#editor").html());

        // the canvas calls to output a png
        var canvas = document.getElementById("canvas");
        var img = canvas.toDataURL("image/png");
        // do what you want with the base64, write to screen, post to server, etc...
    });
}
<script src="canvg-master/canvg.js"></script>
<div id="editor" class="chart">
    <svg width="100" height="100">
        <circle cx="50" cy="50" r="40" stroke="green" stroke-width="4" fill="red" />
    </svg><br />
    <button id="editor_save" onclick="save">Save</button>
</div>


Solution

  • You've a whole host of issues:

    In my corrected code I've left the canvas div visible so you cn see it working. Te canvas would normally be display:none though and you'd do something else with the img object.

    $("#editor_save").click(function() {
    
    // the canvg call that takes the svg xml and converts it to a canvas
      canvg('canvas', $("#svg")[0].outerHTML);
    
    // the canvas calls to output a png
    var canvas = document.getElementById("canvas");
    var img = canvas.toDataURL("image/png");
    // do what you want with the base64, write to screen, post to server, etc...
    });
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <script src="http://canvg.github.io/canvg/rgbcolor.js"></script>
    <script src="http://canvg.github.io/canvg/StackBlur.js"></script>
    <script src="http://canvg.github.io/canvg/canvg.js"></script>
    <div id="editor" class="chart">
    <svg id="svg" width="100" height="100">
      <circle cx="50" cy="50" r="40" stroke="green" stroke-width="4" fill="red" />
    </svg>
    <br />
    <button id="editor_save">Save</button>
    </div>
    <div>
      <canvas id="canvas" width="1000px" height="600px"></canvas> 
    </div>