为了账号安全,请及时绑定邮箱和手机立即绑定

使用 html2canvas 下载 div 作为图像时添加标题

使用 html2canvas 下载 div 作为图像时添加标题

PIPIONE 2023-03-03 15:08:01
我有一个使用 html2canvas 下载一些 div 作为图像的函数。我还希望能够在保存图像时在图像顶部添加一个标题,即 chartColumnID。  function saveAsImage(chartColumnID){            html2canvas($('#'+ chartColumnID),            {                onrendered: function (canvas) {                var a = document.createElement('a');                    a.href = canvas.toDataURL("image/png");                    a.download = chartColumnID;                    a.click();                }             });            };我试过这样的东西,但它不起作用,没有标题出现。我将 a.text= 移动到不同的行以仔细检查我是否可能将它放在错误的位置但没有运气。 function saveAsImage(chartColumnID){            html2canvas($('#'+ chartColumnID),            {                onrendered: function (canvas) {                var a = document.createElement('a');                    a.href = canvas.toDataURL("image/png");                    a.download = chartColumnID;                    a.text= (15, 15, chartColumnID.replace(/([A-Z])/g, ' $1').trim());                    a.click();                }             });            };有没有人知道如何使图表列 ID 也成为标题?
查看完整描述

1 回答

?
桃花长相依

TA贡献1860条经验 获得超8个赞

您可以尝试在画布上绘制文本(我没有检查过):


function saveAsImage(chartColumnID) {

  html2canvas($('#' + chartColumnID), {

    onrendered: function(canvas) {

// ----------------------------- here we draw text:

      const fontHeight = 14;

      const text = String(chartColumnID);

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

      ctx.font = fontHeight + "px Arial";

      ctx.textAlign = "left";

      ctx.fillStyle = "red"; // text color

      ctx.fillText(text, 0, fontHeight);

// ------------------------------ your code as ususal:

      var a = document.createElement('a');

      a.href = canvas.toDataURL("image/png");

      a.download = chartColumnID;

      a.click();

    }

  });

};


它在画布上的外观示例:


var canvas = document.getElementById("c");

var chartColumnID = (Math.random() * 1000 + 1) | 0;

canvas.width = 100;

canvas.height = 100;


const fontHeight = 14;

const text = String(chartColumnID);

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

ctx.font = fontHeight + "px Arial";

ctx.textAlign = "left";

ctx.fillStyle = "red"; // text color

ctx.fillText(text, 0, fontHeight);

canvas { border: 1px solid }

<canvas id="c" />


查看完整回答
反对 回复 2023-03-03
  • 1 回答
  • 0 关注
  • 103 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信