From 2736b481a4e96d5f3425e46387799d586eeb288b Mon Sep 17 00:00:00 2001 From: Naman Aggarwal <31132760+root00198@users.noreply.github.com> Date: Fri, 17 Jan 2020 01:10:30 +0530 Subject: [PATCH] Added aspect ratio module (#1454) * Base file * Added aspect ratio module * Compatiable with Experimental GIF Manipulation * some refactoring * Changed the name from aspect-ratio to Constrained Crop * cleanup * Changes requested * Added test module Co-authored-by: Harsh Khandeparkar <34770591+HarshKhandeparkar@users.noreply.github.com> Co-authored-by: Jeffrey Warren --- src/Modules.js | 1 + src/modules/ConstrainedCrop/Module.js | 56 +++++++++++++++++++++++++++ src/modules/ConstrainedCrop/index.js | 4 ++ src/modules/ConstrainedCrop/info.json | 23 +++++++++++ test/core/modules/constrained-crop.js | 10 +++++ 5 files changed, 94 insertions(+) create mode 100644 src/modules/ConstrainedCrop/Module.js create mode 100644 src/modules/ConstrainedCrop/index.js create mode 100644 src/modules/ConstrainedCrop/info.json create mode 100644 test/core/modules/constrained-crop.js diff --git a/src/Modules.js b/src/Modules.js index 3c34de70f7..6a00ab6dfd 100644 --- a/src/Modules.js +++ b/src/Modules.js @@ -13,6 +13,7 @@ module.exports = { 'colorbar': require('./modules/Colorbar'), 'color-temperature': require('./modules/ColorTemperature'), 'colormap': require('./modules/Colormap'), + 'constrained-crop': require('./modules/ConstrainedCrop'), 'contrast': require('./modules/Contrast'), 'convolution': require('./modules/Convolution'), 'crop': require('./modules/Crop'), diff --git a/src/modules/ConstrainedCrop/Module.js b/src/modules/ConstrainedCrop/Module.js new file mode 100644 index 0000000000..cac7f81572 --- /dev/null +++ b/src/modules/ConstrainedCrop/Module.js @@ -0,0 +1,56 @@ +/* +* Crops an Image on the basis of the ratio provided +*/ +module.exports = function ConstrainedCrop(options, UI) { + + var defaults = require('./../../util/getDefaults.js')(require('./info.json')); + var output; + + function draw(input, callback) { + + var step = this, + startingX = Number(options.startingX || defaults.startingX), + startingY = Number(options.startingY || defaults.startingY), + aspectRatio = (options.aspectRatio || defaults.aspectRatio).split(':'), + widthRatio = Number(aspectRatio[0]), + heightRatio = Number(aspectRatio[1]); + + function extraManipulation(pixels) { + var width = pixels.shape[0], + height = pixels.shape[1]; + var endX, endY; + if(((width - startingX) / widthRatio) * heightRatio <= (height - startingY)) { + endX = width; + endY = (((width - startingX) / widthRatio) * heightRatio) + startingY; + } + else { + endX = (((height - startingY) / heightRatio) * widthRatio) + startingX; + endY = height; + } + const newPixels = require('../Crop/Crop')(pixels, {'x': startingX, 'y': startingY, 'w': endX - startingX, 'h': endY - startingY}, function() { + }); + return newPixels; + } + + + function output(image, datauri, mimetype, wasmSuccess) { + step.output = { src: datauri, format: mimetype, wasmSuccess, useWasm: options.useWasm }; + } + return require('../_nomodule/PixelManipulation')(input, { + output: output, + ui: options.step.ui, + extraManipulation: extraManipulation, + format: input.format, + image: options.image, + inBrowser: options.inBrowser, + callback: callback, + useWasm:options.useWasm + }); + } + return { + options: options, + draw: draw, + output: output, + UI: UI + }; +}; diff --git a/src/modules/ConstrainedCrop/index.js b/src/modules/ConstrainedCrop/index.js new file mode 100644 index 0000000000..71549002ce --- /dev/null +++ b/src/modules/ConstrainedCrop/index.js @@ -0,0 +1,4 @@ +module.exports = [ + require('./Module'), + require('./info.json') +]; \ No newline at end of file diff --git a/src/modules/ConstrainedCrop/info.json b/src/modules/ConstrainedCrop/info.json new file mode 100644 index 0000000000..30115138b2 --- /dev/null +++ b/src/modules/ConstrainedCrop/info.json @@ -0,0 +1,23 @@ +{ + "name": "constrained-crop", + "description": "Crops an image in a particular aspect-ratio", + "inputs": { + "startingX": { + "type": "integer", + "desc": "X-position (measured from left) from where cropping starts", + "default": 0 + }, + "startingY": { + "type": "integer", + "desc": "Y-position (measured from top) from where cropping starts", + "default": 0 + }, + "aspectRatio":{ + "type": "string", + "desc": "Enter aspect ratio in following format width:height", + "default": "1:1" + } + }, + "docs-link":"" + } + \ No newline at end of file diff --git a/test/core/modules/constrained-crop.js b/test/core/modules/constrained-crop.js new file mode 100644 index 0000000000..6fafcf2f80 --- /dev/null +++ b/test/core/modules/constrained-crop.js @@ -0,0 +1,10 @@ +const testModule = require('../templates/module-test'), + benchmark = '', + image = require('../images/IS-QR'), + options = { + startingX : 100, + startingY : 100, + aspectRatio : '1:2' + }; + +testModule('constrained-crop', options, benchmark, image); \ No newline at end of file