mirror of
https://github.com/publiclab/image-sequencer.git
synced 2025-12-12 03:10:03 +01:00
* remove trailing spaces from Run.js Signed-off-by: tech4GT <varun.gupta1798@gmail.com> * minimize module requirements demonstrated with invert fixes #122 Signed-off-by: tech4GT <varun.gupta1798@gmail.com> * refactored modules Signed-off-by: tech4GT <varun.gupta1798@gmail.com> * update docs Signed-off-by: tech4GT <varun.gupta1798@gmail.com> * remove all trailing spaces from all files Signed-off-by: tech4GT <varun.gupta1798@gmail.com> * fixing crop module Signed-off-by: tech4GT <varun.gupta1798@gmail.com> * fix Signed-off-by: tech4GT <varun.gupta1798@gmail.com> * update contributing.md Signed-off-by: tech4GT <varun.gupta1798@gmail.com>
50 lines
1.1 KiB
JavaScript
50 lines
1.1 KiB
JavaScript
/*
|
|
* NDVI with red filter (blue channel is infrared)
|
|
*/
|
|
module.exports = function Ndvi(options,UI) {
|
|
|
|
options.filter = options.filter || "red";
|
|
|
|
var output;
|
|
|
|
// The function which is called on every draw.
|
|
function draw(input,callback,progressObj) {
|
|
|
|
progressObj.stop(true);
|
|
progressObj.overrideFlag = true;
|
|
|
|
var step = this;
|
|
|
|
function changePixel(r, g, b, a) {
|
|
if (options.filter == "red") var ndvi = (b - r) / (1.00 * b + r);
|
|
if (options.filter == "blue") var ndvi = (r - b) / (1.00 * b + r);
|
|
var x = 255 * (ndvi + 1) / 2;
|
|
return [x, x, x, a];
|
|
}
|
|
|
|
function output(image,datauri,mimetype){
|
|
|
|
// This output is accessible by Image Sequencer
|
|
step.output = {src:datauri,format:mimetype};
|
|
|
|
}
|
|
|
|
return require('../_nomodule/PixelManipulation.js')(input, {
|
|
output: output,
|
|
changePixel: changePixel,
|
|
format: input.format,
|
|
image: options.image,
|
|
inBrowser: options.inBrowser,
|
|
callback: callback
|
|
});
|
|
|
|
}
|
|
|
|
return {
|
|
options: options,
|
|
draw: draw,
|
|
output: output,
|
|
UI:UI
|
|
}
|
|
}
|