1
0
mirror of https://github.com/upscayl/upscayl.git synced 2025-01-18 09:04:48 +01:00
upscayl/electron/commands/double-upscayl.ts

227 lines
6.5 KiB
TypeScript
Raw Normal View History

import path, { parse } from "path";
import { getMainWindow } from "../main-window";
import {
childProcesses,
2024-04-09 23:41:24 +05:30
savedCustomModelsPath,
2023-09-19 20:34:31 +05:30
noImageProcessing,
2024-04-09 23:41:24 +05:30
savedOutputPath,
rememberOutputFolder,
2023-11-23 11:09:46 +05:30
setCompression,
2023-11-22 21:24:02 +05:30
setNoImageProcessing,
setStopped,
stopped,
} from "../utils/config-variables";
import slash from "../utils/slash";
import { spawnUpscayl } from "../utils/spawn-upscayl";
import {
getDoubleUpscaleArguments,
getDoubleUpscaleSecondPassArguments,
} from "../utils/get-arguments";
import { modelsPath } from "../utils/get-resource-paths";
import logit from "../utils/logit";
import COMMAND from "../../common/commands";
2023-11-22 21:24:02 +05:30
import { DoubleUpscaylPayload } from "../../common/types/types";
import { ImageFormat } from "../utils/types";
import showNotification from "../utils/show-notification";
import { DEFAULT_MODELS } from "../../common/models-list";
2023-11-22 21:24:02 +05:30
const doubleUpscayl = async (event, payload: DoubleUpscaylPayload) => {
const mainWindow = getMainWindow();
if (!mainWindow) return;
const model = payload.model as string;
const imagePath = payload.imagePath;
let inputDir = (imagePath.match(/(.*)[\/\\]/) || [""])[1];
let outputDir = path.normalize(payload.outputPath);
2024-04-09 23:41:24 +05:30
if (rememberOutputFolder === true && savedOutputPath) {
outputDir = savedOutputPath;
}
const gpuId = payload.gpuId as string;
const saveImageAs = payload.saveImageAs as ImageFormat;
2023-11-22 21:24:02 +05:30
setNoImageProcessing(payload.noImageProcessing);
2023-11-23 11:09:46 +05:30
setCompression(parseInt(payload.compression));
2023-11-22 21:24:02 +05:30
const isDefaultModel = DEFAULT_MODELS.includes(model);
// COPY IMAGE TO TMP FOLDER
const fullfileName = imagePath.split(slash).slice(-1)[0] as string;
const fileName = parse(fullfileName).name;
2024-04-09 23:41:24 +05:30
const scale = parseInt(payload.scale) * parseInt(payload.scale);
2024-04-20 21:14:42 +05:30
const customWidth = payload.customWidth;
const useCustomWidth = payload.useCustomWidth;
2023-09-11 09:27:16 +05:30
const outFile =
outputDir +
slash +
fileName +
"_upscayl_" +
2024-04-20 21:14:42 +05:30
(scale ? scale : "") +
2024-02-08 20:27:35 +05:30
(useCustomWidth ? "px_" : "x_") +
2023-09-11 09:27:16 +05:30
model +
"." +
saveImageAs;
// UPSCALE
let upscayl = spawnUpscayl(
2024-04-09 23:41:24 +05:30
getDoubleUpscaleArguments({
inputDir,
fullfileName,
outFile,
2024-04-09 23:41:24 +05:30
modelsPath: isDefaultModel
? modelsPath
: savedCustomModelsPath ?? modelsPath,
model,
gpuId,
saveImageAs,
2024-04-09 23:41:24 +05:30
scale: scale.toString(),
}),
2024-02-08 20:27:35 +05:30
logit,
);
childProcesses.push(upscayl);
setStopped(false);
let failed = false;
let isAlpha = false;
let failed2 = false;
const onData = (data) => {
if (!mainWindow) return;
// CONVERT DATA TO STRING
data = data.toString();
// SEND UPSCAYL PROGRESS TO RENDERER
mainWindow.webContents.send(COMMAND.DOUBLE_UPSCAYL_PROGRESS, data);
// IF PROGRESS HAS ERROR, UPSCAYL FAILED
2024-04-09 00:17:08 +05:30
if (data.includes("Error") || data.includes("failed")) {
upscayl.kill();
failed = true;
}
2024-04-09 00:17:08 +05:30
if (data.includes("alpha channel")) {
isAlpha = true;
}
};
const onError = (data) => {
if (!mainWindow) return;
mainWindow.setProgressBar(-1);
data.toString();
// SEND UPSCAYL PROGRESS TO RENDERER
mainWindow.webContents.send(COMMAND.DOUBLE_UPSCAYL_PROGRESS, data);
// SET FAILED TO TRUE
failed = true;
mainWindow &&
mainWindow.webContents.send(
COMMAND.UPSCAYL_ERROR,
2024-02-08 20:27:35 +05:30
"Error upscaling image. Error: " + data,
);
showNotification("Upscayl Failure", "Failed to upscale image!");
upscayl.kill();
return;
};
const onClose2 = async (code) => {
if (!mainWindow) return;
if (!failed2 && !stopped) {
logit("💯 Done upscaling");
logit("♻ Scaling and converting now...");
mainWindow.webContents.send(COMMAND.SCALING_AND_CONVERTING);
2023-09-19 20:34:31 +05:30
if (noImageProcessing) {
logit("🚫 Skipping scaling and converting");
mainWindow.setProgressBar(-1);
mainWindow.webContents.send(
COMMAND.DOUBLE_UPSCAYL_DONE,
2024-04-09 00:17:08 +05:30
outFile.replace(
/([^/\\]+)$/i,
encodeURIComponent(outFile.match(/[^/\\]+$/i)![0]),
),
2023-09-19 20:34:31 +05:30
);
return;
}
try {
mainWindow.setProgressBar(-1);
mainWindow.webContents.send(
COMMAND.DOUBLE_UPSCAYL_DONE,
outFile.replace(
/([^/\\]+)$/i,
2024-02-08 20:27:35 +05:30
encodeURIComponent(outFile.match(/[^/\\]+$/i)![0]),
),
);
showNotification("Upscayled", "Image upscayled successfully!");
} catch (error) {
logit("❌ Error reading original image metadata", error);
mainWindow &&
mainWindow.webContents.send(
COMMAND.UPSCAYL_ERROR,
2023-10-14 14:11:57 +05:30
"Error processing (scaling and converting) the image. Please report this error on Upscayl GitHub Issues page.\n" +
2024-02-08 20:27:35 +05:30
error,
);
showNotification("Upscayl Failure", "Failed to upscale image!");
upscayl.kill();
}
}
};
upscayl.process.stderr.on("data", onData);
upscayl.process.on("error", onError);
upscayl.process.on("close", (code) => {
// IF NOT FAILED
if (!failed && !stopped) {
// UPSCALE
let upscayl2 = spawnUpscayl(
2024-04-09 23:41:24 +05:30
getDoubleUpscaleSecondPassArguments({
isAlpha,
outFile,
2024-04-09 23:41:24 +05:30
modelsPath: isDefaultModel
? modelsPath
: savedCustomModelsPath ?? modelsPath,
model,
gpuId,
saveImageAs,
2024-04-09 23:41:24 +05:30
scale: scale.toString(),
2024-04-20 21:14:42 +05:30
customWidth,
2024-04-09 23:41:24 +05:30
}),
2024-02-08 20:27:35 +05:30
logit,
);
childProcesses.push(upscayl2);
upscayl2.process.stderr.on("data", (data) => {
if (!mainWindow) return;
// CONVERT DATA TO STRING
data = data.toString();
// SEND UPSCAYL PROGRESS TO RENDERER
mainWindow.webContents.send(COMMAND.DOUBLE_UPSCAYL_PROGRESS, data);
// IF PROGRESS HAS ERROR, UPSCAYL FAILED
if (data.includes("invalid gpu") || data.includes("failed")) {
upscayl2.kill();
failed2 = true;
}
});
upscayl2.process.on("error", (data) => {
if (!mainWindow) return;
data.toString();
// SEND UPSCAYL PROGRESS TO RENDERER
mainWindow.webContents.send(COMMAND.DOUBLE_UPSCAYL_PROGRESS, data);
// SET FAILED TO TRUE
failed2 = true;
mainWindow &&
mainWindow.webContents.send(
COMMAND.UPSCAYL_ERROR,
2024-02-08 20:27:35 +05:30
"Error upscaling image. Error: " + data,
);
showNotification("Upscayl Failure", "Failed to upscale image!");
upscayl2.kill();
return;
});
upscayl2.process.on("close", onClose2);
}
});
};
export default doubleUpscayl;