How to get png image of a CSS styled element using canvas with transparent background?

后端 未结 3 666
情深已故
情深已故 2021-01-02 17:38

I want to use CSS to style an element on a webpage and then to use that element as a static png. Is it possible to draw html node on eg. canvas and save such image with tran

相关标签:
3条回答
  • 2021-01-02 18:00

    Yes it is possible to save a HTML element as image (PNG file). See

    • Capture HTML Canvas as gif/jpg/png/pdf?
    • how to save canvas as png image?
    • HTML5 Save canvas to PNG
    • Drawing PNG to a canvas element -- not showing transparency
    • http://asserttrue.blogspot.de/2011/12/in-yesterdays-post-i-showed-how-to.html
    0 讨论(0)
  • 2021-01-02 18:04

    Saving HTML elements to images requires a Complicated Answer!

    First, for very good security reasons, browsers do not to allow same-page imaging of HTML elements. Imagine for example a malicious script that takes the HTML input form containing your banking username+password and converts it to an image and sends the image to a thief—not good!

    Therefore, IE simply block same page HTML element imaging--period.

    Chrome and Firefox might still have a feature (bug?!) that allows you to turn HTML elements into images like this: 1. Embed the HTML element into an SVG element using "foreignObject". 2. Draw the SVG element into a Canvas element. 3. Use canvas.toDataURL(‘image/png’) to get an encoded string representing the png image.

    Since it looks like you are in control of styling the HTML, you might have a full solution by using a “headless” HTML generator like PhantomJs.org (phantomjs.org). You can use Phantomjs to generate and style the HTML element. PhantomJs then has a rasterizer you can use to convert that element into an image. Plus, If you can serve up a web page that contains only the styled HTML you need, then this 1 line of PhantomJs code will get you a png of that page:

    phantomjs rasterize.js http://myHtmlOnMyPage.html myHtmlImage.png
    

    The Chrome/Firefox code is found here: https://developer.mozilla.org/en-US/docs/HTML/Canvas/Drawing_DOM_objects_into_a_canvas

    And looks like this:

    <!DOCTYPE html>
    <html>
    <body>
    <p><canvas id="canvas" style="border:2px solid black;" width="200" height="200"></canvas>
    <script>
    var canvas = document.getElementById("canvas");
    var ctx = canvas.getContext("2d");
    var data = "<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'>" +
                 "<foreignObject width='100%' height='100%'>" +
                   "<div xmlns='http://www.w3.org/1999/xhtml' style='font-size:40px'>" +
                     "<em>I</em> like <span style='color:white; text-shadow:0 0 2px blue;'>cheese</span>" +
                   "</div>" +
                 "</foreignObject>" +
               "</svg>";
    var DOMURL = self.URL || self.webkitURL || self;
    var img = new Image();
    var svg = new Blob([data], {type: "image/svg+xml;charset=utf-8"});
    var url = DOMURL.createObjectURL(svg);
    img.onload = function() {
        ctx.drawImage(img, 0, 0);
        DOMURL.revokeObjectURL(url);
    };
    img.src = url;
    </script>
    </body>
    </html>
    
    0 讨论(0)
  • 2021-01-02 18:11

    Just found an easy way via Safari.

    Right click on element, Inspect Element, then in the Inspector right click on the element node you want to export and pick Capture Screenshot. This to me resolves transparency. Safari Version 13.1 (14609.1.20.111.8)

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