import gradio as gr import requests import json import base64 from PIL import Image import io import os # Enhanced 3D style CSS css = """ footer { visibility: hidden; } .gradio-container { background: linear-gradient(145deg, #f0f0f0, #ffffff); box-shadow: 20px 20px 60px #bebebe, -20px -20px 60px #ffffff; border-radius: 15px; } .gr-button { background: linear-gradient(145deg, #007bff, #0056b3); border: none; padding: 12px 24px; border-radius: 10px; color: white; font-weight: bold; box-shadow: 5px 5px 15px rgba(0,0,0,0.2); transition: transform 0.2s; } .gr-button:hover { transform: translateY(-2px); box-shadow: 7px 7px 20px rgba(0,0,0,0.25); } .gr-input, .gr-box { border-radius: 10px; box-shadow: inset 5px 5px 10px #d1d1d1, inset -5px -5px 10px #ffffff; border: 2px solid #e0e0e0; } .gr-form { background: #ffffff; padding: 20px; border-radius: 15px; box-shadow: 0 10px 30px rgba(0,0,0,0.1); } """ app_id = os.getenv("app_id") app_key = os.getenv("app_key") app_url = os.getenv("app_url") # Rest of your functions remain the same def get_latex_from_image_all_formats(image): # Your existing function code... pass def build_gradio_app(css=css): with gr.Blocks(css=css) as demo: gr.Markdown("# ArXivGPT OCR LaTeX Converter") gr.Markdown("Upload an image, click 'Convert' button, and copy the output. Paste it in the empty box below and click 'Render HTML'.") image_input = gr.Image(type="pil", label="Upload Image") def process_and_output(image): latex_result = get_latex_from_image_all_formats(image) text_result = latex_result.get("text", "No result") return text_result submit_button = gr.Button("Convert", elem_classes="custom-button") outputs = gr.Textbox(label="Output") submit_button.click(fn=process_and_output, inputs=[image_input], outputs=[outputs]) examples = gr.Examples( examples=[["ko.png"], ["en.png"], ["hand.jpg"]], inputs=[image_input], fn=process_and_output, outputs=[outputs], label="Example Images" ) latex_iframe = gr.HTML( value='', elem_id="latex_iframe" ) return demo if __name__ == "__main__": app = build_gradio_app() app.launch()