File size: 4,977 Bytes
f3fb878
ec0fdfd
f3fb878
 
ec0fdfd
f3fb878
 
ec0fdfd
f3fb878
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
d8cd782
cd0c844
f3fb878
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
import os
import gradio as gr
import sys 
sys.path.append(".")

#@title Import stuff
import gc

import subprocess
import shutil
from PIL import Image
import time

import imageio


# def run(initial_image, mask, Backgrounds, Backgrounds_complexity, Size, Angle, Steps, num_of_Images):
def run(source_img, Backgrounds, Backgrounds_complexity, Size, Angle, Steps, num_of_Images):
    print('-------------------starting to process-------------------')
    if os.path.exists('results'):
        shutil.rmtree("results")
    if os.path.exists('tmp'):
        shutil.rmtree("tmp")
    time.sleep(1)
    os.makedirs('results', exist_ok=True)
    os.makedirs('tmp/img', exist_ok=True)
    os.makedirs('tmp/mask', exist_ok=True)
    os.makedirs('tmp/bg', exist_ok=True)

    '''
    print('-----initial_image: ', initial_image)
    init_image = Image.open(initial_image)
    mask = Image.open(mask)
    init_image = init_image.resize((256,256))
    mask = mask.resize((256,256))
    init_image.save("tmp/img/input.JPEG")
    mask.save("tmp/mask/input.png")
    '''
    imageio.imwrite("tmp/img/input.JPEG", source_img["image"])
    imageio.imwrite("tmp/mask/input.png", source_img["mask"])
    
    initial_image = Image.open('tmp/img/input.JPEG').resize((256,256))
    initial_image.save('tmp/img/input.JPEG')
    mask = Image.open('tmp/mask/input.png').resize((256,256))
    mask.save('tmp/mask/input.png')


    if Backgrounds:
        background_specific = Backgrounds
        if background_specific is not None:
            background_specific = Image.open(background_specific).convert('RGB') # Specified background
            background_specific = background_specific.resize((256,256))
            background_specific.save('tmp/bg/bg.png')
            background_specific = '../tmp/bg/bg.png'
    else:
        background_specific = ""

    Backgrounds_complexity = Backgrounds_complexity
    Size = Size
    Angle = Angle
    Steps = Steps
    num_of_Images = num_of_Images
    print(Backgrounds_complexity, background_specific, Size, Angle, Steps, num_of_Images)
    p = subprocess.Popen(["sh", "run.sh", str(Backgrounds_complexity), background_specific, str(Size), str(Angle), str(Steps), str(num_of_Images)])
    
    # subprocess.Popen(["cd", "object_removal/TFill/"])
    # subprocess.Popen(["python", "test.py"])
    
    return_code = p.wait()
    print('----return_code: ', return_code)

    if os.path.exists('results/edited.png'):
        return Image.open('results/edited.png')
    else:
        return Image.open('tmp/img/input.JPEG')


image = gr.outputs.Image(type="pil", label="Your result")
css = ".output-image{height: 528px !important} .output-carousel .output-image{height:272px !important} a{text-decoration: underline}"
iface = gr.Interface(fn=run, inputs=[
    # gr.inputs.Image(type="filepath", label='initial_image'),
    gr.Image(source="upload", type="numpy", tool="sketch", elem_id="source_container"),
    # gr.inputs.Image(type="filepath", label='mask - object mask', optional=True),
    gr.inputs.Image(type="filepath", label='Backgrounds - optional, specified backgrounds'),
    gr.inputs.Slider(label="Backgrounds_complexity - How complicated you wish to the generated image to be", default=0, step=1, minimum=-30, maximum=30),
    gr.inputs.Slider(label="Size - Object pixel rates", default=0.1, step=0.02, minimum=0.01, maximum=0.5),
    gr.inputs.Slider(label="Angle - Object angle", default=0, step=10, minimum=-180, maximum=180),
    gr.inputs.Slider(label="Steps - more steps can increase quality but will take longer to generate",default=10,maximum=100,minimum=1,step=1),
    gr.inputs.Slider(label="num_of_Images - How many images you wish to generate", default=2, step=1, minimum=1, maximum=4),

    # gr.inputs.Radio(label="Width", choices=[32,64,128,256],default=256),
    # gr.inputs.Radio(label="Height", choices=[32,64,128,256],default=256),
    # gr.inputs.Textbox(label="Prompt - try adding increments to your prompt such as 'oil on canvas', 'a painting', 'a book cover'",default="chalk pastel drawing of a dog wearing a funny hat"),
    #gr.inputs.Slider(label="ETA - between 0 and 1. Lower values can provide better quality, higher values can be more diverse",default=0.0,minimum=0.0, maximum=1.0,step=0.1),
    ], 
    # outputs=[image,gr.outputs.Carousel(label="Individual images",components=["image"]),gr.outputs.Textbox(label="Error")],
    outputs=["image"],
    css=css,
    title="Image Editing with Controls of Object Attributes including Backgrounds, Sizes, Positions and Directions",
    description="Demo for Image Editing with Controls of Object Attributes. *** NOTE!!! Due to the requirements of GPU, this demo cannot work on this website currently(it always returns the input image). Please download the codes and run them at your server. ***",
    article="Our code are mostly developed based the codes of `Blended Diffusion for Text-driven Editing of Natural Images' and `TFill'")
iface.launch(enable_queue=True)