AP123's picture
Update app.py
c37474c verified
raw
history blame
6.4 kB
import gradio as gr
import requests
import base64
import json
import os
import logging
from time import sleep
# Configure logging
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
def file_to_base64(filepath):
with open(filepath, "rb") as file:
file_data = file.read()
base64_encoded_data = base64.b64encode(file_data)
base64_message = base64_encoded_data.decode('utf-8')
return base64_message
def submit_job(audio_file, preset, beat_sensitivity, fps, width, height):
# Check file size
file_size_mb = os.path.getsize(audio_file.name) / (1024 * 1024)
if file_size_mb > 3.5:
error_message = f"Error: File size is {file_size_mb:.2f}MB, which exceeds the 3.5MB limit."
logging.error(error_message)
return error_message, None
api_key = os.getenv('DEFORUM_API_KEY') # Ensure your environment variable is set
if not api_key:
error_message = "Error: API key is not set in environment variables"
logging.error(error_message)
return error_message, None
server = "https://deforum.studio"
api_url = f'{server}/api/public/v1/audiovis1'
headers = {
"Content-Type": "application/json",
"Authorization": f"Bearer {api_key}"
}
audio_base64 = file_to_base64(audio_file.name)
payload = {
"audioData": audio_base64,
"presetName": preset,
"beatSensitivity": beat_sensitivity,
"fps": fps,
"width": width,
"height": height
}
response = requests.post(api_url, headers=headers, json=payload)
if response.status_code != 201:
error_message = f"Error submitting job: {response.status_code} - {response.text}"
logging.error(error_message)
return error_message, None
data = response.json()
tracking_url = f"{server}{data['links']['audiovis1']}"
logging.info(f"Job submitted successfully. Tracking URL: {tracking_url}")
while True:
response = requests.get(tracking_url, headers=headers)
if response.status_code != 200:
error_message = f"Error getting job status: {response.text}"
logging.error(error_message)
return error_message, None
tracking_data = response.json()
logging.info(f"Job status: {tracking_data['status']}")
if tracking_data['status'] in ['canceled', 'failed', 'succeeded']:
break
sleep(10)
if tracking_data['status'] != 'succeeded':
error_message = f"Job ended with status: {tracking_data['status']}"
logging.error(error_message)
return error_message, None
else:
output_url = tracking_data['links']['outputUrls'][0]
logging.info(f"Job succeeded. Output URL: {output_url}")
return output_url
description1 = """
# Audio Visualizer Playground
### A way for you to easily create audio-synced animation masks for AnimateDiff or Deforum Animations.
"""
description2 = """
#### Please provide feedback for us about which masks you like, or would like to see in our animation channel in our Discord: [discord.gg/deforum](https://discord.gg/deforum)
"""
custom_css = """
@import url('//fonts.googleapis.com/css2?family=Open+Sans:wght@400;600;700&display=swap');
@import url('//fonts.googleapis.com/css?family=Aldrich&display=swap');
@import-normalize;
html, body {
height: 100%;
margin: 0;
font-family: 'Open Sans', sans-serif;
background-color: #121212;
color: #e0e0e0;
text-align: center;
}
.gradio-container {
max-width: 900px;
margin: 0 auto;
padding: 20px;
border-radius: 10px;
box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
background-color: #1e1e1e;
}
h1, h2, h3, h4, h5, h6 {
font-family: 'Aldrich', sans-serif;
color: #ffffff;
text-align: center;
}
label {
font-weight: bold;
color: #000000; /* Change label color to black */
text-align: center;
}
.gr-button {
background-color: #ff5722 !important;
color: #fff !important;
border: none !important;
padding: 10px 20px !important;
border-radius: 5px !important;
cursor: pointer !important;
transition: background-color 0.3s ease !important;
}
.gr-button:hover {
background-color: #e64a19 !important;
}
.gr-box, .gr-box-labeled, .gr-file, input[type=text], textarea, .gr-input, .gr-textbox input {
background-color: #444444 !important;
color: #e0e0e0 !important;
border: 1px solid #333333 !important;
border-radius: 5px !important;
padding: 10px !important;
}
.gr-file {
display: flex;
align-items: center;
justify-content: center;
height: 60px; /* Adjusted height */
border: 2px dashed #ff5722 !important;
transition: background-color 0.3s ease !important;
}
.gr-file:hover {
background-color: #555555 !important;
}
video, .gr-video {
border-radius: 5px !important;
}
.markdown-text {
color: #e0e0e0 !important;
}
"""
def main(audio_file, preset, beat_sensitivity, fps, width, height):
video_url = submit_job(audio_file, preset, beat_sensitivity, fps, width, height)
return video_url
with gr.Blocks(css=custom_css) as demo:
gr.Markdown(description1, elem_id="markdown-text")
gr.Markdown(description2, elem_id="markdown-text")
with gr.Group():
with gr.Column():
audio_file = gr.File(label="Upload MP3 File", file_types=['audio'])
preset = gr.Dropdown(label="Select Visualization Preset", choices=[
"pulsing-circles", "pulsing-hexagons", "pulsing-squares", "pulsing-triangles", "rotating-shapes"
])
with gr.Row():
beat_sensitivity = gr.Slider(label="Beat Sensitivity", minimum=1, maximum=5, step=0.1, value=3)
fps = gr.Slider(label="FPS", minimum=12, maximum=24, step=1, value=24)
with gr.Row():
width = gr.Slider(label="Width", minimum=512, maximum=1024, step=1, value=512)
height = gr.Slider(label="Height", minimum=512, maximum=1024, step=1, value=512)
submit_button = gr.Button("Submit")
output_video = gr.Video(label="Output MP4")
def update_output(video_url):
output_video.update(value=video_url, visible=True)
submit_button.click(main, inputs=[audio_file, preset, beat_sensitivity, fps, width, height], outputs=[output_video])
if __name__ == "__main__":
demo.launch()