This repository has been archived on 2024-10-29. You can view files and clone it, but cannot push or open issues or pull requests.
scoresaber-reloadedv3/src/common/image-utils.ts
Liam dccda18b49
Some checks failed
Deploy / deploy (push) Failing after 41s
oopsie doodle
2024-09-30 08:48:58 +01:00

58 lines
1.7 KiB
TypeScript

import {createCanvas, loadImage} from "canvas";
import {config} from "../../config";
import ky from "ky";
import {extractColors} from "extract-colors";
import {cache} from "react";
/**
* Proxies all non-localhost images to make them load faster.
*
* @param originalUrl the original image url
* @returns the new image url
*/
export function getImageUrl(originalUrl: string) {
return `${!config.siteUrl.includes("localhost") ? "https://img.fascinated.cc/upload/q_70/" : ""}${originalUrl}`;
}
/**
* Gets the average color of an image
*
* @param src the image url
* @returns the average color
*/
export const getAverageColor = cache(async (src: string) => {
const before = performance.now();
console.log(`Getting average color of "${src}"...`);
try {
const response = await ky.get(src);
if (response.status !== 200) {
return undefined;
}
const imageBuffer = await response.arrayBuffer();
// Create an image from the buffer using canvas
const img = await loadImage(Buffer.from(imageBuffer));
const canvas = createCanvas(img.width, img.height);
const ctx = canvas.getContext("2d");
// Draw the image onto the canvas
ctx.drawImage(img, 0, 0);
// Get the pixel data from the canvas
const imageData = ctx.getImageData(0, 0, img.width, img.height);
const { data, width, height } = imageData;
// Use your extractColors function to calculate the average color
const color = await extractColors({ data, width, height });
console.log(
`Found average color of "${src}" in ${(performance.now() - before).toFixed(0)}ms`,
);
return color[2];
} catch (error) {
console.error("Error while getting average color:", error);
return undefined;
}
});