X2Painting / app.py
AntaresGuo's picture
Update app.py
ef96746 verified
raw
history blame
4.22 kB
import gradio as gr
import numpy as np
from interface_modules.X2Painting.template_config import style_example
from interface_modules.X2Painting.client_process import send_to_server
def on_select(evt: gr.SelectData):
index = evt.index
style_name = list(style_example.values())[index]
return gr.update(value=style_name)
css = """
.gradio-container {background-color: #F0F5FF; width: 95% !important}
"""
title = r"""
</br>
<h1 align="center" style="font-size: 42px;">Character2Painting</h1>
<h2 align="center">
<span style="color: red;">Character</span> <---
<span style="color: black;">Zoom out
<a href="https://github.com/antarestcguo/X2Painting" target="_blank" style="text-decoration: none; color: black;">
<img src="https://img.shields.io/badge/Github-Repo-blue" alt="GitHub" style="vertical-align: middle; width: 20px; height: 20px;">
</a>
Zoom in</span> ---&gt;
<span style="color: red;">Painting</span>
</h2>
</br>
</br>
<img src="https://cdn-lfs-us-1.huggingface.co/repos/08/ef/08ef1f5b2ff4e2232d2843b12c514f710b2398df7b2eb1d5af354753aef4bc97/9815b4f1ebc753dfb44ddd8f0ecf6416bd07c5136f53154051cc4b20bd8ec715?response-content-disposition=inline%3B+filename*%3DUTF-8%27%27xword_intro.png%3B+filename%3D%22xword_intro.png%22%3B&response-content-type=image%2Fpng&Expires=1712822072&Policy=eyJTdGF0ZW1lbnQiOlt7IkNvbmRpdGlvbiI6eyJEYXRlTGVzc1RoYW4iOnsiQVdTOkVwb2NoVGltZSI6MTcxMjgyMjA3Mn19LCJSZXNvdXJjZSI6Imh0dHBzOi8vY2RuLWxmcy11cy0xLmh1Z2dpbmdmYWNlLmNvL3JlcG9zLzA4L2VmLzA4ZWYxZjViMmZmNGUyMjMyZDI4NDNiMTJjNTE0ZjcxMGIyMzk4ZGY3YjJlYjFkNWFmMzU0NzUzYWVmNGJjOTcvOTgxNWI0ZjFlYmM3NTNkZmI0NGRkZDhmMGVjZjY0MTZiZDA3YzUxMzZmNTMxNTQwNTFjYzRiMjBiZDhlYzcxNT9yZXNwb25zZS1jb250ZW50LWRpc3Bvc2l0aW9uPSomcmVzcG9uc2UtY29udGVudC10eXBlPSoifV19&Signature=B7RToR-DTnf9OcWOi2spv19seYQiF8fFtxp36WZS6IPEkBdY9r-x5PAnCiZLx1imVcWuzrzabYRSyOaCQZgKqshAAlbmU-7JECvIEDFZcwOuA4-CJU7gR2v6GocVmEuAcfd8igew9gX7Uza8zAPmbdNytskCvFtSnZMdXD6fdCBrq2QHW1PSTL%7E0H5L342aVy6%7E7mfHHvaWsSEE%7EDcUjzahSX1ISlWDUl1dy66SFtfDMzc1z6sMgnzGmqWn6uMNH-3Uv%7Efk4xpLjwlmGQGO0ANE1226zXNegdWnPsjiZNRhN18OcwFy7Kv9XAUBwoePoNjec3iTRwWrqnaN4fzEnww__&Key-Pair-Id=KCD77M1F0VK2B" style="display: block; margin: 0 auto; max-height: 384px;">
</br>
<h2 style="text-align: center;">===================🤪🥳 Have a Try 🤩😄===================</h2>
"""
with gr.Blocks(css=css) as demo:
# description
gr.HTML(title)
with gr.Row():
with gr.Column(scale=1):
gr.HTML("""
<h1>⭐️ User Tips </h1>
<h2> <p><b>step1:</b> Input a Character. Recommended Chinese Character.</p>
<p><b>step2:</b> Select a style in the Gallery</p>
<p><b>step3:</b> Click Run, Waiting for about 1 Min. Enjoy</p></h2>
""")
word = gr.Textbox(
label="Input Character",
info="please type Character, such as 李. (输入中文字,例如,李)",
value="李",
elem_id="InputCha"
)
submit = gr.ClearButton(value="Run",elem_id="RunBtn")
style_name = gr.Textbox(
label="style_name",
info="style_name",
value="", visible=False,
)
with gr.Column(scale=6):
gr.HTML("""
<h1 align="center">Style Gallery</h1>
""")
example_gallery = gr.Gallery(label="style_type", show_label=True, elem_id="example_gallery",
value=list(style_example.keys()), columns=5
)
# vis result gallery
gr.HTML("""
<h1 align="center">Result Gallery</h1>
""")
final_gallery = gr.Gallery(
label="最终生成图",
show_label=False,
elem_classes="final_gallery",columns=[4], rows=[2]
)
submit.add([final_gallery])
submit.click(send_to_server,
inputs=[word, style_name],
outputs=[final_gallery])
example_gallery.select(on_select, None,
[style_name])
demo.queue()
demo.launch(share=True)