canvas.toDataURL返回空白图像

时间:2014-02-25 12:24:14

标签: javascript canvas todataurl

我想在画布上绘制一个表格,然后将画布保存为图像。 (需要创建一个pdf)

有趣的是,表格显示在画布上,但我无法使用.toDataURL进行转换,它只返回一个空白图像。

控制台中没有警报。

function getImgDataTable(tableContainer) {
    var tableArea = tableContainer.getElementsByTagName('table')[0].parentNode;
    var doc = tableContainer.ownerDocument;
    var canvas = doc.createElement('canvas');
    canvas.setAttribute('width', tableArea.offsetWidth);
    canvas.setAttribute('height', tableArea.offsetHeight);
    doc.body.appendChild(canvas);
 /* using rasterizeHTML.js */
    rasterizeHTML.drawHTML('<div style="font-size: 20px;">' + $("#data-table-chart-0").html()+ '</div>', canvas);
    var imgDataTable = canvas.toDataURL();
    console.log(imgDataTable);
    return imgDataTable;
}

我没有想法,每一个见解都受到赞赏。

1 个答案:

答案 0 :(得分:0)

试试这个http://jsfiddle.net/XtUFt/ HTML

   <div id="c"></div>
<div id="i"></div>

JS

var canvas = document.createElement("canvas");
canvas.height = canvas.width = 200;
$('#c').append(canvas);

var ctx = canvas.getContext("2d");

//draw a circle
ctx.beginPath();
ctx.arc(75, 75, 70, 0, Math.PI*2, true); 
ctx.closePath();
ctx.fill();

var dataURL = canvas.toDataURL("image/png");

$('#i').append($('<img/>', { src : dataURL }));