import requests
from PIL import Image
import os
import io
import base64
from pathlib import Path
import gradio as gr
# parameters which can be customized in settings.json of webui
initial_width = 512
initial_height = 512
params = {
"enable_SD_api": True,
"address": "https://253f-2001-d08-e3-5197-8959-3944-7869-3df9.ngrok-free.app",
"save_img": True,
"SD_model": "Chilloutmix-Ni-prune-fp32-fix.safetensors",
"prompt_prefix": "detailed portrait of a asian man in black jacket, Futuristic sci-fi fashion, fine details, realistic shaded, fine-face, pretty face cyberpunk, neotokyo, synthwave, aesthetics, futuristic, low-emission-neon, (blade runner movie scene)",
"negative_prompt": "jpeg artifacts, low quality, lowres, 3d, render, doll, plastic, blur, haze, monochrome, b&w, text, (ugly:1.2), unclear eyes, no arms, bad anatomy, cropped, censoring, asymmetric eyes, bad anatomy, bad proportions, cropped, cross-eyed, deformed, extra arms, extra fingers, extra limbs, fused fingers, malformed, mangled hands, misshapen body, missing arms, missing fingers, missing hands, missing legs, poorly drawn, tentacle finger, too many arms, too many fingers, watermark, logo, text, letters, signature, username, words, blurry, cropped",
"width": initial_width,
"height": initial_height,
"restore_faces": False,
}
pic_id = 0
# Get and save the Stable Diffusion-generated picture
def get_SD_pictures(description):
global params, pic_id
payload = {
"prompt": params["prompt_prefix"] + description,
"seed": -1,
"sampler_name": "Euler a",
"steps": 20,
"cfg_scale": 7,
"width": params["width"],
"height": params["height"],
"restore_faces": params["restore_faces"],
"negative_prompt": params["negative_prompt"],
}
try:
response = requests.post(
url=f'{params["address"]}/sdapi/v1/txt2img', json=payload, timeout=100
)
response.raise_for_status() # Raises stored HTTPError, if one occurred
except requests.exceptions.HTTPError as http_err:
return f"HTTP error occurred: {http_err}"
except Exception as err:
return f"An error occurred: {err}"
r = response.json()
visible_result = ""
for img_str in r["images"]:
image = Image.open(io.BytesIO(base64.b64decode(img_str.split(",", 1)[0])))
if not os.path.exists("outputs"):
os.makedirs("outputs")
if params["save_img"]:
output_file = Path(f"outputs/{pic_id:06d}.png")
image.save(output_file.as_posix())
pic_id += 1
# lower the resolution of received images for the chat
# otherwise the log size gets out of control quickly
# with all the base64 values in visible history
image.thumbnail((512, 512))
buffered = io.BytesIO()
image.save(buffered, format="JPEG")
buffered.seek(0)
image_bytes = buffered.getvalue()
img_str = "data:image/jpeg;base64," + base64.b64encode(image_bytes).decode()
visible_result = visible_result + f'\n'
return visible_result
def display_image(description: str, artist: str) -> gr.Image:
if artist == "Kashif":
description += " "
elif artist == "Daniel Ho":
description += " "
elif artist == "Adrian":
description += " "
elif artist == "Tony":
description += " "
elif artist == "Kevin":
description += " "
elif artist == "Aaron":
description += " "
if artist == "none":
artist = False
if artist:
params["width"] = 768
params["height"] = 768
params[
"prompt_prefix"
] = "detailed portrait of a asian man in black jacket, Futuristic sci-fi fashion, fine details, realistic shaded, fine-face, pretty face cyberpunk, neotokyo, synthwave, aesthetics, futuristic, low-emission-neon, (blade runner movie scene)"
else:
params["width"] = initial_width
params["height"] = initial_height
params["prompt_prefix"] = "4k"
visible_result = get_SD_pictures(description)
if "error occurred" in visible_result:
return visible_result
image_data = base64.b64decode(visible_result.split(",", 1)[1])
image = Image.open(io.BytesIO(image_data))
return image
inputs = [
gr.inputs.Textbox(lines=2, label="Enter image description"),
gr.inputs.Radio(
["Kashif", "Daniel Ho", "Adrian", "Tony", "Kevin", "Aaron", "none"],
label="Artist",
),
]
outputs = gr.outputs.Image(type="pil", label="Generated Image")
interface = gr.Interface(
fn=display_image, inputs=inputs, outputs=outputs, title="DC Image Generator"
)
interface.launch()