Files
threetwo-core-service/utils/imagetransformation.utils.ts
2022-05-03 08:47:11 -07:00

99 lines
2.3 KiB
TypeScript

const sharp = require("sharp");
import { ISharpResizedImageStats } from "threetwo-ui-typings";
const imghash = require("imghash");
const leven = require("leven");
import { isNull, reject } from "lodash";
import Jimp from "jimp";
export const extractMetadataFromImage = async (
imageFilePath: string
): Promise<unknown> => {
const image = await sharp(imageFilePath)
.metadata()
.then((metadata) => {
return metadata;
});
return image;
};
export const resizeImage = async (
imageFile: string | Buffer,
outputPath: string,
newWidth: number,
newHeight?: number
): Promise<ISharpResizedImageStats> => {
const buffer = await sharp(imageFile)
.resize(newWidth, newHeight, {
fit: sharp.fit.inside,
withoutEnlargement: true,
})
.toBuffer();
return await sharp(buffer).toFile(`${outputPath}`, (err, info) => {
if (err) {
console.log("Failed to resize image:");
console.log(err);
return err;
}
console.log(
"Image file resized with the following parameters: %o",
info
);
return info;
});
};
export const analyze = async (inputFilePath: string | Buffer) => {
const stats = await sharp(inputFilePath).stats();
// const { r, g, b } = dominant;
return stats;
};
export const getColorHistogramData = async (
inputFilePath: string | Buffer,
isValueHistogram: Boolean
) => {
return new Promise(async (resolve, reject) => {
sharp(inputFilePath)
.toBuffer()
.then((new_image) => {
let index = 0;
let rgb_values = { r: [], g: [], b: [] };
while (index < new_image.length) {
let point = {
red: new_image[index] & 0xFF,
green: (new_image[index + 1] >> 8) & 0xFF,
blue: (new_image[index + 2] >> 16) & 0xFF,
};
rgb_values.r.push(point.red);
rgb_values.g.push(point.green);
rgb_values.b.push(point.blue);
index = index + 3;
}
console.log(rgb_values);
resolve(rgb_values);
})
.catch((e) => {
reject(e);
});
});
};
export const calculateLevenshteinDistance = async (
imagePath1: string,
imagePath2: string
): Promise<Record<string, unknown>> => {
const hash1 = await imghash.hash(imagePath1);
const hash2 = await imghash.hash(imagePath2);
if (!isNull(hash1) && !isNull(hash2)) {
return new Promise((resolve, reject) => {
resolve({ levenshteinDistance: leven(hash1, hash2) });
});
} else {
reject("Can't calculate the Levenshtein distance");
}
};