fabricjs中因mac retina屏幕像素比导致的捕捉canvas像素不准确

背景

问题的起因是某项目中实现一个光标指向canvas后,捕捉当前鼠标位置色值的功能。功能完成后部分用户出现色值偏差,如图:

分析

fabricjs初始化canvas时,enableRetinaScalling默认开启,致使canvas getImageData()坐标错位,

问题解决:

修改前:

javascript 复制代码
/**
 * 获取canvas背景图中指定像素色值
 * @param canvas canvas参数为new fabric.Canvas()实例
 * @param x 鼠标x坐标位置
 * @param y 鼠标y坐标位置
 * @returns 当前鼠标所在像素的色值
 */
function getColorAtPosition(canvas, x, y) {
  var canvasElement = canvas.getElement()
  var context = canvasElement.getContext('2d')
  let newX = x * canvas.backgroundImage.scaleX
  let newY = y * canvas.backgroundImage.scaleY
  var pixel = context.getImageData(newX, newY, 1, 1).data
  const color = new fabric.Color(`rgba(${pixel.join(',')})`)
  return {
    array: pixel,
    rgba: `rgba(${pixel.join(',')})`,
    hex: `#${color.toHex()}`
  }
}

为保证当前坐标在不同屏幕下都可以正常捕捉,需要乘以屏幕像素比的比例,window.devicePixelRatio

修改后:

javascript 复制代码
// 获取canvas背景图中指定像素色值
function getColorAtPosition(canvas, x, y) {
  var canvasElement = canvas.getElement()
  var context = canvasElement.getContext('2d')
  // 注:retina屏幕下需要乘以当前设备的devicePixelRatio值 
  let newX = x * canvas.backgroundImage.scaleX * window.devicePixelRatio
  let newY = y * canvas.backgroundImage.scaleY * window.devicePixelRatio
  var pixel = context.getImageData(newX, newY, 1, 1).data
  const color = new fabric.Color(`rgba(${pixel.join(',')})`)
  return {
    array: pixel,
    rgba: `rgba(${pixel.join(',')})`,
    hex: `#${color.toHex()}`
  }
}

可以根据不同屏幕像素比,计算在canvas图像中相应的准确坐标。

相关推荐
heRs BART9 分钟前
spring-boot-starter和spring-boot-starter-web的关联
前端
龙猫里的小梅啊10 分钟前
CSS(七)CSS列表控制
前端·css
浩冉学编程11 分钟前
微信小程序中基于java后端实现官方的文本内容安全识别msgSecCheck
java·前端·安全·微信小程序·小程序·微信公众平台·内容安全审核
李李李勃谦28 分钟前
鸿蒙PC配色方案工具:取色、配色生成与 CSS 导出
前端·css·华为·harmonyos
threelab34 分钟前
Three.js 咖啡杯烟雾效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
Jul1en_1 小时前
Claude 迁移 Codex 工作流迁移与更新
java·服务器·前端·后端·ai编程
Heo1 小时前
14_React 中的更新队列 updateQueue
前端·javascript·面试
前端 贾公子1 小时前
解决浏览器端 globalThis is not defined 报错
前端·javascript·vue.js
宁雨桥1 小时前
前端与AI结合实战分享
前端·人工智能
之歆1 小时前
DAY12_CSS3选择器全攻略 + 盒子新特性完全指南(下)
前端·javascript·css3