美文网首页
鼠标在canvas上的位置计算

鼠标在canvas上的位置计算

作者: yummyMao | 来源:发表于2020-05-01 21:53 被阅读0次

最近有这样的需求,鼠标需要拖动矩形的顶点变化大小,这就需要检测鼠标在画布上的位置,接下来给大家介绍几种情况

一般情况

一般情况下,如果需要在 canvas 中获取鼠标指针坐标,可以通过监听鼠标的 mousemove(如果只需单击时的坐标,可以用 click)事件。 当事件被触发时,我们可以获取鼠标相对于 viewport 的坐标(event.clientX, event.clientY)。 同时,我们可以通过 canvas.getBoundingClientRect() 来获取 canvas 相对于 viewport 的坐标,这样我们就可以计算出鼠标在 canvas 中的坐标。

canvas.addEventListener("click", function __handler__(evt) {
    var x = evt.clientX;
    var y = evt.clientY;
    var rect = canvas.getBoundingClientRect();
    x -= rect.left;
    y -= rect.top;
    console.log(x, y); // (x, y) 就是鼠标在 canvas 单击时的坐标
});

设置了 border/padding

一般情况下,我们根据上面的方法获取出来的坐标是准确的,但当我们在 canvas 上添加了 border 或 padding 后,坐标就出现了偏移。
这是因为在 canvas 中,坐标区域是 canvas 元素的 content 区域,不包括 border 和 padding,而通过上面得到的坐标原点在 canvas 的 border 开始的。因此,这里还需要减去 border 和 padding。

var style = window.getComputedStyle(canvas, null);
var borderLeft = parseFloat(style["border-left-width"]);
var borderTop = parseFloat(style["border-top-width"]);
var paddingLeft = parseFloat(style["padding-left"]);
var paddingTop = parseFloat(style["padding-top"]);
canvas.addEventListener("click", function __handler__(evt) {
    var x = evt.clientX;
    var y = evt.clientY;
    var rect = canvas.getBoundingClientRect();
    x -= rect.left - borderLeft - paddingLeft; // 去除 borderLeft paddingLeft 后的坐标
    y -= rect.top - borderTop - paddingTop; // 去除 borderLeft paddingLeft 后的坐标
    console.log(x, y); // (x, y) 就是鼠标在 canvas 单击时的坐标
});

设置了 css width/height

当在 canvas 上设置了 css 的 width、height,并且与 canvas 的 width、height 属性不同时(可以非常简单对 canvas 进行放大或缩小,在移动页面上常常会使用)。从上面计算出来的坐标在 canvas 里使用又会出现偏移。

var style = window.getComputedStyle(canvas, null);
var cssWidth = parseFloat(style["width"]);
var cssHeight = parseFloat(style["height"]);
var scaleX = canvas.width / cssWidth; // 水平方向的缩放因子
var scaleY = canvas.height / cssHeight; // 垂直方向的缩放因子
canvas.addEventListener("click", function __handler__(evt) {
    var x = evt.clientX;
    var y = evt.clientY;
    var rect = canvas.getBoundingClientRect();
    x -= rect.left;
    y -= rect.top;
    x *= scaleX; // 修正水平方向的坐标
    y *= scaleY; // 修正垂直方向的坐标
    console.log(x, y); // (x, y) canvas 里的坐标
});

设置了 transform

如果我们在 canvas 的 style 上添加了 transform,又有可能会导致上面计算出来的坐标出现偏移。
而且经过 transform 后很难通过已经的 API 来计算出准确的坐标?w3c 为了解决这个问题,在 CSSOM-View 中添加了一个名为 GeometryUtils 的接口,该接口提供了一系列的 api 帮助我们对页面上的点、矩形、四边形等的坐标进行转换(目前只有 Firefox 支持)。 这里我们使用其中的 convertPointFromNode 方法,直接把在 viewport 的坐标 (evt.clientX, evt.clientY) 转换成相对于 canvas 元素的坐标。 如果 canvas 同时设置了样式 width、height、box-sizing,我们可以使用 getBoxQuads 方法来获取 canvas 经过 transform 之前的元素的 width 和 height(虽然可以使用通过获取 style 的相关属性来计算,但这种方式太麻烦了)来计算出经过 css 缩放的因子。

var quads = canvas.getBoxQuads({
    box: "content",
    relativeTo: canvas
});
var bounds = quads[0];
var scaleX = canvas.width / bounds.width;
var scaleY = canvas.height / bounds.height;
canvas.addEventListener("click", function __handler__(evt) {
    var {x, y} = canvas.convertPointFromNode({
        x: evt.clientX,
        y: evt.clientY
    }, document, {
        toBox: "content"
    });
    x *= scaleX;
    y *= scaleY;
    console.log(x, y);
});

相关文章

  • 鼠标在canvas上的位置计算

    最近有这样的需求,鼠标需要拖动矩形的顶点变化大小,这就需要检测鼠标在画布上的位置,接下来给大家介绍几种情况 一般情...

  • canvas画饼图(三)canvas 与鼠标事件和判断函数

    canvas需要绑定鼠标事件,同时需要得到鼠标在 canvas 上面的位置和判断鼠标是否在饼图上面 绑定鼠标事件 ...

  • HTML5 Canvas粒子模拟效果

    这是一款利用HTML5 Canvas模拟出来的30000个粒子动画,当你用鼠标在canvas画布上移动时,鼠标周围...

  • canvas 小效果

    canvas 画板 当在画布中,如果按下鼠标,我们将画布的起始点放在此时鼠标的位置,用到的是moveTo(),然后...

  • js 拖拽

    1:鼠标在元素上的坐标位置 offsetX offsetY 2:鼠标在浏览器(可视窗口)上的坐标位置 client...

  • javascript-放大镜特效

    点击查看 原理:鼠标在小图片上移动时,通过捕捉鼠标在小图片上的位置,定位大图片的位置 注意offsetWidth和...

  • 鼠标滚轮实现图片的放大缩小

    关键点,鼠标的位置是不动的,其他位置 的缩小是跟据鼠标左边的宽度与总宽度的壁纸来计算的数值方向是根据鼠标距离上边高...

  • 事件对象

    三个重要坐标 计算鼠标在盒子中的位置 阻止事件冒泡 even 对象封装

  • 【个人提升】canvas气泡漂浮动画

    canvas气泡漂浮动画实现效果思路: 1.获取鼠标移动的x、y坐标 //鼠标滑动 canvas.onmousem...

  • 使用vue作出锤子官方商城的3d-banner效果

    原理 利用js获取鼠标指针位置,根据位置计算偏转角度,通过设定css中transform的perspective/...

网友评论

      本文标题:鼠标在canvas上的位置计算

      本文链接:https://www.haomeiwen.com/subject/ljvlyhtx.html