Convert SVG to PNG and maintain CSS integrity

后端 未结 3 1051
眼角桃花
眼角桃花 2021-01-04 13:56

I am currently using canvg() and Canvas2Image to copy my SVG to a canvas and then convert the canvas to PNG. I would like to maintain the image format and not use PDF.

相关标签:
3条回答
  • 2021-01-04 14:05

    The key thing here is that all the style rules need to be part of the SVG, not in external style files. So you would need to go through all the CSS for NVD3 and set all of those attributes in the code. Anything that is set via an external stylesheet will be ignored.

    0 讨论(0)
  • 2021-01-04 14:21

    Style definitions for svg elements defined in stylesheets are not applied to the generated canvas. This can be patched by adding style definitions to the svg elements before calling canvg.

    Inspired on this article, I've created this:

    function generateStyleDefs(svgDomElement) {
      var styleDefs = "";
      var sheets = document.styleSheets;
      for (var i = 0; i < sheets.length; i++) {
        var rules = sheets[i].cssRules;
        for (var j = 0; j < rules.length; j++) {
          var rule = rules[j];
          if (rule.style) {
            var selectorText = rule.selectorText;
            var elems = svgDomElement.querySelectorAll(selectorText);
    
            if (elems.length) {
              styleDefs += selectorText + " { " + rule.style.cssText + " }\n";
            }
          }
        }
      }
    
      var s = document.createElement('style');
      s.setAttribute('type', 'text/css');
      s.innerHTML = "<![CDATA[\n" + styleDefs + "\n]]>";
      //somehow cdata section doesn't always work; you could use this instead:
      //s.innerHTML = styleDefs;
    
      var defs = document.createElement('defs');
      defs.appendChild(s);
      svgDomElement.insertBefore(defs, svgDomElement.firstChild);
    }
    
    // generate style definitions on the svg element(s)
    generateStyleDefs(document.getElementById('svgElementId'));
    
    0 讨论(0)
  • 2021-01-04 14:21

    just to make @Lars Kotthoff's answer more concrete. "example of how to export a png directly from an svg" has a working example. the code snippet/gist tries to first apply all css to the svg inline and then draw the image on the canvas and export the data as png. (internally it adopted svg-crowbar code). and i apply the technique in my project and it works smoothly - a download button that can download the svg image rendered using nvd3.

    0 讨论(0)
提交回复
热议问题