Spaces:
Sleeping
Sleeping
| import gradio as gr | |
| import cv2 | |
| import numpy as np | |
| from PIL import Image, ImageOps | |
| def extract_components(image, component): | |
| image = np.array(image) | |
| if component == "Red Channel": | |
| red_channel = image.copy() | |
| red_channel[:, :, 1] = 0 # Zero out the green channel | |
| red_channel[:, :, 2] = 0 # Zero out the blue channel | |
| return Image.fromarray(red_channel) | |
| elif component == "Green Channel": | |
| green_channel = image.copy() | |
| green_channel[:, :, 0] = 0 # Zero out the red channel | |
| green_channel[:, :, 2] = 0 # Zero out the blue channel | |
| return Image.fromarray(green_channel) | |
| elif component == "Blue Channel": | |
| blue_channel = image.copy() | |
| blue_channel[:, :, 0] = 0 # Zero out the red channel | |
| blue_channel[:, :, 1] = 0 # Zero out the green channel | |
| return Image.fromarray(blue_channel) | |
| elif component == "Grayscale": | |
| grayscale = cv2.cvtColor(image, cv2.COLOR_RGB2GRAY) | |
| return Image.fromarray(grayscale) | |
| elif component == "Edges": | |
| grayscale = cv2.cvtColor(image, cv2.COLOR_RGB2GRAY) | |
| edges = cv2.Canny(grayscale, 100, 200) | |
| return Image.fromarray(edges) | |
| elif component == "Original": | |
| return Image.fromarray(image) | |
| else: | |
| return Image.fromarray(image) | |
| # Define the Gradio interface | |
| iface = gr.Interface( | |
| fn=extract_components, | |
| inputs=[ | |
| gr.Image(label="Input Image"), | |
| gr.Radio(["Red Channel", "Green Channel", "Blue Channel", "Grayscale", "Edges", "Original"], label="Select Component") | |
| ], | |
| outputs=gr.Image(label="Output Image"), | |
| title="Image to Components", | |
| description="Extract different components from an image (e.g., RGB channels, grayscale, edges)", | |
| theme='NoCrypt/miku' | |
| ) | |
| # Launch the app | |
| iface.launch(share=True) |