UNPKG

image-js

Version:

Image processing and manipulation in JavaScript

68 lines (66 loc) 1.88 kB
"use strict"; 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; }