muhammadsalmanalfaridzi
commited on
Update app.py
Browse files
app.py
CHANGED
@@ -494,31 +494,40 @@ def create_canvas(canvas_size, bg_choice, custom_color):
|
|
494 |
return Image.new("RGBA", canvas_size, (0, 0, 0, 0))
|
495 |
|
496 |
# Function to add watermark
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
497 |
def add_watermark(image, watermark_path):
|
498 |
-
|
499 |
-
|
500 |
-
|
501 |
-
|
502 |
-
|
503 |
-
|
504 |
-
|
505 |
-
|
506 |
-
|
507 |
-
|
|
|
|
|
|
|
|
|
508 |
|
509 |
-
def process_image(
|
510 |
-
|
511 |
-
|
512 |
-
|
513 |
-
|
514 |
-
|
515 |
-
|
516 |
-
#
|
517 |
-
|
518 |
-
|
519 |
-
|
520 |
-
print(f"Error processing image: {e}")
|
521 |
-
return None
|
522 |
|
523 |
def save_image(canvas, output_folder, filename, output_format):
|
524 |
output_ext = 'jpg' if output_format == 'JPG' else 'png'
|
@@ -590,6 +599,65 @@ def process_images(input_files, bg_method='rembg', watermark_path=None, canvas_s
|
|
590 |
print(f"Error processing image {future_to_image[future]}: {e}")
|
591 |
|
592 |
output_zip_path = "processed_images.zip"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
593 |
with zipfile.ZipFile(output_zip_path, 'w') as zipf:
|
594 |
for file, _ in processed_images:
|
595 |
zipf.write(file, os.path.basename(file))
|
|
|
494 |
return Image.new("RGBA", canvas_size, (0, 0, 0, 0))
|
495 |
|
496 |
# Function to add watermark
|
497 |
+
def generate_image(prompt):
|
498 |
+
# Code to generate an image using Stable Diffusion
|
499 |
+
# Placeholder: Replace with actual image generation code
|
500 |
+
response = requests.get("URL_OF_GENERATED_IMAGE") # Replace with the actual URL or generation method
|
501 |
+
img = Image.open(BytesIO(response.content))
|
502 |
+
return img
|
503 |
+
|
504 |
def add_watermark(image, watermark_path):
|
505 |
+
watermark = Image.open(watermark_path).convert("RGBA")
|
506 |
+
|
507 |
+
# Resize watermark if needed
|
508 |
+
watermark = watermark.resize((image.width // 4, image.height // 4), Image.ANTIALIAS)
|
509 |
+
|
510 |
+
# Position watermark in the center
|
511 |
+
position = ((image.width - watermark.width) // 2, (image.height - watermark.height) // 2)
|
512 |
+
|
513 |
+
# Composite the watermark onto the image
|
514 |
+
transparent = Image.new('RGBA', image.size, (0, 0, 0, 0))
|
515 |
+
transparent.paste(image, (0, 0))
|
516 |
+
transparent.paste(watermark, position, watermark)
|
517 |
+
|
518 |
+
return transparent
|
519 |
|
520 |
+
def process_image(prompt, watermark_path, bg_removal_choice):
|
521 |
+
image = generate_image(prompt)
|
522 |
+
|
523 |
+
if bg_removal_choice == "none":
|
524 |
+
final_image = image
|
525 |
+
else:
|
526 |
+
# Placeholder for actual background removal code
|
527 |
+
final_image = image # Replace with background removal logic
|
528 |
+
|
529 |
+
final_image_with_watermark = add_watermark(final_image, watermark_path)
|
530 |
+
return final_image_with_watermark
|
|
|
|
|
531 |
|
532 |
def save_image(canvas, output_folder, filename, output_format):
|
533 |
output_ext = 'jpg' if output_format == 'JPG' else 'png'
|
|
|
599 |
print(f"Error processing image {future_to_image[future]}: {e}")
|
600 |
|
601 |
output_zip_path = "processed_images.zip"
|
602 |
+
# Handle uploaded files
|
603 |
+
if isinstance(input_files, list):
|
604 |
+
images = [Image.open(file.name) for file in input_files]
|
605 |
+
else:
|
606 |
+
with zipfile.ZipFile(input_files.name, 'r') as zip_ref:
|
607 |
+
zip_ref.extractall("extracted_images")
|
608 |
+
images = [Image.open(os.path.join("extracted_images", f)) for f in os.listdir("extracted_images")]
|
609 |
+
|
610 |
+
# Background removal logic (placeholder)
|
611 |
+
for img in images:
|
612 |
+
# Implement background removal based on selected method
|
613 |
+
if bg_method == "rembg":
|
614 |
+
img = remove_background_with_rembg(img) # Placeholder function
|
615 |
+
elif bg_method == "bria":
|
616 |
+
img = remove_background_with_bria(img) # Placeholder function
|
617 |
+
|
618 |
+
# Add watermark if provided
|
619 |
+
if watermark:
|
620 |
+
watermark_img = Image.open(watermark.name).convert("RGBA")
|
621 |
+
img = add_watermark(img, watermark_img)
|
622 |
+
|
623 |
+
# Save processed image
|
624 |
+
output_path = f"processed_{len(processed_images)}.{output_format.lower()}"
|
625 |
+
img.save(output_path, format=output_format)
|
626 |
+
processed_images.append(output_path)
|
627 |
+
|
628 |
+
# Create a zip file of processed images
|
629 |
+
with zipfile.ZipFile(output_zip_path, 'w') as zipf:
|
630 |
+
for processed_img in processed_images:
|
631 |
+
zipf.write(processed_img)
|
632 |
+
|
633 |
+
return processed_images, output_zip_path
|
634 |
+
|
635 |
+
def add_watermark(image, watermark):
|
636 |
+
# Resize and position watermark
|
637 |
+
watermark = watermark.resize((image.width // 4, image.height // 4), Image.ANTIALIAS)
|
638 |
+
position = ((image.width - watermark.width) // 2, (image.height - watermark.height) // 2)
|
639 |
+
|
640 |
+
transparent = Image.new('RGBA', image.size, (0, 0, 0, 0))
|
641 |
+
transparent.paste(image.convert("RGBA"), (0, 0))
|
642 |
+
transparent.paste(watermark, position, watermark)
|
643 |
+
|
644 |
+
return transparent.convert("RGB")
|
645 |
+
|
646 |
+
def remove_background_with_rembg(image):
|
647 |
+
# Placeholder for actual background removal code
|
648 |
+
return image # Replace with actual removal logic
|
649 |
+
|
650 |
+
def remove_background_with_bria(image):
|
651 |
+
# Placeholder for actual background removal code
|
652 |
+
return image # Replace with actual removal logic
|
653 |
+
|
654 |
+
def show_color_picker(bg_choice):
|
655 |
+
return bg_choice == "custom"
|
656 |
+
|
657 |
+
def update_compare(selected_image):
|
658 |
+
# Logic to display original vs processed images
|
659 |
+
return selected_image, selected_image # Replace with actual images
|
660 |
+
|
661 |
with zipfile.ZipFile(output_zip_path, 'w') as zipf:
|
662 |
for file, _ in processed_images:
|
663 |
zipf.write(file, os.path.basename(file))
|