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