|
import gradio as gr |
|
from model import Model |
|
from functools import partial |
|
|
|
examples = [ |
|
["an astronaut waving the arm on the moon"], |
|
["a sloth surfing on a wakeboard"], |
|
["an astronaut walking on a street"], |
|
["a cute cat walking on grass"], |
|
["a horse is galloping on a street"], |
|
["an astronaut is skiing down the hill"], |
|
["a gorilla walking alone down the street"], |
|
["a gorilla dancing on times square"], |
|
["A panda dancing dancing like crazy on Times Square"], |
|
] |
|
|
|
|
|
def create_demo(model: Model): |
|
|
|
with gr.Blocks() as demo: |
|
with gr.Row(): |
|
gr.Markdown('## Text2Video-Zero: Video Generation') |
|
with gr.Row(): |
|
gr.HTML( |
|
""" |
|
<div style="text-align: left; auto;"> |
|
<h2 style="font-weight: 450; font-size: 1rem; margin: 0rem"> |
|
Description: Simply input <b>any textual prompt</b> to generate videos right away and unleash your creativity and imagination! You can also select from the examples below. For performance purposes, our current preview release generates only 8 output frames and output 4s videos. |
|
</h3> |
|
</div> |
|
""") |
|
|
|
with gr.Row(): |
|
with gr.Column(): |
|
prompt = gr.Textbox(label='Prompt') |
|
run_button = gr.Button(label='Run') |
|
with gr.Accordion('Advanced options', open=False): |
|
motion_field_strength_x = gr.Slider(label='Global Translation $\delta_{x}$', |
|
minimum=-20, |
|
maximum=20, |
|
value=12, |
|
step=1) |
|
|
|
motion_field_strength_y = gr.Slider(label='Global Translation $\delta_{y}$', |
|
minimum=-20, |
|
maximum=20, |
|
value=12, |
|
step=1) |
|
|
|
n_prompt = gr.Textbox(label="Optional Negative Prompt", |
|
value='') |
|
with gr.Column(): |
|
result = gr.Video(label="Generated Video") |
|
inputs = [ |
|
prompt, |
|
motion_field_strength_x, |
|
motion_field_strength_y, |
|
n_prompt |
|
] |
|
|
|
gr.Examples(examples=examples, |
|
inputs=inputs, |
|
outputs=result, |
|
fn=model.process_text2video, |
|
cache_examples=True, |
|
run_on_click=False, |
|
) |
|
|
|
run_button.click(fn=model.process_text2video, |
|
inputs=inputs, |
|
outputs=result,) |
|
return demo |
|
|