image-js
Version:
Image processing and manipulation in JavaScript
68 lines (66 loc) • 1.88 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = hsv;
var _Image = _interopRequireDefault(require("../Image"));
var _model = require("../model/model");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
// based on https://bgrins.github.io/TinyColor/docs/tinycolor.html
/**
* 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();
*/
function hsv() {
this.checkProcessable('hsv', {
bitDepth: [8, 16],
alpha: [0, 1],
colorModel: [_model.RGB]
});
let newImage = _Image.default.createFrom(this, {
colorModel: _model.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;
}