From 0af8a0e84b5041274e8a0bb9a3b03f6dc204f1c0 Mon Sep 17 00:00:00 2001
From: blessedcoolant <54517381+blessedcoolant@users.noreply.github.com>
Date: Thu, 24 Aug 2023 04:40:59 +1200
Subject: [PATCH] feat: Replace Seam Painting with Refine Pass for Outpainting
---
invokeai/frontend/web/public/locales/en.json | 9 +-
.../graphBuilders/buildCanvasOutpaintGraph.ts | 178 +++---------------
.../nodes/util/graphBuilders/constants.ts | 2 +
.../SeamPainting/ParamRefinePassCollapse.tsx | 21 +++
...aramSeamSteps.tsx => ParamRefineSteps.tsx} | 18 +-
...amStrength.tsx => ParamRefineStrength.tsx} | 18 +-
.../Canvas/SeamPainting/ParamSeamBlur.tsx | 36 ----
.../ParamSeamPaintingCollapse.tsx | 27 ---
.../Canvas/SeamPainting/ParamSeamSize.tsx | 36 ----
.../SeamPainting/ParamSeamThreshold.tsx | 121 ------------
.../parameters/store/generationSlice.ts | 44 +----
.../SDXLUnifiedCanvasTabParameters.tsx | 4 +-
.../UnifiedCanvas/UnifiedCanvasParameters.tsx | 8 +-
13 files changed, 87 insertions(+), 435 deletions(-)
create mode 100644 invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefinePassCollapse.tsx
rename invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/{ParamSeamSteps.tsx => ParamRefineSteps.tsx} (60%)
rename invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/{ParamSeamStrength.tsx => ParamRefineStrength.tsx} (58%)
delete mode 100644 invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamBlur.tsx
delete mode 100644 invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamPaintingCollapse.tsx
delete mode 100644 invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamSize.tsx
delete mode 100644 invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamThreshold.tsx
diff --git a/invokeai/frontend/web/public/locales/en.json b/invokeai/frontend/web/public/locales/en.json
index 7d426efbb6..0bddc07bac 100644
--- a/invokeai/frontend/web/public/locales/en.json
+++ b/invokeai/frontend/web/public/locales/en.json
@@ -509,12 +509,9 @@
"maskAdjustmentsHeader": "Mask Adjustments",
"maskBlur": "Mask Blur",
"maskBlurMethod": "Mask Blur Method",
- "seamPaintingHeader": "Seam Painting",
- "seamSize": "Seam Size",
- "seamBlur": "Seam Blur",
- "seamSteps": "Seam Steps",
- "seamStrength": "Seam Strength",
- "seamThreshold": "Seam Threshold",
+ "refinePassHeader": "Refine Pass",
+ "refineSteps": "Refine Steps",
+ "refineStrength": "Refine Strength",
"seamLowThreshold": "Low",
"seamHighThreshold": "High",
"scaleBeforeProcessing": "Scale Before Processing",
diff --git a/invokeai/frontend/web/src/features/nodes/util/graphBuilders/buildCanvasOutpaintGraph.ts b/invokeai/frontend/web/src/features/nodes/util/graphBuilders/buildCanvasOutpaintGraph.ts
index e5216dacb2..ecdd5ce556 100644
--- a/invokeai/frontend/web/src/features/nodes/util/graphBuilders/buildCanvasOutpaintGraph.ts
+++ b/invokeai/frontend/web/src/features/nodes/util/graphBuilders/buildCanvasOutpaintGraph.ts
@@ -20,7 +20,6 @@ import {
CANVAS_OUTPAINT_GRAPH,
CANVAS_OUTPUT,
CLIP_SKIP,
- COLOR_CORRECT,
DENOISE_LATENTS,
INPAINT_IMAGE,
INPAINT_IMAGE_RESIZE_DOWN,
@@ -32,16 +31,15 @@ import {
MAIN_MODEL_LOADER,
MASK_BLUR,
MASK_COMBINE,
- MASK_EDGE,
MASK_FROM_ALPHA,
MASK_RESIZE_DOWN,
MASK_RESIZE_UP,
NEGATIVE_CONDITIONING,
NOISE,
+ OUTPAINT_REFINE_DENOISE_LATENTS,
POSITIVE_CONDITIONING,
RANDOM_INT,
RANGE_OF_SIZE,
- SEAM_FIX_DENOISE_LATENTS,
SEAM_MASK_RESIZE_UP,
} from './constants';
@@ -70,12 +68,8 @@ export const buildCanvasOutpaintGraph = (
shouldUseCpuNoise,
maskBlur,
maskBlurMethod,
- seamSize,
- seamBlur,
- seamSteps,
- seamStrength,
- seamLowThreshold,
- seamHighThreshold,
+ refineSteps,
+ refineStrength,
tileSize,
infillMethod,
clipSkip,
@@ -174,23 +168,23 @@ export const buildCanvasOutpaintGraph = (
denoising_start: 1 - strength,
denoising_end: 1,
},
- [MASK_EDGE]: {
- type: 'mask_edge',
- id: MASK_EDGE,
- is_intermediate: true,
- edge_size: seamSize,
- edge_blur: seamBlur,
- low_threshold: seamLowThreshold,
- high_threshold: seamHighThreshold,
- },
- [SEAM_FIX_DENOISE_LATENTS]: {
+ // [MASK_EDGE]: {
+ // type: 'mask_edge',
+ // id: MASK_EDGE,
+ // is_intermediate: true,
+ // edge_size: seamSize,
+ // edge_blur: seamBlur,
+ // low_threshold: seamLowThreshold,
+ // high_threshold: seamHighThreshold,
+ // },
+ [OUTPAINT_REFINE_DENOISE_LATENTS]: {
type: 'denoise_latents',
- id: SEAM_FIX_DENOISE_LATENTS,
+ id: OUTPAINT_REFINE_DENOISE_LATENTS,
is_intermediate: true,
- steps: seamSteps,
+ steps: refineSteps,
cfg_scale: cfg_scale,
scheduler: scheduler,
- denoising_start: 1 - seamStrength,
+ denoising_start: 1 - refineStrength,
denoising_end: 1,
},
[LATENTS_TO_IMAGE]: {
@@ -199,13 +193,8 @@ export const buildCanvasOutpaintGraph = (
is_intermediate: true,
fp32: vaePrecision === 'fp32' ? true : false,
},
- [COLOR_CORRECT]: {
- type: 'color_correct',
- id: COLOR_CORRECT,
- is_intermediate: true,
- },
[CANVAS_OUTPUT]: {
- type: 'img_paste',
+ type: 'color_correct',
id: CANVAS_OUTPUT,
is_intermediate: !shouldAutoSave,
},
@@ -361,24 +350,25 @@ export const buildCanvasOutpaintGraph = (
field: 'seed',
},
},
- // Seam Paint
+ // Image To Image Clean Up
{
source: {
node_id: MAIN_MODEL_LOADER,
field: 'unet',
},
destination: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
+ node_id: OUTPAINT_REFINE_DENOISE_LATENTS,
field: 'unet',
},
},
+
{
source: {
node_id: POSITIVE_CONDITIONING,
field: 'conditioning',
},
destination: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
+ node_id: OUTPAINT_REFINE_DENOISE_LATENTS,
field: 'positive_conditioning',
},
},
@@ -388,7 +378,7 @@ export const buildCanvasOutpaintGraph = (
field: 'conditioning',
},
destination: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
+ node_id: OUTPAINT_REFINE_DENOISE_LATENTS,
field: 'negative_conditioning',
},
},
@@ -398,7 +388,7 @@ export const buildCanvasOutpaintGraph = (
field: 'noise',
},
destination: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
+ node_id: OUTPAINT_REFINE_DENOISE_LATENTS,
field: 'noise',
},
},
@@ -408,14 +398,14 @@ export const buildCanvasOutpaintGraph = (
field: 'latents',
},
destination: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
+ node_id: OUTPAINT_REFINE_DENOISE_LATENTS,
field: 'latents',
},
},
// Decode the result from Inpaint
{
source: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
+ node_id: OUTPAINT_REFINE_DENOISE_LATENTS,
field: 'latents',
},
destination: {
@@ -525,37 +515,6 @@ export const buildCanvasOutpaintGraph = (
field: 'image',
},
},
- // Seam Paint Mask
- {
- source: {
- node_id: MASK_FROM_ALPHA,
- field: 'image',
- },
- destination: {
- node_id: MASK_EDGE,
- field: 'image',
- },
- },
- {
- source: {
- node_id: MASK_EDGE,
- field: 'image',
- },
- destination: {
- node_id: SEAM_MASK_RESIZE_UP,
- field: 'image',
- },
- },
- {
- source: {
- node_id: SEAM_MASK_RESIZE_UP,
- field: 'image',
- },
- destination: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
- field: 'mask',
- },
- },
// Resize Results Down
{
source: {
@@ -594,7 +553,7 @@ export const buildCanvasOutpaintGraph = (
field: 'image',
},
destination: {
- node_id: COLOR_CORRECT,
+ node_id: CANVAS_OUTPUT,
field: 'reference',
},
},
@@ -603,37 +562,6 @@ export const buildCanvasOutpaintGraph = (
node_id: INPAINT_IMAGE_RESIZE_DOWN,
field: 'image',
},
- destination: {
- node_id: COLOR_CORRECT,
- field: 'image',
- },
- },
- {
- source: {
- node_id: MASK_RESIZE_DOWN,
- field: 'image',
- },
- destination: {
- node_id: COLOR_CORRECT,
- field: 'mask',
- },
- },
- // Paste Everything Back
- {
- source: {
- node_id: INPAINT_INFILL_RESIZE_DOWN,
- field: 'image',
- },
- destination: {
- node_id: CANVAS_OUTPUT,
- field: 'base_image',
- },
- },
- {
- source: {
- node_id: COLOR_CORRECT,
- field: 'image',
- },
destination: {
node_id: CANVAS_OUTPUT,
field: 'image',
@@ -683,27 +611,6 @@ export const buildCanvasOutpaintGraph = (
field: 'image',
},
},
- // Seam Paint Mask
- {
- source: {
- node_id: MASK_FROM_ALPHA,
- field: 'image',
- },
- destination: {
- node_id: MASK_EDGE,
- field: 'image',
- },
- },
- {
- source: {
- node_id: MASK_EDGE,
- field: 'image',
- },
- destination: {
- node_id: SEAM_FIX_DENOISE_LATENTS,
- field: 'mask',
- },
- },
// Color Correct The Inpainted Result
{
source: {
@@ -711,7 +618,7 @@ export const buildCanvasOutpaintGraph = (
field: 'image',
},
destination: {
- node_id: COLOR_CORRECT,
+ node_id: CANVAS_OUTPUT,
field: 'reference',
},
},
@@ -720,37 +627,6 @@ export const buildCanvasOutpaintGraph = (
node_id: LATENTS_TO_IMAGE,
field: 'image',
},
- destination: {
- node_id: COLOR_CORRECT,
- field: 'image',
- },
- },
- {
- source: {
- node_id: MASK_BLUR,
- field: 'image',
- },
- destination: {
- node_id: COLOR_CORRECT,
- field: 'mask',
- },
- },
- // Paste Everything Back
- {
- source: {
- node_id: INPAINT_INFILL,
- field: 'image',
- },
- destination: {
- node_id: CANVAS_OUTPUT,
- field: 'base_image',
- },
- },
- {
- source: {
- node_id: COLOR_CORRECT,
- field: 'image',
- },
destination: {
node_id: CANVAS_OUTPUT,
field: 'image',
diff --git a/invokeai/frontend/web/src/features/nodes/util/graphBuilders/constants.ts b/invokeai/frontend/web/src/features/nodes/util/graphBuilders/constants.ts
index ff65d9d12a..00866fc633 100644
--- a/invokeai/frontend/web/src/features/nodes/util/graphBuilders/constants.ts
+++ b/invokeai/frontend/web/src/features/nodes/util/graphBuilders/constants.ts
@@ -26,6 +26,8 @@ export const INPAINT_INFILL = 'inpaint_infill';
export const INPAINT_INFILL_RESIZE_DOWN = 'inpaint_infill_resize_down';
export const INPAINT_FINAL_IMAGE = 'inpaint_final_image';
export const SEAM_FIX_DENOISE_LATENTS = 'seam_fix_denoise_latents';
+export const OUTPAINT_REFINE_DENOISE_LATENTS =
+ 'outpaint_refine_denoise_latents';
export const MASK_FROM_ALPHA = 'tomask';
export const MASK_EDGE = 'mask_edge';
export const MASK_BLUR = 'mask_blur';
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefinePassCollapse.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefinePassCollapse.tsx
new file mode 100644
index 0000000000..47d57569f6
--- /dev/null
+++ b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefinePassCollapse.tsx
@@ -0,0 +1,21 @@
+import { Flex } from '@chakra-ui/react';
+import IAICollapse from 'common/components/IAICollapse';
+import { memo } from 'react';
+import { useTranslation } from 'react-i18next';
+import ParamRefineSteps from './ParamRefineSteps';
+import ParamRefineStrength from './ParamRefineStrength';
+
+const ParamRefinePassCollapse = () => {
+ const { t } = useTranslation();
+
+ return (
+
+
+
+
+
+
+ );
+};
+
+export default memo(ParamRefinePassCollapse);
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamSteps.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefineSteps.tsx
similarity index 60%
rename from invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamSteps.tsx
rename to invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefineSteps.tsx
index e69339dbfe..1b3b7df598 100644
--- a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamSteps.tsx
+++ b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefineSteps.tsx
@@ -1,36 +1,36 @@
import type { RootState } from 'app/store/store';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import IAISlider from 'common/components/IAISlider';
-import { setSeamSteps } from 'features/parameters/store/generationSlice';
+import { setRefineSteps } from 'features/parameters/store/generationSlice';
import { memo } from 'react';
import { useTranslation } from 'react-i18next';
-const ParamSeamSteps = () => {
+const ParamRefineSteps = () => {
const dispatch = useAppDispatch();
- const seamSteps = useAppSelector(
- (state: RootState) => state.generation.seamSteps
+ const refineSteps = useAppSelector(
+ (state: RootState) => state.generation.refineSteps
);
const { t } = useTranslation();
return (
{
- dispatch(setSeamSteps(v));
+ dispatch(setRefineSteps(v));
}}
withInput
withSliderMarks
withReset
handleReset={() => {
- dispatch(setSeamSteps(20));
+ dispatch(setRefineSteps(20));
}}
/>
);
};
-export default memo(ParamSeamSteps);
+export default memo(ParamRefineSteps);
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamStrength.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefineStrength.tsx
similarity index 58%
rename from invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamStrength.tsx
rename to invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefineStrength.tsx
index 3f0fa01fcb..2bd46c4e23 100644
--- a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamStrength.tsx
+++ b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefineStrength.tsx
@@ -1,36 +1,36 @@
import type { RootState } from 'app/store/store';
import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
import IAISlider from 'common/components/IAISlider';
-import { setSeamStrength } from 'features/parameters/store/generationSlice';
+import { setRefineStrength } from 'features/parameters/store/generationSlice';
import { memo } from 'react';
import { useTranslation } from 'react-i18next';
-const ParamSeamStrength = () => {
+const ParamRefineStrength = () => {
const dispatch = useAppDispatch();
- const seamStrength = useAppSelector(
- (state: RootState) => state.generation.seamStrength
+ const refineStrength = useAppSelector(
+ (state: RootState) => state.generation.refineStrength
);
const { t } = useTranslation();
return (
{
- dispatch(setSeamStrength(v));
+ dispatch(setRefineStrength(v));
}}
withInput
withSliderMarks
withReset
handleReset={() => {
- dispatch(setSeamStrength(0.7));
+ dispatch(setRefineStrength(0.3));
}}
/>
);
};
-export default memo(ParamSeamStrength);
+export default memo(ParamRefineStrength);
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamBlur.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamBlur.tsx
deleted file mode 100644
index 2ab048ce72..0000000000
--- a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamBlur.tsx
+++ /dev/null
@@ -1,36 +0,0 @@
-import type { RootState } from 'app/store/store';
-import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
-import IAISlider from 'common/components/IAISlider';
-import { setSeamBlur } from 'features/parameters/store/generationSlice';
-import { memo } from 'react';
-import { useTranslation } from 'react-i18next';
-
-const ParamSeamBlur = () => {
- const dispatch = useAppDispatch();
- const seamBlur = useAppSelector(
- (state: RootState) => state.generation.seamBlur
- );
- const { t } = useTranslation();
-
- return (
- {
- dispatch(setSeamBlur(v));
- }}
- withInput
- withSliderMarks
- withReset
- handleReset={() => {
- dispatch(setSeamBlur(8));
- }}
- />
- );
-};
-
-export default memo(ParamSeamBlur);
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamPaintingCollapse.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamPaintingCollapse.tsx
deleted file mode 100644
index 23e06797e5..0000000000
--- a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamPaintingCollapse.tsx
+++ /dev/null
@@ -1,27 +0,0 @@
-import { Flex } from '@chakra-ui/react';
-import IAICollapse from 'common/components/IAICollapse';
-import { memo } from 'react';
-import { useTranslation } from 'react-i18next';
-import ParamSeamBlur from './ParamSeamBlur';
-import ParamSeamSize from './ParamSeamSize';
-import ParamSeamSteps from './ParamSeamSteps';
-import ParamSeamStrength from './ParamSeamStrength';
-import ParamSeamThreshold from './ParamSeamThreshold';
-
-const ParamSeamPaintingCollapse = () => {
- const { t } = useTranslation();
-
- return (
-
-
-
-
-
-
-
-
-
- );
-};
-
-export default memo(ParamSeamPaintingCollapse);
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamSize.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamSize.tsx
deleted file mode 100644
index 841e9555fd..0000000000
--- a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamSize.tsx
+++ /dev/null
@@ -1,36 +0,0 @@
-import type { RootState } from 'app/store/store';
-import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
-import IAISlider from 'common/components/IAISlider';
-import { setSeamSize } from 'features/parameters/store/generationSlice';
-import { memo } from 'react';
-import { useTranslation } from 'react-i18next';
-
-const ParamSeamSize = () => {
- const dispatch = useAppDispatch();
- const seamSize = useAppSelector(
- (state: RootState) => state.generation.seamSize
- );
- const { t } = useTranslation();
-
- return (
- {
- dispatch(setSeamSize(v));
- }}
- withInput
- withSliderMarks
- withReset
- handleReset={() => {
- dispatch(setSeamSize(16));
- }}
- />
- );
-};
-
-export default memo(ParamSeamSize);
diff --git a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamThreshold.tsx b/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamThreshold.tsx
deleted file mode 100644
index f40491db98..0000000000
--- a/invokeai/frontend/web/src/features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamThreshold.tsx
+++ /dev/null
@@ -1,121 +0,0 @@
-import {
- FormControl,
- FormLabel,
- HStack,
- RangeSlider,
- RangeSliderFilledTrack,
- RangeSliderMark,
- RangeSliderThumb,
- RangeSliderTrack,
- Tooltip,
-} from '@chakra-ui/react';
-import type { RootState } from 'app/store/store';
-import { useAppDispatch, useAppSelector } from 'app/store/storeHooks';
-import IAIIconButton from 'common/components/IAIIconButton';
-import {
- setSeamHighThreshold,
- setSeamLowThreshold,
-} from 'features/parameters/store/generationSlice';
-import { memo, useCallback } from 'react';
-import { useTranslation } from 'react-i18next';
-import { BiReset } from 'react-icons/bi';
-
-const ParamSeamThreshold = () => {
- const dispatch = useAppDispatch();
- const seamLowThreshold = useAppSelector(
- (state: RootState) => state.generation.seamLowThreshold
- );
-
- const seamHighThreshold = useAppSelector(
- (state: RootState) => state.generation.seamHighThreshold
- );
- const { t } = useTranslation();
-
- const handleSeamThresholdChange = useCallback(
- (v: number[]) => {
- dispatch(setSeamLowThreshold(v[0] as number));
- dispatch(setSeamHighThreshold(v[1] as number));
- },
- [dispatch]
- );
-
- const handleSeamThresholdReset = () => {
- dispatch(setSeamLowThreshold(100));
- dispatch(setSeamHighThreshold(200));
- };
-
- return (
-
- {t('parameters.seamThreshold')}
-
-
-
-
-
-
-
-
-
-
-
-
- 0
-
-
- 100
-
-
- 200
-
-
- 255
-
-
- }
- onClick={handleSeamThresholdReset}
- />
-
-
- );
-};
-
-export default memo(ParamSeamThreshold);
diff --git a/invokeai/frontend/web/src/features/parameters/store/generationSlice.ts b/invokeai/frontend/web/src/features/parameters/store/generationSlice.ts
index c7ab83cc00..8cc347871c 100644
--- a/invokeai/frontend/web/src/features/parameters/store/generationSlice.ts
+++ b/invokeai/frontend/web/src/features/parameters/store/generationSlice.ts
@@ -37,12 +37,8 @@ export interface GenerationState {
scheduler: SchedulerParam;
maskBlur: number;
maskBlurMethod: MaskBlurMethodParam;
- seamSize: number;
- seamBlur: number;
- seamSteps: number;
- seamStrength: StrengthParam;
- seamLowThreshold: number;
- seamHighThreshold: number;
+ refineSteps: number;
+ refineStrength: StrengthParam;
seed: SeedParam;
seedWeights: string;
shouldFitToWidthHeight: boolean;
@@ -80,12 +76,8 @@ export const initialGenerationState: GenerationState = {
scheduler: 'euler',
maskBlur: 16,
maskBlurMethod: 'box',
- seamSize: 16,
- seamBlur: 8,
- seamSteps: 20,
- seamStrength: 0.7,
- seamLowThreshold: 100,
- seamHighThreshold: 200,
+ refineSteps: 20,
+ refineStrength: 0.3,
seed: 0,
seedWeights: '',
shouldFitToWidthHeight: true,
@@ -212,23 +204,11 @@ export const generationSlice = createSlice({
setMaskBlurMethod: (state, action: PayloadAction) => {
state.maskBlurMethod = action.payload;
},
- setSeamSize: (state, action: PayloadAction) => {
- state.seamSize = action.payload;
+ setRefineSteps: (state, action: PayloadAction) => {
+ state.refineSteps = action.payload;
},
- setSeamBlur: (state, action: PayloadAction) => {
- state.seamBlur = action.payload;
- },
- setSeamSteps: (state, action: PayloadAction) => {
- state.seamSteps = action.payload;
- },
- setSeamStrength: (state, action: PayloadAction) => {
- state.seamStrength = action.payload;
- },
- setSeamLowThreshold: (state, action: PayloadAction) => {
- state.seamLowThreshold = action.payload;
- },
- setSeamHighThreshold: (state, action: PayloadAction) => {
- state.seamHighThreshold = action.payload;
+ setRefineStrength: (state, action: PayloadAction) => {
+ state.refineStrength = action.payload;
},
setTileSize: (state, action: PayloadAction) => {
state.tileSize = action.payload;
@@ -338,12 +318,8 @@ export const {
setScheduler,
setMaskBlur,
setMaskBlurMethod,
- setSeamSize,
- setSeamBlur,
- setSeamSteps,
- setSeamStrength,
- setSeamLowThreshold,
- setSeamHighThreshold,
+ setRefineSteps,
+ setRefineStrength,
setSeed,
setSeedWeights,
setShouldFitToWidthHeight,
diff --git a/invokeai/frontend/web/src/features/sdxl/components/SDXLUnifiedCanvasTabParameters.tsx b/invokeai/frontend/web/src/features/sdxl/components/SDXLUnifiedCanvasTabParameters.tsx
index 9b0dfd87c8..2f1f58cad4 100644
--- a/invokeai/frontend/web/src/features/sdxl/components/SDXLUnifiedCanvasTabParameters.tsx
+++ b/invokeai/frontend/web/src/features/sdxl/components/SDXLUnifiedCanvasTabParameters.tsx
@@ -2,7 +2,7 @@ import ParamDynamicPromptsCollapse from 'features/dynamicPrompts/components/Para
import ParamLoraCollapse from 'features/lora/components/ParamLoraCollapse';
import ParamInfillAndScalingCollapse from 'features/parameters/components/Parameters/Canvas/InfillAndScaling/ParamInfillAndScalingCollapse';
import ParamMaskAdjustmentCollapse from 'features/parameters/components/Parameters/Canvas/MaskAdjustment/ParamMaskAdjustmentCollapse';
-import ParamSeamPaintingCollapse from 'features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamPaintingCollapse';
+import ParamRefinePassCollapse from 'features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefinePassCollapse';
import ParamControlNetCollapse from 'features/parameters/components/Parameters/ControlNet/ParamControlNetCollapse';
import ParamNoiseCollapse from 'features/parameters/components/Parameters/Noise/ParamNoiseCollapse';
import ParamSDXLPromptArea from './ParamSDXLPromptArea';
@@ -21,7 +21,7 @@ export default function SDXLUnifiedCanvasTabParameters() {
-
+
>
);
}
diff --git a/invokeai/frontend/web/src/features/ui/components/tabs/UnifiedCanvas/UnifiedCanvasParameters.tsx b/invokeai/frontend/web/src/features/ui/components/tabs/UnifiedCanvas/UnifiedCanvasParameters.tsx
index e042261a69..4362253c39 100644
--- a/invokeai/frontend/web/src/features/ui/components/tabs/UnifiedCanvas/UnifiedCanvasParameters.tsx
+++ b/invokeai/frontend/web/src/features/ui/components/tabs/UnifiedCanvas/UnifiedCanvasParameters.tsx
@@ -2,11 +2,11 @@ import ParamDynamicPromptsCollapse from 'features/dynamicPrompts/components/Para
import ParamLoraCollapse from 'features/lora/components/ParamLoraCollapse';
import ParamAdvancedCollapse from 'features/parameters/components/Parameters/Advanced/ParamAdvancedCollapse';
import ParamInfillAndScalingCollapse from 'features/parameters/components/Parameters/Canvas/InfillAndScaling/ParamInfillAndScalingCollapse';
-import ParamControlNetCollapse from 'features/parameters/components/Parameters/ControlNet/ParamControlNetCollapse';
-import ParamSymmetryCollapse from 'features/parameters/components/Parameters/Symmetry/ParamSymmetryCollapse';
import ParamMaskAdjustmentCollapse from 'features/parameters/components/Parameters/Canvas/MaskAdjustment/ParamMaskAdjustmentCollapse';
-import ParamSeamPaintingCollapse from 'features/parameters/components/Parameters/Canvas/SeamPainting/ParamSeamPaintingCollapse';
+import ParamRefinePassCollapse from 'features/parameters/components/Parameters/Canvas/SeamPainting/ParamRefinePassCollapse';
+import ParamControlNetCollapse from 'features/parameters/components/Parameters/ControlNet/ParamControlNetCollapse';
import ParamPromptArea from 'features/parameters/components/Parameters/Prompt/ParamPromptArea';
+import ParamSymmetryCollapse from 'features/parameters/components/Parameters/Symmetry/ParamSymmetryCollapse';
import { memo } from 'react';
import UnifiedCanvasCoreParameters from './UnifiedCanvasCoreParameters';
@@ -21,7 +21,7 @@ const UnifiedCanvasParameters = () => {
-
+
>
);