import os import cv2 import gradio as gr from gradio_client import Client, handle_file read_key = os.getenv('HUGGINGFACE_TOKEN') client = Client("Albert-NHWang/Depth-Anywhere", hf_token=read_key) def get_example(): case = [ [ 'examples/small_nthu_assembly.jpg' ], [ 'examples/small_Luca_Biada_flickr_2.jpg' ], [ 'examples/small_Dominic_Alves_flickr_panohead_test.jpg' ], [ 'examples/small_Luca_Biada_flickr.jpg' ], ] return case def depth(path): depth_path = client.predict(handle_file(path), api_name='/process_image') return depth_path intro = """

Depth Anywhere: Enhancing 360 Monocular Depth Estimation via Perspective Distillation and Unlabeled Data Augmentation

[Project page], [Paper], [Hugging Face Daily Paper]
Please test with browsers other then Safari, and avoid using incognito window due to unsolved gradio bug!
""" footnote = """
Dominic Alves, https://www.flickr.com/photos/dominicspics/28296671029/, CC BY 2.0 DEED
Luca Biada, https://www.flickr.com/photos/pedroscreamerovsky/6873256488/, CC BY 2.0 DEED
Luca Biada, https://www.flickr.com/photos/pedroscreamerovsky/6798474782/, CC BY 2.0 DEED
""" with gr.Blocks(css="style.css") as demo: gr.HTML(intro) with gr.Row(): input_image = gr.File(type="filepath") output_rgb = gr.Image(label="Loaded Image", type="filepath") with gr.Row(): load_button = gr.Button("Load RGB!", visible=True) load_button.click(fn = lambda x: x, inputs = [input_image], outputs = [output_rgb] ) with gr.Row(): output_image = gr.Image(label="Output Depth", type="filepath") with gr.Row(): run_button = gr.Button("Estimate Depth!", visible=True) run_button.click(fn = depth, inputs = [input_image], outputs = [output_image] ) gr.Examples( fn=lambda x:x, inputs=[input_image], outputs=[output_rgb], examples=get_example(), run_on_click=True, cache_examples=False) gr.HTML(footnote) demo.queue() demo.launch()