mirror of
https://github.com/upscayl/upscayl.git
synced 2025-01-18 17:14:08 +01:00
Fix sharp pixel limit and compression and macos quit
This commit is contained in:
parent
737ab925d4
commit
b620c568b6
@ -46,9 +46,7 @@ app.on("ready", async () => {
|
||||
|
||||
// Quit the app once all windows are closed
|
||||
app.on("window-all-closed", () => {
|
||||
if (process.platform !== "darwin") {
|
||||
app.quit();
|
||||
}
|
||||
app.quit();
|
||||
});
|
||||
|
||||
ipcMain.on(COMMAND.STOP, stop);
|
||||
|
@ -98,19 +98,15 @@ const createMainWindow = () => {
|
||||
setSaveOutputFolder(lastSaveOutputFolder);
|
||||
}
|
||||
});
|
||||
// GET IMAGE QUALITY (NUMBER) TO LOCAL STORAGE
|
||||
// GET IMAGE COMPRESSION (NUMBER) FROM LOCAL STORAGE
|
||||
mainWindow.webContents
|
||||
.executeJavaScript('localStorage.getItem("quality");', true)
|
||||
.then((lastSavedQuality: string | null) => {
|
||||
if (lastSavedQuality !== null) {
|
||||
if (parseInt(lastSavedQuality) === 100) {
|
||||
setCompression(99);
|
||||
} else {
|
||||
setCompression(parseInt(lastSavedQuality));
|
||||
}
|
||||
.executeJavaScript('localStorage.getItem("compression");', true)
|
||||
.then((lastSavedCompression: string | null) => {
|
||||
if (lastSavedCompression !== null) {
|
||||
setCompression(parseInt(lastSavedCompression));
|
||||
}
|
||||
});
|
||||
// GET IMAGE QUALITY (NUMBER) TO LOCAL STORAGE
|
||||
// GET OVERWRITE (BOOLEAN) FROM LOCAL STORAGE
|
||||
mainWindow.webContents
|
||||
.executeJavaScript('localStorage.getItem("overwrite");', true)
|
||||
.then((lastSavedOverwrite: string | null) => {
|
||||
|
@ -18,23 +18,29 @@ const convertAndScale = async (
|
||||
throw new Error("Could not grab the original image!");
|
||||
}
|
||||
// Resize the image to the scale
|
||||
const newImage = sharp(upscaledImagePath)
|
||||
const newImage = sharp(upscaledImagePath, {
|
||||
limitInputPixels: false,
|
||||
})
|
||||
.resize(
|
||||
originalImage.width && originalImage.width * parseInt(scale),
|
||||
originalImage.height && originalImage.height * parseInt(scale)
|
||||
)
|
||||
.withMetadata(); // Keep metadata
|
||||
// Convert compression percentage (0-100) to compressionLevel (0-9)
|
||||
const compressionLevel = Math.round((compression / 100) * 9);
|
||||
// Change the output according to the saveImageAs
|
||||
if (saveImageAs === "png") {
|
||||
newImage.png({ quality: 100 - compression });
|
||||
newImage.png({ compressionLevel });
|
||||
} else if (saveImageAs === "jpg") {
|
||||
console.log("Quality: ", compression);
|
||||
newImage.jpeg({ quality: 100 - compression });
|
||||
console.log("compression: ", compression);
|
||||
newImage.jpeg({ quality: compression });
|
||||
}
|
||||
// Save the image
|
||||
const buffer = await newImage.toBuffer();
|
||||
try {
|
||||
await sharp(buffer).toFile(processedImagePath);
|
||||
await sharp(buffer, {
|
||||
limitInputPixels: false,
|
||||
}).toFile(processedImagePath);
|
||||
} catch (error) {
|
||||
logit("❌ Error converting to: ", saveImageAs, error);
|
||||
onError(error);
|
||||
|
@ -1,12 +1,12 @@
|
||||
type QualityInputProps = {
|
||||
type CompressionInputProps = {
|
||||
compression: number;
|
||||
handleQualityChange: (arg: any) => void;
|
||||
handleCompressionChange: (arg: any) => void;
|
||||
};
|
||||
|
||||
export function QualityInput({
|
||||
export function CompressionInput({
|
||||
compression,
|
||||
handleQualityChange,
|
||||
}: QualityInputProps) {
|
||||
handleCompressionChange,
|
||||
}: CompressionInputProps) {
|
||||
return (
|
||||
<div className="flex flex-col gap-2">
|
||||
<div className="flex gap-1 text-sm font-medium uppercase">
|
||||
@ -22,7 +22,7 @@ export function QualityInput({
|
||||
min={0}
|
||||
max={100}
|
||||
value={compression}
|
||||
onChange={handleQualityChange}
|
||||
onChange={handleCompressionChange}
|
||||
/>
|
||||
</div>
|
||||
);
|
@ -12,7 +12,7 @@ import { useAtom, useAtomValue } from "jotai";
|
||||
import { customModelsPathAtom, scaleAtom } from "../../atoms/userSettingsAtom";
|
||||
import { modelsListAtom } from "../../atoms/modelsListAtom";
|
||||
import useLog from "../hooks/useLog";
|
||||
import { QualityInput } from "./QualityInput";
|
||||
import { CompressionInput } from "./CompressionInput";
|
||||
import ToggleOverwrite from "./ToggleOverwrite";
|
||||
import { UpscaylCloudModal } from "../UpscaylCloudModal";
|
||||
import { ResetSettings } from "./ResetSettings";
|
||||
@ -126,14 +126,14 @@ function SettingsTab({
|
||||
);
|
||||
}
|
||||
|
||||
if (!localStorage.getItem("quality")) {
|
||||
logit("⚙️ Setting quality to 100%");
|
||||
localStorage.setItem("quality", JSON.stringify(compression));
|
||||
if (!localStorage.getItem("compression")) {
|
||||
logit("⚙️ Setting compression to 100%");
|
||||
localStorage.setItem("compression", JSON.stringify(compression));
|
||||
} else {
|
||||
const currentlySavedQuality = localStorage.getItem("quality");
|
||||
logit("⚙️ Getting quality from localStorage", compression);
|
||||
if (currentlySavedQuality) {
|
||||
setCompression(JSON.parse(currentlySavedQuality));
|
||||
const currentlySavedCompression = localStorage.getItem("compression");
|
||||
logit("⚙️ Getting compression from localStorage", compression);
|
||||
if (currentlySavedCompression) {
|
||||
setCompression(JSON.parse(currentlySavedCompression));
|
||||
}
|
||||
}
|
||||
}, []);
|
||||
@ -144,9 +144,9 @@ function SettingsTab({
|
||||
localStorage.setItem("saveImageAs", format);
|
||||
};
|
||||
|
||||
const handleQualityChange = (e) => {
|
||||
const handleCompressionChange = (e) => {
|
||||
setCompression(e.target.value);
|
||||
localStorage.setItem("quality", e.target.value);
|
||||
localStorage.setItem("compression", e.target.value);
|
||||
};
|
||||
|
||||
const handleGpuIdChange = (e) => {
|
||||
@ -194,9 +194,9 @@ function SettingsTab({
|
||||
{/* IMAGE SCALE */}
|
||||
<ImageScaleSelect scale={scale} setScale={setScale} />
|
||||
|
||||
<QualityInput
|
||||
<CompressionInput
|
||||
compression={compression}
|
||||
handleQualityChange={handleQualityChange}
|
||||
handleCompressionChange={handleCompressionChange}
|
||||
/>
|
||||
|
||||
<SaveOutputFolderToggle
|
||||
|
@ -19,7 +19,7 @@ module.exports = {
|
||||
},
|
||||
plugins: [require("daisyui"), require("tailwind-scrollbar")],
|
||||
daisyui: {
|
||||
darkTheme: 'upscayl',
|
||||
darkTheme: "upscayl",
|
||||
themes: [
|
||||
{
|
||||
upscayl: {
|
||||
|
Loading…
x
Reference in New Issue
Block a user