import gradio as gr from transformers import pipeline import torch import numpy as np from PIL import Image import io def remove_background(input_image): try: # Initialize the pipeline with trust_remote_code=True segmentor = pipeline( "image-segmentation", model="briaai/RMBG-1.4", trust_remote_code=True, device="cpu" ) # Process the image and get result result = segmentor(input_image, return_mask=True) # Convert result to RGBA if isinstance(result, Image.Image): # Create transparent background output = Image.new('RGBA', result.size, (0, 0, 0, 0)) output.paste(input_image, mask=result) else: output = result['output_image'] return output except Exception as e: raise gr.Error(f"Error processing image: {str(e)}") # Custom theme and styling theme = gr.themes.Soft( primary_hue="gold", secondary_hue="orange", ).set( body_background_fill="linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%)", body_text_color="#ffffff", button_primary_background_fill="linear-gradient(45deg, #FFD700, #FFA500)", button_primary_text_color="#000000", border_color_primary="#FFD700" ) css = """ .gradio-container { max-width: 1200px !important; margin: 0 auto !important; padding: 20px !important; } .image-container { border-radius: 15px !important; border: 2px solid rgba(255, 215, 0, 0.3) !important; padding: 10px !important; background: rgba(255, 255, 255, 0.1) !important; transition: transform 0.3s ease !important; } .image-container:hover { transform: translateY(-5px) !important; } .gr-button { min-width: 200px !important; height: 45px !important; font-size: 16px !important; margin: 10px !important; transition: all 0.3s ease !important; } .gr-button:hover { transform: translateY(-2px) !important; box-shadow: 0 5px 15px rgba(255, 215, 0, 0.3) !important; } .footer { text-align: center; margin-top: 20px; color: #666; } """ # Create Gradio interface with gr.Blocks(theme=theme, css=css) as demo: gr.HTML( """
Remove backgrounds instantly using advanced AI technology