canvas坐标系转webgl坐标系

红色的canvas坐标系,蓝色是webgl坐标系

需要注意的地方有三点

  1. 坐标原点不同,需要将canvas的中间位置作为webgl的原点,求出绿色的点相对于canvas中间位置的偏移量
  2. 求出绿色的点 相对于canvas中间位置的偏移量 对应的webgl的位置
  3. 处理y轴,canvas的y向下,webgl的y轴向上,需要将 y 的值取反

代码为鼠标点击canvas,获取当前的点的webgl坐标

复制代码
canvas.addEventListener('click', (e) => {
    // 第一步:e.clientX 是鼠标在网页中的位置,需要根据 e.clientX 求出鼠标在canvas中的位置
    const { clientX, clientY } = e
    const { top, left } = canvas.getBoundingClientRect();
    const [canvasX, canvasY] = [clientX - left, clientY - top]

    // 第二步:求canvas中的坐标值对应的webgl的坐标值
    // 1、处理原点,以canvas的中间位置(canvas.width/2,canvas.height/2)作为webgl的原点(0,0),求出鼠标当前位置在canvas系统中相对于webgl中的位置
    const canvasOffsetX = canvasX - canvas.width / 2
    const canvasOffsetY = canvasY - canvas.height / 2

    // 2、将canvas系统中的坐标值转换成webgl中的值
    const canvas2WebglX = canvasOffsetX / (canvas.width / 2)
    const canvas2WebglY = canvasOffsetY / (canvas.height / 2)

    // 3、处理y轴,canvas的y向下,webgl的y轴向上
    const canvas2WebglY2 = -canvas2WebglY;

    // canvas2WebglX 即为鼠标点在webgl中的x,canvas2WebglY2 即为鼠标点在webgl中的y
})
相关推荐
郝学胜-神的一滴1 天前
Three.js 材质系统深度解析
javascript·3d·游戏引擎·webgl·材质
Tetap1 天前
pixijs实现绿幕抠图和视频
前端·webgl
山西第一大怨种2 天前
我的浏览器下雨了进水了
前端·webgl
sixgod_h5 天前
Threejs源码系列- Object3D
webgl·three.js
烛阴6 天前
Clamp
前端·webgl
答案answer6 天前
three.js 实现几个好看的文本内容效果
前端·webgl·three.js
sixgod_h6 天前
Threejs源码系列- Quaternion
webgl·three.js
sixgod_h6 天前
Threejs源码系列- MathUtils(2)
前端·webgl
sixgod_h7 天前
Threejs源码系列- MathUtils(1)
前端·webgl
烛阴8 天前
Dot
前端·webgl