File size: 7,555 Bytes
5f62c46
a63d13c
 
 
5f62c46
a63d13c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
edd9ec8
a63d13c
 
 
 
 
edd9ec8
 
a63d13c
 
 
 
 
 
 
 
 
 
 
 
 
 
edd9ec8
a63d13c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
edd9ec8
 
 
 
 
a63d13c
 
 
 
 
 
 
 
 
edd9ec8
a63d13c
 
edd9ec8
a63d13c
 
 
 
 
 
 
 
edd9ec8
a63d13c
 
 
 
 
 
 
 
 
 
 
 
 
edd9ec8
a63d13c
 
edd9ec8
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
104
105
106
107
108
109
110
111
112
113
114
115
import gradio as gr
import argparse
import os, sys
import torch

def parse_args() -> argparse.Namespace:
    parser = argparse.ArgumentParser()
    parser.add_argument('--device', type=str, default='cpu')
    parser.add_argument('--theme', type=str)
    parser.add_argument('--live', action='store_true')
    parser.add_argument('--share', action='store_true')
    parser.add_argument('--port', type=int)
    parser.add_argument('--disable-queue',
                        dest='enable_queue',
                        action='store_false')
    parser.add_argument('--allow-flagging', type=str, default='never')
    parser.add_argument('--allow-screenshot', action='store_true')
    return parser.parse_args()

_TITLE = '''DreamGaussian: Generative Gaussian Splatting for Efficient 3D Content Creation'''

_DESCRIPTION = '''
<div>
<a style="display:inline-block" href="https://dreamgaussian.github.io"><img src='https://img.shields.io/badge/public_website-8A2BE2'></a>
<a style="display:inline-block; margin-left: .5em" href="https://arxiv.org/abs/2309.16653"><img src="https://img.shields.io/badge/2306.16928-f9f7f7?logo="></a>
<a style="display:inline-block; margin-left: .5em" href='https://github.com/dreamgaussian/dreamgaussian'><img src='https://img.shields.io/github/stars/dreamgaussian/dreamgaussian?style=social'/></a>
</div>
We present DreamGausssion, a 3D content generation framework that significantly improves the efficiency of 3D content creation. 
'''
_IMG_USER_GUIDE = "Please upload an image in the block above (or choose an example above) and click **Run Generation**." 
_TXT_USER_GUIDE = "Please type what you want to generate in the block above and click **Run Generation**." 

# trigger Image-to-3D model
def inference_img(img):
    pass

# trigger Text-to-3D model
def inference_txt(txt):
    pass

def run_demo():
    args = parse_args()
    args.device = 'cuda' if torch.cuda.is_available() else 'cpu'
    print('*** Now using %s.'%(args.device))

    # append README as extra info
    with open('README.md', 'r') as f:
        article = f.read()

    # NOTE: Examples must match inputs
    example_folder = os.path.join(os.path.dirname(__file__), 'demo_examples')
    example_fns = os.listdir(example_folder)
    example_fns.sort()
    examples_full = [os.path.join(example_folder, x) for x in example_fns if x.endswith('.png')]

    # Compose demo layout & data flow
    with gr.Blocks(title=_TITLE, css="style.css") as demo:
        with gr.Row():
            with gr.Column(scale=1):
                gr.Markdown('# ' + _TITLE)
            with gr.Column(scale=0):
                gr.DuplicateButton(value='Duplicate Space for private use',
                            elem_id='duplicate-button')
        gr.Markdown(_DESCRIPTION)

        # Image-to-3D
        with gr.Row(variant='panel'):
            with gr.Column(scale=6):
                image_block = gr.Image(type='pil', image_mode='RGBA', height=290, label='Input image', tool=None)

                elevation_slider = gr.Slider(-90, 90, value=0, step=1, label='Estimated elevation angle')
                gr.Markdown("default to 0 (horizontal), range from [-90, 90]. If you upload a look-down image, try a value like -30")

                preprocess_chk = gr.Checkbox(True, label='Preprocess image automatically (remove background and recenter object)')

                gr.Examples(
                    examples=examples_full,  # NOTE: elements must match inputs list!
                    inputs=[image_block],
                    outputs=[image_block],
                    cache_examples=False,
                    label='Examples (click one of the images below to start)',
                    examples_per_page=40
                )
                img_run_btn = gr.Button('Run Generation', variant='primary', interactive=False)
                img_guide_text = gr.Markdown(_IMG_USER_GUIDE, visible=True)
                
            with gr.Column(scale=4):
                processed_image_block = gr.Image(type='pil', image_mode='RGBA', height=290, label='Processed image', tool=None)
                img_mesh_output = gr.Model3D(clear_color=[0.0, 0.0, 0.0, 0.0], label="Textured Mesh", elem_id="img-model-3d-out")
        
        # Text-to-3D
        with gr.Row(variant='panel'):
            with gr.Column(scale=6):
                text_block = gr.Textbox(label="Input text")

                txt_run_btn = gr.Button('Run Generation', variant='primary', interactive=False)
                txt_guide_text = gr.Markdown(_TXT_USER_GUIDE, visible=True)
                
            with gr.Column(scale=4):
                txt_mesh_output = gr.Model3D(clear_color=[0.0, 0.0, 0.0, 0.0], label="Textured Mesh", elem_id="txt-model-3d-out")
        
        gr.Markdown(article)
        gr.HTML("""
            <div class="footer">
                <p> 
                This is a test demo
                </p>
            </div>
        """)

    demo.queue().launch(share=True, max_threads=80) # auth=("admin", os.environ['PASSWD'])

if __name__ == '__main__':
    run_demo()