鼠标经过canvas已绘制区域时,显示绘制时间

实现鼠标经过绘制区域时,显示绘制人绘制时间,如下图所示
在这里插入图片描述

  1. 在canvas上添加mousemove事件
    @mousemove=“mouse_move(item, $event)”
  2. 判断鼠标经过的点是否在已绘制区域内

        // 鼠标经过时 显示toolTip
        var xy = this.windowToCanvas(el, e.clientX, e.clientY);
        console.log('鼠标经过时', xy.x, xy.y);
        // 计算经过的点是否在已绘制的图形区域内 markList为已存储的所有绘制内容 box为绘制内容坐标
        for (var i = 0; i < this.markList.length; i++) {
          let page = this.markList[i].page + 1
          if (page == currentPage) {
            console.log(page);
            let box = JSON.parse(JSON.stringify(this.markList[i].box))
            //box为归一后的坐标 需要转为原始坐标
            let item = initSize((box), el)
            console.log(item);
            // box值为[x1,y1,x2,y2]
            penWidth为画笔高度
            if ((item[2] > xy.x && item[0] < xy.x) && (item[3] + this.penWidth > xy.y && item[1] - this.penWidth < xy.y)) {
              // 鼠标在已绘制区域
              this.drawTooltip(elTooltip, xy.x, xy.y, this.markList[i].time, this.markList[i].person)
              break
            } else {
              context2.clearRect(0, 0, elTooltip.width, elTooltip.height)
              console.log('不在');
            }
          }

        }
      
    drawTooltip(el, x, y, text, user) {
      let context = el.getContext('2d')
      // 清除旧的再绘制
      context.clearRect(0, 0, el.width, el.height)
      let username = user ? user : 'admin';

      let txtLoc = `${username}${text}添加了高亮 `
      context.save();
      var padding = 12;
      var font = "16px arial";
      context.font = font;
      context.textBaseline = 'bottom';
      context.fillStyle = '#dcf2f1';
      context.globalAlpha = 1
      //绘制ToolTip背景
      var width = context.measureText(txtLoc).width;
      var height = parseInt(font, 10);
      context.fillRect(x, y - height, width + padding * 2, height + padding * 2);
      context.strokeRect(x, y - height, width + padding * 2, height + padding * 2);

      //绘制ToolTip文字
      context.fillStyle = '#7c7c7c';
      context.fillText(txtLoc, x + padding, y + padding);
      context.restore();
    },
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值