From b10d745dae9521051dde82e876c6e1ec02be3a0a Mon Sep 17 00:00:00 2001 From: psychedelicious <4822129+psychedelicious@users.noreply.github.com> Date: Fri, 9 Feb 2024 09:16:07 +1100 Subject: [PATCH] fix(ui): when using control image dimensions, round to 8 The control image dimensions were set directly without rounding them to 8, causing an error during generation if they weren't a multiple of 8. --- .../components/ControlAdapterImagePreview.tsx | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/invokeai/frontend/web/src/features/controlAdapters/components/ControlAdapterImagePreview.tsx b/invokeai/frontend/web/src/features/controlAdapters/components/ControlAdapterImagePreview.tsx index 32aca81185..9321687219 100644 --- a/invokeai/frontend/web/src/features/controlAdapters/components/ControlAdapterImagePreview.tsx +++ b/invokeai/frontend/web/src/features/controlAdapters/components/ControlAdapterImagePreview.tsx @@ -5,6 +5,7 @@ import { createMemoizedSelector } from 'app/store/createMemoizedSelector'; import { useAppDispatch, useAppSelector } from 'app/store/storeHooks'; import IAIDndImage from 'common/components/IAIDndImage'; import IAIDndImageIcon from 'common/components/IAIDndImageIcon'; +import { roundToMultiple } from 'common/util/roundDownToMultiple'; import { setBoundingBoxDimensions } from 'features/canvas/store/canvasSlice'; import { useControlAdapterControlImage } from 'features/controlAdapters/hooks/useControlAdapterControlImage'; import { useControlAdapterProcessedControlImage } from 'features/controlAdapters/hooks/useControlAdapterProcessedControlImage'; @@ -91,19 +92,14 @@ const ControlAdapterImagePreview = ({ isSmall, id }: Props) => { return; } + const width = roundToMultiple(controlImage.width, 8); + const height = roundToMultiple(controlImage.height, 8); + if (activeTabName === 'unifiedCanvas') { - dispatch( - setBoundingBoxDimensions( - { - width: controlImage.width, - height: controlImage.height, - }, - optimalDimension - ) - ); + dispatch(setBoundingBoxDimensions({ width, height }, optimalDimension)); } else { - dispatch(widthChanged(controlImage.width)); - dispatch(heightChanged(controlImage.height)); + dispatch(widthChanged(width)); + dispatch(heightChanged(height)); } }, [controlImage, activeTabName, dispatch, optimalDimension]);