Я искал способ подсчета зеленых пикселей на изображении, и в итоге я написал свои собственные функции. Вот, пожалуйста,
Магия ®
function getPixel(imgData, index) {
var i = index*4, d = imgData.data;
return [d[i],d[i+1],d[i+2],d[i+3]] // [R,G,B,A]
}
function getPixelXY(imgData, x, y) {
return getPixel(imgData, y*imgData.width+x);
}
Где вы получаете imgData?
- создать
<canvas>
- получить холст
context
- копия
<img>
на <canvas>
- получить данные изображения холста (массив значений
[r,g,b,a,r,g,b,a,r,g,..]
)
- do `The magic`®
le код:
var cvs = document.createElement('canvas'),
img = document.getElementsByTagName("img")[0]; // your image goes here
// img = $('#yourImage')[0]; // can use jquery for selection
cvs.width = img.width; cvs.height = img.height;
var ctx = cvs.getContext("2d");
ctx.drawImage(img,0,0,cvs.width,cvs.height);
var idt = ctx.getImageData(0,0,cvs.width,cvs.height);
// The magic®
getPixel(idt, 852); // returns array [red, green, blue, alpha]
getPixelXY(idt,1,1); // same pixel using x,y
Рабочий пример см. В исходном коде http://qry.me/xyscope/