鸡蛋灌饼1 2022-07-12 09:56 采纳率: 50%
浏览 129
已结题

在canvas画布上添加字体时,动态切多次添加不一样的字会出现重叠问题改怎么解决,

canvas 动态添加 不一样的字体发生了重叠的一个效果,这样的该怎么解决

img

newImage(text) {
      // 生成图片
      var canvas = document.getElementById("canvas")
      var cxt = canvas.getContext("2d")

      var img = new Image()
      img.src = require('../assets/img/wxqcode.png')
      // 图片加载完成,才可处理
      img.onload = () => {

        // 画图(这里画布与图片等宽高)
        cxt.drawImage(img, 0, 0)
        // 设置字体大小

        cxt.font = "36px Microsoft YaHei"
        // 更改字号后,必须重置对齐方式,否则居中麻烦。设置文本的垂直对齐方式
        cxt.textBaseline = 'middle'
        cxt.textAlign = 'center'
        // 距离左边的位置
        var left = canvas.width / 2
        // 距离上边的位置 (图片高-文字距离图片底部的距离)
        var top = 150
        // 文字颜色
        cxt.fillStyle = "#000"
        // 文字在画布的位置
        cxt.fillText(text, left, top)
        // cxt.fillText(text2, left, top)
        imageBox.src = canvas.toDataURL("image/jpg")
        // this.flag = 1
      }

    },

上面是我的代码,因为需要动态加文字,需要多次调用这个方法,多次调用就会出现文字重叠的问题,这种要怎么解决

  • 写回答

1条回答 默认 最新

  • 不吐泡泡的咸鱼 2022-07-12 11:14
    关注

    每次内容的更改都需要对画面重新绘制。
    在img.onload 绘制图片之前,清空画布

    
    // 图片加载完成,才可处理
          img.onload = () => {
            cxt.clearRect(0,0, canvas.width, canvas.height);  
            
            // 画图(这里画布与图片等宽高)
            cxt.drawImage(img, 0, 0)  
            // ...
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 7月20日
  • 已采纳回答 7月12日
  • 修改了问题 7月12日
  • 修改了问题 7月12日
  • 展开全部

悬赏问题

  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码