in remove-background-web/main.js [59:100]
async function predict(url) {
// Read image
const image = await RawImage.fromURL(url);
// Update UI
imageContainer.innerHTML = "";
imageContainer.style.backgroundImage = `url(${url})`;
// Set container width and height depending on the image aspect ratio
const ar = image.width / image.height;
const [cw, ch] = ar > 720 / 480 ? [720, 720 / ar] : [480 * ar, 480];
imageContainer.style.width = `${cw}px`;
imageContainer.style.height = `${ch}px`;
status.textContent = "Analysing...";
// Preprocess image
const { pixel_values } = await processor(image);
// Predict alpha matte
const { output } = await model({ input: pixel_values });
// Resize mask back to original size
const mask = await RawImage.fromTensor(output[0].mul(255).to("uint8")).resize(
image.width,
image.height,
);
image.putAlpha(mask);
// Create new canvas
const canvas = document.createElement("canvas");
canvas.width = image.width;
canvas.height = image.height;
const ctx = canvas.getContext("2d");
ctx.drawImage(image.toCanvas(), 0, 0);
// Update UI
imageContainer.append(canvas);
imageContainer.style.removeProperty("background-image");
imageContainer.style.background = `url("")`;
status.textContent = "Done!";
}