tidy(ui): clean up unused logic

This commit is contained in:
psychedelicious 2024-08-07 17:32:57 +10:00
parent fa3560bb61
commit e5f2860b74
2 changed files with 12 additions and 303 deletions

View File

@ -11,12 +11,8 @@ import { CanvasProgressPreview } from 'features/controlLayers/konva/CanvasProgre
import type { CanvasRectRenderer } from 'features/controlLayers/konva/CanvasRect'; import type { CanvasRectRenderer } from 'features/controlLayers/konva/CanvasRect';
import type { CanvasTransformer } from 'features/controlLayers/konva/CanvasTransformer'; import type { CanvasTransformer } from 'features/controlLayers/konva/CanvasTransformer';
import { import {
getCompositeLayerImage,
getControlAdapterImage,
getImageDataTransparency, getImageDataTransparency,
getInpaintMaskImage,
getPrefixedId, getPrefixedId,
getRegionMaskImage,
konvaNodeToBlob, konvaNodeToBlob,
konvaNodeToImageData, konvaNodeToImageData,
nanoid, nanoid,
@ -722,22 +718,6 @@ export class CanvasManager {
} }
} }
getControlAdapterImage(arg: Omit<Parameters<typeof getControlAdapterImage>[0], 'manager'>) {
return getControlAdapterImage({ ...arg, manager: this });
}
getRegionMaskImage(arg: Omit<Parameters<typeof getRegionMaskImage>[0], 'manager'>) {
return getRegionMaskImage({ ...arg, manager: this });
}
getInpaintMaskImage(arg: Omit<Parameters<typeof getInpaintMaskImage>[0], 'manager'>) {
return getInpaintMaskImage({ ...arg, manager: this });
}
getInitialImage(arg: Omit<Parameters<typeof getCompositeLayerImage>[0], 'manager'>) {
return getCompositeLayerImage({ ...arg, manager: this });
}
getLoggingContext() { getLoggingContext() {
return { return {
// timestamp: new Date().toISOString(), // timestamp: new Date().toISOString(),

View File

@ -1,17 +1,8 @@
import type { CanvasManager } from 'features/controlLayers/konva/CanvasManager'; import type { CanvasObjectState, Coordinate, Rect, RgbaColor } from 'features/controlLayers/store/types';
import type {
CanvasObjectState,
Coordinate,
GenerationMode,
Rect,
RgbaColor,
} from 'features/controlLayers/store/types';
import { isValidLayer } from 'features/nodes/util/graph/generation/addLayers';
import Konva from 'konva'; import Konva from 'konva';
import type { KonvaEventObject } from 'konva/lib/Node'; import type { KonvaEventObject } from 'konva/lib/Node';
import type { Vector2d } from 'konva/lib/types'; import type { Vector2d } from 'konva/lib/types';
import { customAlphabet } from 'nanoid'; import { customAlphabet } from 'nanoid';
import type { ImageDTO } from 'services/api/types';
import { assert } from 'tsafe'; import { assert } from 'tsafe';
/** /**
@ -312,7 +303,7 @@ export const getPixelUnderCursor = (stage: Konva.Stage): RgbaColor | null => {
return { r, g, b, a }; return { r, g, b, a };
}; };
export const previewBlob = async (blob: Blob, label?: string) => { export const previewBlob = (blob: Blob, label?: string) => {
const url = URL.createObjectURL(blob); const url = URL.createObjectURL(blob);
const w = window.open(''); const w = window.open('');
if (!w) { if (!w) {
@ -325,99 +316,6 @@ export const previewBlob = async (blob: Blob, label?: string) => {
w.document.write(`<img src="${url}" style="border: 1px solid red;" />`); w.document.write(`<img src="${url}" style="border: 1px solid red;" />`);
}; };
export function getInpaintMaskLayerClone(arg: { manager: CanvasManager }): Konva.Layer {
const { manager } = arg;
const layerClone = manager.inpaintMask.konva.layer.clone();
const objectGroupClone = manager.inpaintMask.renderer.konva.objectGroup.clone();
layerClone.destroyChildren();
layerClone.add(objectGroupClone);
objectGroupClone.opacity(1);
objectGroupClone.cache();
return layerClone;
}
export function getRegionMaskLayerClone(arg: { manager: CanvasManager; id: string }): Konva.Layer {
const { id, manager } = arg;
const canvasRegion = manager.regions.get(id);
assert(canvasRegion, `Canvas region with id ${id} not found`);
const layerClone = canvasRegion.konva.layer.clone();
const objectGroupClone = canvasRegion.renderer.konva.objectGroup.clone();
layerClone.destroyChildren();
layerClone.add(objectGroupClone);
objectGroupClone.opacity(1);
objectGroupClone.cache();
return layerClone;
}
export function getControlAdapterLayerClone(arg: { manager: CanvasManager; id: string }): Konva.Layer {
const { id, manager } = arg;
const controlAdapter = manager.controlAdapters.get(id);
assert(controlAdapter, `Canvas region with id ${id} not found`);
const controlAdapterClone = controlAdapter.konva.layer.clone();
const objectGroupClone = controlAdapter.konva.group.clone();
controlAdapterClone.destroyChildren();
controlAdapterClone.add(objectGroupClone);
objectGroupClone.opacity(1);
objectGroupClone.cache();
return controlAdapterClone;
}
export function getInitialImageLayerClone(arg: { manager: CanvasManager }): Konva.Layer {
const { manager } = arg;
const initialImage = manager.initialImage;
const initialImageClone = initialImage.konva.layer.clone();
const objectGroupClone = initialImage.konva.group.clone();
initialImageClone.destroyChildren();
initialImageClone.add(objectGroupClone);
objectGroupClone.opacity(1);
objectGroupClone.cache();
return initialImageClone;
}
export function getCompositeLayerStageClone(arg: { manager: CanvasManager }): Konva.Stage {
const { manager } = arg;
const layersState = manager.stateApi.getLayersState();
const stageClone = manager.stage.clone();
stageClone.scaleX(1);
stageClone.scaleY(1);
stageClone.x(0);
stageClone.y(0);
const validLayers = layersState.entities.filter(isValidLayer);
console.log(validLayers);
// getLayers() returns the internal `children` array of the stage directly - calling destroy on a layer will
// mutate that array. We need to clone the array to avoid mutating the original.
for (const konvaLayer of stageClone.getLayers().slice()) {
if (!validLayers.find((l) => l.id === konvaLayer.id())) {
console.log('destroying', konvaLayer.id());
konvaLayer.destroy();
}
}
return stageClone;
}
export type Transparency = 'FULLY_TRANSPARENT' | 'PARTIALLY_TRANSPARENT' | 'OPAQUE'; export type Transparency = 'FULLY_TRANSPARENT' | 'PARTIALLY_TRANSPARENT' | 'OPAQUE';
export function getImageDataTransparency(imageData: ImageData): Transparency { export function getImageDataTransparency(imageData: ImageData): Transparency {
let isFullyTransparent = true; let isFullyTransparent = true;
@ -442,186 +340,17 @@ export function getImageDataTransparency(imageData: ImageData): Transparency {
return 'OPAQUE'; return 'OPAQUE';
} }
export function getGenerationMode(arg: { manager: CanvasManager }): GenerationMode { /**
const { manager } = arg; * Loads an image from a URL and returns a promise that resolves with the loaded image element.
const { x, y, width, height } = manager.stateApi.getBbox().rect; * @param src The image source URL
const inpaintMaskLayer = getInpaintMaskLayerClone(arg); * @returns A promise that resolves with the loaded image element
const inpaintMaskImageData = konvaNodeToImageData(inpaintMaskLayer, { x, y, width, height }); */
const inpaintMaskTransparency = getImageDataTransparency(inpaintMaskImageData); export function loadImage(src: string): Promise<HTMLImageElement> {
const compositeLayer = getCompositeLayerStageClone(arg);
const compositeLayerImageData = konvaNodeToImageData(compositeLayer, { x, y, width, height });
imageDataToBlob(compositeLayerImageData).then((blob) => {
previewBlob(blob, 'composite layer');
});
const compositeLayerTransparency = getImageDataTransparency(compositeLayerImageData);
if (compositeLayerTransparency.isPartiallyTransparent) {
if (compositeLayerTransparency.isFullyTransparent) {
return 'txt2img';
}
return 'outpaint';
} else {
if (!inpaintMaskTransparency.isFullyTransparent) {
return 'inpaint';
}
return 'img2img';
}
}
export async function getRegionMaskImage(arg: {
manager: CanvasManager;
id: string;
bbox?: Rect;
preview?: boolean;
}): Promise<ImageDTO> {
const { manager, id, bbox, preview = false } = arg;
const region = manager.stateApi.getRegionsState().entities.find((entity) => entity.id === id);
assert(region, `Region entity state with id ${id} not found`);
// if (region.imageCache) {
// const imageDTO = await this.util.getImageDTO(region.imageCache.name);
// if (imageDTO) {
// return imageDTO;
// }
// }
const layerClone = getRegionMaskLayerClone({ id, manager });
const blob = await konvaNodeToBlob(layerClone, bbox);
if (preview) {
previewBlob(blob, `region ${region.id} mask`);
}
layerClone.destroy();
const imageDTO = await manager.util.uploadImage(blob, `${region.id}_mask.png`, 'mask', true);
manager.stateApi.setRegionMaskImageCache(region.id, imageDTO);
return imageDTO;
}
export async function getControlAdapterImage(arg: {
manager: CanvasManager;
id: string;
bbox?: Rect;
preview?: boolean;
}): Promise<ImageDTO> {
const { manager, id, bbox, preview = false } = arg;
const ca = manager.stateApi.getControlAdaptersState().entities.find((entity) => entity.id === id);
assert(ca, `Control adapter entity state with id ${id} not found`);
// if (region.imageCache) {
// const imageDTO = await this.util.getImageDTO(region.imageCache.name);
// if (imageDTO) {
// return imageDTO;
// }
// }
const layerClone = getControlAdapterLayerClone({ id, manager });
const blob = await konvaNodeToBlob(layerClone, bbox);
if (preview) {
previewBlob(blob, `region ${ca.id} mask`);
}
layerClone.destroy();
const imageDTO = await manager.util.uploadImage(blob, `${ca.id}_control_image.png`, 'control', true);
// manager.stateApi.onRegionMaskImageCached(ca.id, imageDTO);
return imageDTO;
}
export async function getInitialImage(arg: {
manager: CanvasManager;
bbox?: Rect;
preview?: boolean;
}): Promise<ImageDTO> {
const { manager, bbox, preview = false } = arg;
// if (region.imageCache) {
// const imageDTO = await this.util.getImageDTO(region.imageCache.name);
// if (imageDTO) {
// return imageDTO;
// }
// }
const layerClone = getInitialImageLayerClone({ manager });
const blob = await konvaNodeToBlob(layerClone, bbox);
if (preview) {
previewBlob(blob, 'initial image');
}
layerClone.destroy();
const imageDTO = await manager.util.uploadImage(blob, 'initial_image.png', 'other', true);
// manager.stateApi.onRegionMaskImageCached(ca.id, imageDTO);
return imageDTO;
}
export async function getInpaintMaskImage(arg: {
manager: CanvasManager;
bbox?: Rect;
preview?: boolean;
}): Promise<ImageDTO> {
const { manager, bbox, preview = false } = arg;
// const inpaintMask = this.stateApi.getInpaintMaskState();
// if (inpaintMask.imageCache) {
// const imageDTO = await this.util.getImageDTO(inpaintMask.imageCache.name);
// if (imageDTO) {
// return imageDTO;
// }
// }
const layerClone = getInpaintMaskLayerClone({ manager });
const blob = await konvaNodeToBlob(layerClone, bbox);
if (preview) {
previewBlob(blob, 'inpaint mask');
}
layerClone.destroy();
const imageDTO = await manager.util.uploadImage(blob, 'inpaint_mask.png', 'mask', true);
manager.stateApi.setInpaintMaskImageCache(imageDTO);
return imageDTO;
}
export async function getCompositeLayerImage(arg: {
manager: CanvasManager;
bbox?: Rect;
preview?: boolean;
}): Promise<ImageDTO> {
const { manager, bbox, preview = false } = arg;
// const { imageCache } = this.stateApi.getLayersState();
// if (imageCache) {
// const imageDTO = await this.util.getImageDTO(imageCache.name);
// if (imageDTO) {
// return imageDTO;
// }
// }
const stageClone = getCompositeLayerStageClone({ manager });
const blob = await konvaNodeToBlob(stageClone, bbox);
if (preview) {
previewBlob(blob, 'image source');
}
stageClone.destroy();
const imageDTO = await manager.util.uploadImage(blob, 'base_layer.png', 'general', true);
manager.stateApi.setLayerImageCache(imageDTO);
return imageDTO;
}
export function loadImage(src: string, imageEl?: HTMLImageElement): Promise<HTMLImageElement> {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
const _imageEl = imageEl ?? new Image(); const imageElement = new Image();
_imageEl.onload = () => resolve(_imageEl); imageElement.onload = () => resolve(imageElement);
_imageEl.onerror = (error) => reject(error); imageElement.onerror = (error) => reject(error);
_imageEl.src = src; imageElement.src = src;
}); });
} }