123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- /**
- * @author j433866 [j433866@gmail.com]
- * @copyright Crown Copyright 2019
- * @license Apache-2.0
- */
- import Operation from "../Operation.mjs";
- import OperationError from "../errors/OperationError.mjs";
- import { isImage } from "../lib/FileType.mjs";
- import { toBase64 } from "../lib/Base64.mjs";
- import { isWorkerEnvironment } from "../Utils.mjs";
- import jimp from "jimp";
- /**
- * Image Opacity operation
- */
- class ImageOpacity extends Operation {
- /**
- * ImageOpacity constructor
- */
- constructor() {
- super();
- this.name = "Image Opacity";
- this.module = "Image";
- this.description = "Adjust the opacity of an image.";
- this.infoURL = "";
- this.inputType = "ArrayBuffer";
- this.outputType = "ArrayBuffer";
- this.presentType = "html";
- this.args = [
- {
- name: "Opacity (%)",
- type: "number",
- value: 100,
- min: 0,
- max: 100
- }
- ];
- }
- /**
- * @param {ArrayBuffer} input
- * @param {Object[]} args
- * @returns {byteArray}
- */
- async run(input, args) {
- const [opacity] = args;
- if (!isImage(input)) {
- throw new OperationError("Invalid file type.");
- }
- let image;
- try {
- image = await jimp.read(input);
- } catch (err) {
- throw new OperationError(`Error loading image. (${err})`);
- }
- try {
- if (isWorkerEnvironment())
- self.sendStatusMessage("Changing image opacity...");
- image.opacity(opacity / 100);
- let imageBuffer;
- if (image.getMIME() === "image/gif") {
- imageBuffer = await image.getBufferAsync(jimp.MIME_PNG);
- } else {
- imageBuffer = await image.getBufferAsync(jimp.AUTO);
- }
- return imageBuffer.buffer;
- } catch (err) {
- throw new OperationError(`Error changing image opacity. (${err})`);
- }
- }
- /**
- * Displays the image using HTML for web apps
- * @param {ArrayBuffer} data
- * @returns {html}
- */
- present(data) {
- if (!data.byteLength) return "";
- const dataArray = new Uint8Array(data);
- const type = isImage(dataArray);
- if (!type) {
- throw new OperationError("Invalid file type.");
- }
- return `<img src="data:${type};base64,${toBase64(dataArray)}">`;
- }
- }
- export default ImageOpacity;
|