image-js
Version:
Image processing and manipulation in JavaScript
69 lines (60 loc) • 1.67 kB
JavaScript
// based on https://bgrins.github.io/TinyColor/docs/tinycolor.html
import Image from '../Image';
import { RGB, HSV } from '../model/model';
/**
* Make a copy of the current image and convert the color model to HSV
* The source image has to be RGB !
* @memberof Image
* @instance
* @return {Image} - New image in HSV color model
* @example
* var hsvImage = image.hsv();
* // we can create one image per channel
* var channels = hsvImage.split();
*/
export default function hsv() {
this.checkProcessable('hsv', {
bitDepth: [8, 16],
alpha: [0, 1],
colorModel: [RGB],
});
let newImage = Image.createFrom(this, {
colorModel: HSV,
});
let ptr = 0;
let data = this.data;
for (let i = 0; i < data.length; i += this.channels) {
let red = data[i];
let green = data[i + 1];
let blue = data[i + 2];
let min = Math.min(red, green, blue);
let max = Math.max(red, green, blue);
let delta = max - min;
let hue = 0;
let saturation = max === 0 ? 0 : delta / max;
let value = max;
if (max !== min) {
switch (max) {
case red:
hue = (green - blue) / delta + (green < blue ? 6 : 0);
break;
case green:
hue = (blue - red) / delta + 2;
break;
case blue:
hue = (red - green) / delta + 4;
break;
default:
throw new Error('unreachable');
}
hue /= 6;
}
newImage.data[ptr++] = hue * this.maxValue;
newImage.data[ptr++] = saturation * this.maxValue;
newImage.data[ptr++] = value;
if (this.alpha) {
newImage.data[ptr++] = data[i + 3];
}
}
return newImage;
}