Circle-Canvas获取lineWidth的像素颜色
Circle - Canvas get pixel color of lineWidth
我想获得lineWidth
圆的像素颜色。我测试了很多解决方案,但从未返回Linewidth
颜色。
下面是我尝试过的一个例子:
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.beginPath();
ctx.lineWidth=3;
ctx.arc(100, 100, 50, 0, 2 * Math.PI);
ctx.stroke();
function findPos(obj) {
var curleft = 0, curtop = 0;
if (obj.offsetParent) {
do {
curleft += obj.offsetLeft;
curtop += obj.offsetTop;
} while (obj = obj.offsetParent);
return { x: curleft, y: curtop };
}
return undefined;
}
function rgbToHex(r, g, b) {
if (r > 255 || g > 255 || b > 255)
throw "Invalid color component";
return ((r << 16) | (g << 8) | b).toString(16);
}
$('#myCanvas').mousemove(function(e) {
var pos = findPos(this);
var x = e.pageX - pos.x;
var y = e.pageY - pos.y;
var coord = "x=" + x + ", y=" + y;
var c = this.getContext('2d');
var p = c.getImageData(x, y, 1, 1).data;
var hex = "#" + ("000000" + rgbToHex(p[0], p[1], p[2])).slice(-6);
$('#status').html(coord + "<br>" + hex);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<canvas id="myCanvas" width="300" height="200" ></canvas>
<div id="status"></div>
最初的jsfiddle,我以正方形为例:http://jsfiddle.net/DV9Bw/1/
我试过的另一个jsfiddle:http://jsfiddle.net/9SEMf/1727/
实际上,您的代码没有任何问题。颜色十六进制值不变的原因是画布默认背景看起来是白色的,但实际上是黑色的,alpha为0。
如果您在mousemove处理程序中打印值,如console.log(JSON.stringify(p));
当鼠标不在圆圈上方时,您将看到类似于{"0":0,"1":0,"2":0,"3":0}
的内容。
请注意alpha的第四个值。
你可以先在画布上涂上白色,然后再画圆圈来看看区别。
//fill the entier canvas with opaque white
ctx.rect(0, 0, c.width, c.height);
ctx.fillStyle = "#FFFFFF";
ctx.fill();
jsfiddle与您的示例
相关文章:
- 获取图像的平均外部像素颜色
- 画布-在多个画布叠加中获取像素颜色
- Circle-Canvas获取lineWidth的像素颜色
- 如果滚动 300 像素,请更改背景颜色
- 如何使用WebGL设置画布上像素的颜色
- Javascript - 如何使用基于站点像素颜色的画布创建图像
- 在 JavaScript 画布中获取图像的颜色像素
- 从画布获取像素颜色
- 获取图像的第一个像素颜色(JS/jQuery)
- 如何根据某些功能为 svg 中的每个像素分配颜色
- HTML5画布-在屏幕上显示像素颜色阵列的最快方式
- 从图像中获取像素颜色
- 通过Three.js中的getImageData像素颜色数据循环生成多个立方体
- 从IMG获取像素颜色总是0 0 0 0
- 不同的像素颜色值相同
- 使用Javascript查找网页上特定坐标的像素颜色
- javascript getImageData未从png图像返回正确的像素颜色
- 在javascript中获取像素颜色
- 手动在JS画布上分配像素颜色
- 当检测画布上的像素颜色时,DOM异常18