Javascript JSFIDLE获取画布中像素的颜色始终返回000的rgb值

Javascript JSFIDLE获取画布中像素的颜色始终返回000的rgb值,javascript,canvas,Javascript,Canvas,我在stackoverflow和其他资源上找到/尝试了许多解决方案,但我仍然无法正确读取鼠标悬停的像素值的颜色 我创建了一个JSFIDLE,其中在画布上绘制一个矩形,画布背景设置为蓝色 我有一个onMouseMove事件,它将在每次鼠标移动时触发。此函数的目的是获取鼠标的x和y坐标,并使用这些坐标获取该位置像素的颜色 以下是指向JSFIDLE的链接: 这是js文件: class Canvas extends React.Component { constructor(props) {

我在stackoverflow和其他资源上找到/尝试了许多解决方案,但我仍然无法正确读取鼠标悬停的像素值的颜色

我创建了一个JSFIDLE,其中在画布上绘制一个矩形,画布背景设置为蓝色

我有一个onMouseMove事件,它将在每次鼠标移动时触发。此函数的目的是获取鼠标的x和y坐标,并使用这些坐标获取该位置像素的颜色

以下是指向JSFIDLE的链接:

这是js文件:

class Canvas extends React.Component {
  constructor(props) {
    super(props);

    this.state = { x: 0, y: 0 };
  }

  componentDidMount() {
    const canvas = this.refs.canvas
    const ctx = canvas.getContext("2d")

    ctx.fillRect(25, 25, 100, 100);
    ctx.clearRect(45, 45, 60, 60);
    ctx.strokeRect(50, 50, 50, 50);
  }

  _onMouseMove(e) {
    this.setState({ x: e.screenX, y: e.screenY });
    console.log("x: " + this.state.x + " y: " + this.state.y);

    var canvas = this.refs.canvas;
    var ctx = canvas.getContext("2d");
    var data = ctx.getImageData(this.state.x, this.state.y, 1, 1).data;
    console.log(data);
  }

  render() {
    return(
      <div >
        <canvas onMouseMove={this._onMouseMove.bind(this)} ref="canvas" width={640} height={425} />
      </div>
    )
  }
}

ReactDOM.render(<Canvas />, document.querySelector("#app"))
数据变量在计算位置保存像素的RGB值。出于某种原因,RGB值始终为000,尽管我正在蓝色背景上移动鼠标。但是x&y坐标正在正确更新,因此我不确定这是否是
getImageData
函数的问题,或者它可能是什么


如何正确读取鼠标所在位置的像素值?

@gman我在问题中添加了代码您为什么不使用鼠标?然后,代码实际上会在问题中运行,只需单击一下即可将其复制到要修复的答案。无论如何,我怀疑问题在于您使用的是与屏幕相关的
e.screenX
e.screenY
。您可能需要与元素相关的
e.offsetX
e.offsetY
,或者可以使用
rect=canvas.getBoundingClientRect();x=e.clientX-右左;y=e.clientY-rect.top
@gman我在问题中添加了代码你为什么不使用密码?然后,代码实际上会在问题中运行,只需单击一下即可将其复制到要修复的答案。无论如何,我怀疑问题在于您使用的是与屏幕相关的
e.screenX
e.screenY
。您可能需要与元素相关的
e.offsetX
e.offsetY
,或者可以使用
rect=canvas.getBoundingClientRect();x=e.clientX-右左;y=e.clientY-rect.top
<div id="app"></div>
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#app {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  transition: all 0.2s;
}

/* #example {
  background-color: blue;
} */

canvas {
  background-color: blue;
}

li {
  margin: 8px 0;
}

h2 {
  font-weight: bold;
  margin-bottom: 15px;
}

.done {
  color: rgba(0, 0, 0, 0.3);
  text-decoration: line-through;
}

input {
  margin-right: 5px;
}