muhammadsalmanalfaridzi
commited on
Update app.py
Browse files
app.py
CHANGED
@@ -12,6 +12,7 @@ from transformers import pipeline
|
|
12 |
import numpy as np
|
13 |
import json
|
14 |
import torch
|
|
|
15 |
|
16 |
# Load Stable Diffusion Model
|
17 |
def load_stable_diffusion_model():
|
@@ -354,10 +355,15 @@ def process_images(input_files, bg_method='rembg', watermark_path=None, canvas_s
|
|
354 |
|
355 |
return original_images, processed_images, output_zip_path, processing_time
|
356 |
|
|
|
|
|
|
|
357 |
def gradio_interface(input_files, bg_method, watermark, canvas_size, output_format, bg_choice, custom_color, num_workers):
|
|
|
358 |
progress = gr.Progress()
|
359 |
watermark_path = watermark.name if watermark else None
|
360 |
|
|
|
361 |
if isinstance(input_files, str) and input_files.lower().endswith(('.zip', '.rar')):
|
362 |
return process_images(input_files, bg_method, watermark_path, canvas_size, output_format, bg_choice, custom_color, num_workers, progress)
|
363 |
elif isinstance(input_files, list):
|
@@ -366,31 +372,41 @@ def gradio_interface(input_files, bg_method, watermark, canvas_size, output_form
|
|
366 |
return process_images(input_files.name, bg_method, watermark_path, canvas_size, output_format, bg_choice, custom_color, num_workers, progress)
|
367 |
|
368 |
def show_color_picker(bg_choice):
|
369 |
-
|
370 |
-
|
371 |
-
return gr.update(visible=False)
|
372 |
|
373 |
def update_compare(evt: gr.SelectData):
|
|
|
374 |
if isinstance(evt.value, dict) and 'caption' in evt.value:
|
375 |
-
input_path = evt.value['caption']
|
376 |
output_path = evt.value['image']['path']
|
377 |
-
input_path = input_path.split("Input: ")[-1]
|
378 |
|
|
|
379 |
original_img = Image.open(input_path)
|
380 |
processed_img = Image.open(output_path)
|
381 |
|
|
|
382 |
original_ratio = f"{original_img.width}x{original_img.height}"
|
383 |
processed_ratio = f"{processed_img.width}x{processed_img.height}"
|
384 |
|
385 |
-
return gr.update(value=input_path),
|
|
|
|
|
|
|
|
|
386 |
else:
|
387 |
-
|
388 |
-
return
|
389 |
|
390 |
def process(input_files, bg_method, watermark, canvas_size, output_format, bg_choice, custom_color, num_workers):
|
391 |
-
|
392 |
-
|
393 |
-
|
|
|
|
|
|
|
|
|
|
|
394 |
|
395 |
with gr.Blocks(theme="NoCrypt/[email protected]") as iface:
|
396 |
gr.Markdown("# Image Background Removal and Resizing with Optional Watermark")
|
|
|
12 |
import numpy as np
|
13 |
import json
|
14 |
import torch
|
15 |
+
import logging
|
16 |
|
17 |
# Load Stable Diffusion Model
|
18 |
def load_stable_diffusion_model():
|
|
|
355 |
|
356 |
return original_images, processed_images, output_zip_path, processing_time
|
357 |
|
358 |
+
# Set up logging
|
359 |
+
logging.basicConfig(level=logging.INFO)
|
360 |
+
|
361 |
def gradio_interface(input_files, bg_method, watermark, canvas_size, output_format, bg_choice, custom_color, num_workers):
|
362 |
+
"""Handles input files and processes them accordingly."""
|
363 |
progress = gr.Progress()
|
364 |
watermark_path = watermark.name if watermark else None
|
365 |
|
366 |
+
# Check the type of input_files and call the process_images function
|
367 |
if isinstance(input_files, str) and input_files.lower().endswith(('.zip', '.rar')):
|
368 |
return process_images(input_files, bg_method, watermark_path, canvas_size, output_format, bg_choice, custom_color, num_workers, progress)
|
369 |
elif isinstance(input_files, list):
|
|
|
372 |
return process_images(input_files.name, bg_method, watermark_path, canvas_size, output_format, bg_choice, custom_color, num_workers, progress)
|
373 |
|
374 |
def show_color_picker(bg_choice):
|
375 |
+
"""Shows the color picker if 'custom' background is selected."""
|
376 |
+
return gr.update(visible=(bg_choice == 'custom'))
|
|
|
377 |
|
378 |
def update_compare(evt: gr.SelectData):
|
379 |
+
"""Updates the displayed images and their ratios when a processed image is selected."""
|
380 |
if isinstance(evt.value, dict) and 'caption' in evt.value:
|
381 |
+
input_path = evt.value['caption'].split("Input: ")[-1]
|
382 |
output_path = evt.value['image']['path']
|
|
|
383 |
|
384 |
+
# Open the original and processed images
|
385 |
original_img = Image.open(input_path)
|
386 |
processed_img = Image.open(output_path)
|
387 |
|
388 |
+
# Calculate the aspect ratios
|
389 |
original_ratio = f"{original_img.width}x{original_img.height}"
|
390 |
processed_ratio = f"{processed_img.width}x{processed_img.height}"
|
391 |
|
392 |
+
return (gr.update(value=input_path),
|
393 |
+
gr.update(value=output_path),
|
394 |
+
gr.update(value=original_ratio),
|
395 |
+
gr.update(value=processed_ratio)
|
396 |
+
)
|
397 |
else:
|
398 |
+
logging.warning("No caption found in selection")
|
399 |
+
return (gr.update(value=None),) * 4
|
400 |
|
401 |
def process(input_files, bg_method, watermark, canvas_size, output_format, bg_choice, custom_color, num_workers):
|
402 |
+
"""Processes the images and returns the results."""
|
403 |
+
try:
|
404 |
+
_, processed_images, zip_path, time_taken = gradio_interface(input_files, bg_method, watermark, canvas_size, output_format, bg_choice, custom_color, num_workers)
|
405 |
+
processed_images_with_captions = [(img, f"Input: {caption}") for img, caption in processed_images]
|
406 |
+
return processed_images_with_captions, zip_path, f"{time_taken:.2f} seconds"
|
407 |
+
except Exception as e:
|
408 |
+
logging.error(f"Error in processing images: {e}")
|
409 |
+
return [], None, "Error during processing"
|
410 |
|
411 |
with gr.Blocks(theme="NoCrypt/[email protected]") as iface:
|
412 |
gr.Markdown("# Image Background Removal and Resizing with Optional Watermark")
|