- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我需要实现一个吸管工具。我想要它,所以您单击吸管按钮使其处于事件状态,然后使用 onmove 它将更改我的颜色选择器的颜色,当您使用 onclick 单击它时,它将使用以下方法将颜色设置为颜色选择器:
$('#colorpickerHolder').ColorPickerSetColor(eyeDropperColour);
变量 eyeDropperColour 将使用 onlick 设置,基于您所处的颜色像素。我想知道我是否必须根据我拥有的层来执行此操作:canvas 和 canvasCursor。
我一直在看这个指南,但我不能让它适用于我的项目? http://palebluepixel.org/2011/11/16/html5-canvas-eyedropper/
这是我的项目: http://www.taffatech.com/Paint.html
我有:
var eyeDropperActive = false;
var eyeDropperColour;
和:
$("#brushEyeDropper").click(function() {
if ( eyeDropperActive == true)
{
eyeDropperActive = false;
}
else if ( eyeDropperActive == false)
{
eyeDropperActive = true;
}
});
最佳答案
创建 Canvas “吸管”工具
这是读取 Canvas 上任意 X/Y 像素颜色的方法:
function getPixelColor(x, y) {
var pxData = ctx.getImageData(x,y,1,1);
return("rgb("+pxData.data[0]+","+pxData.data[1]+","+pxData.data[2]+")");
}
剩下的只是控制何时通过在 Canvas 上单击来接受颜色。
var eyedropperIsActive=false;
// Activate reading pixel colors when a #startDropper button is clicked
$("#startDropper").click(function(e){eyedropperIsActive=true;});
// if the tool is active, report the color under the mouse
$("#canvas").mousemove(function(e){handleMouseMove(e);});
// when the user clicks on the canvas, turn off the tool
// (the last color will remain selected)
$("#canvas").click(function(e){eyedropperIsActive=false;});
这里是调用 getPixelColor 并报告颜色的 mousemove 事件处理程序
// if the tool is active, report any color under the mouse
function handleMouseMove(e){
if(!eyedropperIsActive){return;}
mouseX=parseInt(e.clientX-offsetX);
mouseY=parseInt(e.clientY-offsetY);
// Put your mousemove stuff here
var eyedropColor=getPixelColor(mouseX,mouseY);
$("#results").css("backgroundColor",getPixelColor(mouseX,mouseY));
}
这是代码和 fiddle :http://jsfiddle.net/m1erickson/zpfdv/
<!doctype html>
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
<style>
body{ background-color: ivory; padding:30px; }
canvas{border:1px solid red;}
#results{width:30px; height:30px; border:1px solid blue;}
</style>
<script>
$(function(){
var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var canvasOffset=$("#canvas").offset();
var offsetX=canvasOffset.left;
var offsetY=canvasOffset.top;
var eyedropperIsActive=false;
drawTestColors(20,20,"red");
drawTestColors(100,20,"green");
drawTestColors(180,20,"blue");
function drawTestColors(x,y,color){
ctx.beginPath();
ctx.fillStyle=color;
ctx.rect(x,y,50,50);
ctx.fill();
}
function getPixelColor(x, y) {
var pxData = ctx.getImageData(x,y,1,1);
return("rgb("+pxData.data[0]+","+pxData.data[1]+","+pxData.data[2]+")");
}
function handleMouseMove(e){
if(!eyedropperIsActive){return;}
mouseX=parseInt(e.clientX-offsetX);
mouseY=parseInt(e.clientY-offsetY);
// Put your mousemove stuff here
var eyedropColor=getPixelColor(mouseX,mouseY);
$("#results").css("backgroundColor",getPixelColor(mouseX,mouseY));
}
$("#canvas").click(function(e){eyedropperIsActive=false;});
$("#canvas").mousemove(function(e){handleMouseMove(e);});
$("#startDropper").click(function(e){eyedropperIsActive=true;});
}); // end $(function(){});
</script>
</head>
<body>
<p>Click "Activate Eyedropper" to read pixel color under the mouse</p>
<p>Click canvas to set the color and de-active the eyedropper</p>
<canvas id="canvas" width=300 height=300></canvas><br>
<button id="startDropper">Activate Eyedropper</button>
<div id="results" width=30 height=30> </div>
</body>
</html>
关于javascript - Canvas 滴管,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17221802/
我正在寻找一个“吸管器”工具,它可以在 CMS 的 JavaScript 中为我提供鼠标光标所在像素的十六进制值。 对于 Firefox,有出色的 ColorZilla正是这样做的扩展。不过,当然这只
我需要实现一个吸管工具。我想要它,所以您单击吸管按钮使其处于事件状态,然后使用 onmove 它将更改我的颜色选择器的颜色,当您使用 onclick 单击它时,它将使用以下方法将颜色设置为颜色选择器:
我正在寻找一个“吸管”工具,它可以在 CMS 的 JavaScript 中为我提供鼠标光标所在像素的十六进制值。 对于 Firefox,有优秀的 ColorZilla正是这样做的扩展。然而,它当然只是
我刚刚发现,chrome 开发工具内置了一个非常有用的工具。我什至不知道它的名字,在谷歌上也找不到它。我想说它是一个像素检查器工具。 我发现以下方法如何使用它: 1a。检查具有背景颜色的 html 元
在 BioDaliance 网络应用程序中 http://www.biodalliance.org用户可以在使用 Chrome/Firefox 的 Mac 上呈现类似于 Mac 系统颜色选择器的内容。
我是一名优秀的程序员,十分优秀!