Spaces:
Running
Running
import requests | |
import gradio as gr | |
import os | |
import json | |
import base64 | |
# π Form-like Configuration Section - Easily customize your script settings here! | |
# ----------------------------------------------------------- | |
# Server Configuration - Change these to match your server! | |
fooocus_host = 'http://192.168.50.136:7878' # π Host address for the Fooocus server | |
# π File Paths - Change these paths if your images are stored in a different location! | |
imgs_base_path = "./saved_images" # Define the base path for saving images | |
# Headers for HTTP Requests - Modify if needed! | |
headers = { | |
"accept": "application/json" | |
} | |
# ----------------------------------------------------------- | |
# π οΈ Utility Functions - These functions perform the core operations of the script. | |
# Function to encode images to base64 - This helps in preparing images for API requests. | |
def encode_image_to_base64(image_path): | |
with open(image_path, "rb") as image_file: | |
return base64.b64encode(image_file.read()).decode('utf-8') | |
# Function to save images from API response - This saves the processed images locally. | |
def save_image_from_response(response, base_filename="generated-image"): | |
if not os.path.exists(imgs_base_path): | |
os.makedirs(imgs_base_path) # Create the directory if it does not exist | |
output_path = os.path.join(imgs_base_path, base_filename) | |
for i, item in enumerate(response, start=1): | |
if item.get('url'): | |
modified_url = item['url'].replace('http://127.0.0.1:7878', fooocus_host) | |
img_data = requests.get(modified_url).content | |
with open(f"{output_path}{i}.png", 'wb') as handler: | |
handler.write(img_data) | |
print(f"πΌοΈ Image saved as {output_path}{i}.png") | |
# Enhanced Gradio app for text and image prompt generation | |
def generate_image_from_prompt(prompt, image_file=None): | |
api_url = f"{fooocus_host}/v1/generation/text-to-image" | |
request_payload = {"prompt": prompt} | |
if image_file: | |
image_base64 = encode_image_to_base64(image_file.name) | |
request_payload["image_prompt"] = image_base64 # Add image prompt if provided | |
response = requests.post(api_url, json=request_payload, headers=headers) | |
if response.status_code == 200: | |
result = response.json() | |
if isinstance(result, list) and len(result) > 0: | |
save_image_from_response(result, "generated-image") | |
image_url = result[0].get("url") # Assuming the first item in the list contains the URL | |
if image_url: | |
modified_url = image_url.replace('http://127.0.0.1:7878', fooocus_host) | |
return f"<img src='{modified_url}'/>" # Return an HTML image tag with the modified URL | |
else: | |
return "Error: URL not found in response." | |
elif isinstance(result, dict): | |
save_image_from_response([result], "generated-image-single") # Save single image response | |
image_url = result.get("url") | |
if image_url: | |
modified_url = image_url.replace('http://127.0.0.1:7878', fooocus_host) | |
return f"<img src='{modified_url}'/>" # Return an HTML image tag with the modified URL | |
else: | |
return "Error: URL not found in response." | |
else: | |
return "Error: Unexpected response format. Please try again." | |
else: | |
return f"Error: Could not generate image. Status code: {response.status_code}" | |
iface = gr.Interface( | |
fn=generate_image_from_prompt, | |
inputs=[gr.Textbox(label="Enter your prompt"), gr.File(label="Upload an image prompt (optional)")], | |
outputs=gr.HTML(label="Generated Image"), # Adjusted to handle image URLs via HTML | |
title="Enhanced Image Generator", | |
description="Enter a prompt and optionally upload an image to generate an image using the API. Images are saved locally." | |
) | |
if __name__ == "__main__": | |
iface.launch() | |