reformat cli/main.ts
This commit is contained in:
parent
14efcf03a1
commit
a656d37d8c
1 changed files with 29 additions and 13 deletions
34
cli/main.ts
34
cli/main.ts
|
@ -1,17 +1,27 @@
|
|||
import { parse } from "https://deno.land/std@0.106.0/flags/mod.ts";
|
||||
import { createCanvas, loadImage } from "https://deno.land/x/canvas/mod.ts";
|
||||
import { CollageModes, CollageModeType, collageModeType } from "../src/common/collages.ts";
|
||||
import DenoCollageModes, { CastCanvasRenderingContext, ProxyImage } from "./collages.ts";
|
||||
import {
|
||||
CollageModes,
|
||||
CollageModeType,
|
||||
collageModeType,
|
||||
} from "../src/common/collages.ts";
|
||||
import DenoCollageModes, {
|
||||
CastCanvasRenderingContext,
|
||||
ProxyImage,
|
||||
} from "./collages.ts";
|
||||
import { CollageConfig } from "../src/common/types.ts";
|
||||
import { choice, shuffle } from "../src/common/utils.ts";
|
||||
|
||||
const args = parse(Deno.args, {
|
||||
alias: {
|
||||
'o': 'output'
|
||||
}
|
||||
"o": "output",
|
||||
},
|
||||
});
|
||||
|
||||
const images: ProxyImage[] = (await Promise.all(args["_"].map((imageURL) => loadImage(imageURL.toString())))).map((image) => new ProxyImage(image));
|
||||
const images: ProxyImage[] =
|
||||
(await Promise.all(
|
||||
args["_"].map((imageURL) => loadImage(imageURL.toString())),
|
||||
)).map((image) => new ProxyImage(image));
|
||||
|
||||
if (images.length < 2) {
|
||||
console.error("kollagen needs at least 2 images to work.");
|
||||
|
@ -23,18 +33,24 @@ const modes = new DenoCollageModes();
|
|||
const modeKey: CollageModeType = args["mode"] || choice(collageModeType);
|
||||
const mode = modes.modes[modeKey];
|
||||
|
||||
console.log(`Creating a "${mode.name}" collage from ${images.length} images...`);
|
||||
console.log(
|
||||
`Creating a "${mode.name}" collage from ${images.length} images...`,
|
||||
);
|
||||
console.debug(`Images: ${args["_"].join(", ")}`);
|
||||
|
||||
const canvas = createCanvas(args["width"] || 640, args["height"] || 640);
|
||||
const context = canvas.getContext("2d");
|
||||
|
||||
const collageConfig: CollageConfig = {
|
||||
numImages: args["n"]
|
||||
}
|
||||
numImages: args["n"],
|
||||
};
|
||||
|
||||
const shuffledImages = shuffle(images);
|
||||
const segments = mode.getSegments(context as CastCanvasRenderingContext, collageConfig, shuffledImages);
|
||||
const segments = mode.getSegments(
|
||||
context as CastCanvasRenderingContext,
|
||||
collageConfig,
|
||||
shuffledImages,
|
||||
);
|
||||
mode.place(context as CastCanvasRenderingContext, shuffledImages, segments);
|
||||
|
||||
const output = args["output"] || "collage.png";
|
||||
|
|
Loading…
Reference in a new issue