Я загрузил изображение цветового круга на холст, и у меня есть список значений оттенков в массиве. Я зацикливаю каждый пиксель на холсте и удаляю пиксели, которые соответствуют одинаковым значениям оттенка.
Код для этого:
var element = document.getElementById("wheel-canvas");
var c = element.getContext("2d");
var image = c.getImageData(0, 0, 375, 375);
var imageData = image.data;
paletteList = this.collection.pluck('hsv');
for (var i = 0, n = imageData.length; i < n; i += 4) {
var hsv = this.model.convertRGBToHSV(imageData[i], imageData[i+1], imageData[i+2]);
var hue = hsv[0];
var sat = hsv[1];
var val = hsv[2];
$.each(paletteList, function(index, value) {
if (hue === value[0])
{
imageData[i] = '0';
imageData[i+1] = '0';
imageData[i+2] = '0';
}
});
}
c.putImageData(image, 0, 0);

Теперь я хочу, чтобы все пиксели, которые не соответствуют оттенкам, стали черными. Я делаю изменение кода:
if (hue !== value[0])
и я получаю следующий результат:

Почему это не похоже на инверсию первого круга?
Спасибо!