|
import spaces |
|
import gradio as gr |
|
from diffusers import StableDiffusion3InpaintPipeline, AutoencoderKL |
|
import torch |
|
from PIL import Image, ImageOps |
|
import time |
|
from huggingface_hub import login |
|
import os |
|
|
|
login(token=os.getenv("HF_TOKEN")) |
|
|
|
|
|
|
|
|
|
pipeline = StableDiffusion3InpaintPipeline.from_pretrained("stabilityai/stable-diffusion-3-medium-diffusers", torch_dtype=torch.float16) |
|
|
|
def get_select_index(evt: gr.SelectData): |
|
return evt.index |
|
|
|
|
|
def squarify_image(img): |
|
if(img.height > img.width): bg_size = img.height |
|
else: bg_size = img.width |
|
bg = Image.new(mode="RGB", size=(bg_size,bg_size), color="white") |
|
bg.paste(img, ( int((bg.width - bg.width)/2), 0) ) |
|
|
|
return bg |
|
|
|
|
|
def divisible_by_8(image): |
|
width, height = image.size |
|
|
|
|
|
new_width = (width // 8) * 8 |
|
new_height = (height // 8) * 8 |
|
|
|
|
|
resized_image = image.resize((new_width, new_height)) |
|
|
|
return resized_image |
|
|
|
|
|
def restore_version(index, versions): |
|
print('restore version:', index) |
|
final_dict = {'background': versions[index][0], 'layers': None, 'composite': versions[index][0]} |
|
return final_dict |
|
|
|
def clear_all(): |
|
return gr.update(value=None), gr.update(value=None), gr.update(value=[], visible=False), gr.update(visible=False), gr.update(visible=False) |
|
|
|
@spaces.GPU() |
|
def generate(image_editor, prompt, neg_prompt, versions, num_inference_steps, guidance_scale): |
|
start = time.time() |
|
image = image_editor['background'].convert('RGB') |
|
|
|
|
|
image.thumbnail((1024, 1024)) |
|
image = divisible_by_8(image) |
|
original_image_size = image.size |
|
|
|
|
|
layer = image_editor["layers"][0].resize(image.size) |
|
|
|
|
|
image = squarify_image(image) |
|
|
|
|
|
mask = Image.new("RGBA", image.size, "WHITE") |
|
mask.paste(layer, (0, 0), layer) |
|
mask = ImageOps.invert(mask.convert('L')) |
|
|
|
|
|
pipeline.to("cuda") |
|
final_image = pipeline(prompt=prompt, |
|
image=image, |
|
mask_image=mask, |
|
num_inference_steps=num_inference_steps, |
|
guidance_scale=guidance_scale).images[0] |
|
|
|
|
|
|
|
if (original_image_size[0] > original_image_size[1]): |
|
original_image_size = ( original_image_size[0] * (1024/original_image_size[0]) , original_image_size[1] * (1024/original_image_size[0])) |
|
else: |
|
original_image_size = (original_image_size[0] * (1024/original_image_size[1]), original_image_size[1] * (1024/original_image_size[1])) |
|
|
|
|
|
|
|
final_image = final_image.crop((0, 0, original_image_size[0], original_image_size[1])) |
|
|
|
|
|
final_dict = {'background': final_image, 'layers': None, 'composite': final_image} |
|
|
|
|
|
if(versions==None): |
|
final_gallery = [image_editor['background'] ,final_image] |
|
else: |
|
final_gallery = versions |
|
final_gallery.append(final_image) |
|
|
|
end = time.time() |
|
print('time:', end - start) |
|
|
|
return final_dict, gr.Gallery(value=final_gallery, visible=True), gr.update(visible=True), gr.update(visible=True) |
|
|
|
with gr.Blocks() as demo: |
|
gr.Markdown(""" |
|
# Inpainting SD3 Sketch Pad |
|
Please ❤️ this Space |
|
""") |
|
|
|
with gr.Row(): |
|
with gr.Column(): |
|
sketch_pad = gr.ImageMask(type='pil', label='Inpaint') |
|
prompt = gr.Textbox(label="Prompt") |
|
generate_button = gr.Button(value="Inpaint", variant="primary") |
|
with gr.Accordion("Advanced Settings", open=False): |
|
neg_prompt = gr.Textbox(label='Negative Prompt', value='ugly, deformed') |
|
num_inference_steps = gr.Slider(minimum = 10, maximum = 100, value = 30, step = 1, label = "Number of inference steps", info = "lower=faster, higher=image quality") |
|
guidance_scale = gr.Slider(minimum = 1, maximum = 13, value = 7, step = 0.1, label = "Classifier-Free Guidance Scale", info = "lower=image quality, higher=follow the prompt") |
|
with gr.Column(): |
|
version_gallery = gr.Gallery(label="Versions", type="pil", object_fit='contain', visible=False) |
|
restore_button = gr.Button("Restore Version", visible=False) |
|
clear_button = gr.Button('Clear', visible=False) |
|
selected = gr.Number(show_label=False, visible=False) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
version_gallery.select(get_select_index, None, selected) |
|
generate_button.click(fn=generate, inputs=[sketch_pad,prompt, neg_prompt, version_gallery, num_inference_steps, guidance_scale], outputs=[sketch_pad, version_gallery, restore_button, clear_button]) |
|
restore_button.click(fn=restore_version, inputs=[selected, version_gallery], outputs=sketch_pad) |
|
clear_button.click(clear_all, inputs=None, outputs=[sketch_pad, prompt, version_gallery, restore_button, clear_button]) |
|
|
|
demo.launch() |