ControlNet-Plus-Plus / app_lineart.py
Ming Li
fix bug
95068c2
#!/usr/bin/env python
import gradio as gr
from settings import (
DEFAULT_IMAGE_RESOLUTION,
DEFAULT_NUM_IMAGES,
MAX_IMAGE_RESOLUTION,
MAX_NUM_IMAGES,
MAX_SEED,
)
from utils import randomize_seed_fn
examples = [
[
"images/lineart/Ryan Reynolds_1.png",
"Ryan Reynolds",
"None",
],
[
"images/lineart/Ryan Reynolds_2.png",
"Ryan Reynolds",
"None",
],
[
"images/lineart/Ryan Reynolds_3.png",
"Ryan Reynolds",
"None",
],
[
"images/lineart/tube.jpg",
"Picture Of Looking Through A View Finder",
"Lineart",
],
]
def create_demo(process):
with gr.Blocks() as demo:
with gr.Row():
with gr.Column():
image = gr.Image()
prompt = gr.Textbox(label="Prompt")
run_button = gr.Button("Run")
with gr.Accordion("Advanced options", open=False):
preprocessor_name = gr.Radio(
label="Preprocessor",
choices=[
"Lineart",
"Lineart coarse",
"None",
"Lineart (anime)",
"None (anime)",
],
type="value",
value="Lineart",
info='Please note that the only difference here is pre-processing. We use exactly the same ControlNet++ model to generate images.',
)
num_samples = gr.Slider(
label="Number of images", minimum=1, maximum=MAX_NUM_IMAGES, value=DEFAULT_NUM_IMAGES, step=1
)
image_resolution = gr.Slider(
label="Image resolution",
minimum=256,
maximum=MAX_IMAGE_RESOLUTION,
value=DEFAULT_IMAGE_RESOLUTION,
step=256,
)
preprocess_resolution = gr.Slider(
label="Preprocess resolution", minimum=128, maximum=512, value=512, step=1
)
num_steps = gr.Slider(label="Number of steps", minimum=1, maximum=100, value=20, step=1)
guidance_scale = gr.Slider(label="Guidance scale", minimum=0.1, maximum=30.0, value=7.5, step=0.1)
seed = gr.Slider(label="Seed", minimum=0, maximum=MAX_SEED, step=1, value=0)
randomize_seed = gr.Checkbox(label="Randomize seed", value=True)
a_prompt = gr.Textbox(label="Additional prompt")
n_prompt = gr.Textbox(
label="Negative prompt",
)
with gr.Column():
result = gr.Gallery(label="Output", show_label=False, columns=2, object_fit="scale-down")
gr.Examples(
examples=examples,
inputs=[
image,
prompt,
preprocessor_name
],
outputs=result,
fn=process,
)
inputs = [
image,
prompt,
a_prompt,
n_prompt,
num_samples,
image_resolution,
preprocess_resolution,
num_steps,
guidance_scale,
seed,
preprocessor_name,
]
prompt.submit(
fn=randomize_seed_fn,
inputs=[seed, randomize_seed],
outputs=seed,
queue=False,
api_name=False,
).then(
fn=process,
inputs=inputs,
outputs=result,
api_name=False,
)
run_button.click(
fn=randomize_seed_fn,
inputs=[seed, randomize_seed],
outputs=seed,
queue=False,
api_name=False,
).then(
fn=process,
inputs=inputs,
outputs=result,
api_name="lineart",
)
return demo
if __name__ == "__main__":
from model import Model
model = Model(task_name="lineart")
demo = create_demo(model.process_lineart)
demo.queue().launch()