Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
|
@@ -2,6 +2,7 @@ import tempfile
|
|
| 2 |
import logging
|
| 3 |
import os
|
| 4 |
import asyncio
|
|
|
|
| 5 |
from moviepy.editor import *
|
| 6 |
import edge_tts
|
| 7 |
import gradio as gr
|
|
@@ -14,7 +15,7 @@ logging.basicConfig(level=logging.INFO, format="%(asctime)s - %(levelname)s - %(
|
|
| 14 |
INTRO_VIDEO = "introvideo.mp4"
|
| 15 |
OUTRO_VIDEO = "outrovideo.mp4"
|
| 16 |
MUSIC_BG = "musicafondo.mp3"
|
| 17 |
-
FX_GLITCH = "glitch.mp4"
|
| 18 |
EJEMPLO_VIDEO = "ejemplo.mp4"
|
| 19 |
|
| 20 |
# Validar existencia de archivos
|
|
@@ -34,7 +35,7 @@ def eliminar_archivo_tiempo(ruta, delay=1800):
|
|
| 34 |
from threading import Timer
|
| 35 |
Timer(delay, eliminar).start()
|
| 36 |
|
| 37 |
-
async def procesar_audio(texto, voz, duracion_video):
|
| 38 |
temp_files = []
|
| 39 |
try:
|
| 40 |
# Generar TTS
|
|
@@ -61,11 +62,12 @@ async def procesar_audio(texto, voz, duracion_video):
|
|
| 61 |
temp_files.append(tmp_bg.name)
|
| 62 |
|
| 63 |
# Combinar audios
|
| 64 |
-
|
| 65 |
-
|
| 66 |
-
|
| 67 |
-
|
| 68 |
|
|
|
|
| 69 |
return audio_final
|
| 70 |
|
| 71 |
except Exception as e:
|
|
@@ -79,9 +81,8 @@ async def procesar_audio(texto, voz, duracion_video):
|
|
| 79 |
logging.warning(f"Error limpiando {file}: {e}")
|
| 80 |
|
| 81 |
def agregar_glitch(video, intervalo=40):
|
| 82 |
-
"""Agrega glitch cada X segundos SIN
|
| 83 |
-
glitch = VideoFileClip(FX_GLITCH)
|
| 84 |
-
duracion_glitch = glitch.duration
|
| 85 |
duracion_video = video.duration
|
| 86 |
|
| 87 |
# Crear glitches en intervalos
|
|
@@ -90,7 +91,6 @@ def agregar_glitch(video, intervalo=40):
|
|
| 90 |
glitch_clip = glitch.set_start(t).set_pos("center")
|
| 91 |
glitches.append(glitch_clip)
|
| 92 |
|
| 93 |
-
# Superponer glitches al video original
|
| 94 |
return CompositeVideoClip([video] + glitches)
|
| 95 |
|
| 96 |
async def procesar_video(video_input, texto_tts, voz_seleccionada):
|
|
@@ -99,12 +99,18 @@ async def procesar_video(video_input, texto_tts, voz_seleccionada):
|
|
| 99 |
intro = VideoFileClip(INTRO_VIDEO)
|
| 100 |
outro = VideoFileClip(OUTRO_VIDEO)
|
| 101 |
video_original = VideoFileClip(video_input)
|
|
|
|
| 102 |
|
| 103 |
# Duraci贸n del video editado (sin intro/outro)
|
| 104 |
duracion_video = video_original.duration
|
| 105 |
|
| 106 |
# Procesar audio
|
| 107 |
-
audio_final = await procesar_audio(
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 108 |
|
| 109 |
# Agregar glitch al video original
|
| 110 |
video_con_glitch = agregar_glitch(video_original, intervalo=40)
|
|
@@ -124,7 +130,7 @@ async def procesar_video(video_input, texto_tts, voz_seleccionada):
|
|
| 124 |
tmp.name,
|
| 125 |
codec="libx264",
|
| 126 |
audio_codec="aac",
|
| 127 |
-
fps=video_original.fps,
|
| 128 |
threads=4,
|
| 129 |
verbose=False
|
| 130 |
)
|
|
|
|
| 2 |
import logging
|
| 3 |
import os
|
| 4 |
import asyncio
|
| 5 |
+
import math # <-- M贸dulo a帽adido
|
| 6 |
from moviepy.editor import *
|
| 7 |
import edge_tts
|
| 8 |
import gradio as gr
|
|
|
|
| 15 |
INTRO_VIDEO = "introvideo.mp4"
|
| 16 |
OUTRO_VIDEO = "outrovideo.mp4"
|
| 17 |
MUSIC_BG = "musicafondo.mp3"
|
| 18 |
+
FX_GLITCH = "glitch.mp4"
|
| 19 |
EJEMPLO_VIDEO = "ejemplo.mp4"
|
| 20 |
|
| 21 |
# Validar existencia de archivos
|
|
|
|
| 35 |
from threading import Timer
|
| 36 |
Timer(delay, eliminar).start()
|
| 37 |
|
| 38 |
+
async def procesar_audio(texto, voz, duracion_video, audio_original):
|
| 39 |
temp_files = []
|
| 40 |
try:
|
| 41 |
# Generar TTS
|
|
|
|
| 62 |
temp_files.append(tmp_bg.name)
|
| 63 |
|
| 64 |
# Combinar audios
|
| 65 |
+
audios = [bg_audio.set_duration(duracion_video)]
|
| 66 |
+
if audio_original:
|
| 67 |
+
audios.append(audio_original.volumex(0.7)) # Audio original al 70%
|
| 68 |
+
audios.append(tts_audio.volumex(0.85).set_start(0)) # TTS al 85%
|
| 69 |
|
| 70 |
+
audio_final = CompositeAudioClip(audios).set_duration(duracion_video)
|
| 71 |
return audio_final
|
| 72 |
|
| 73 |
except Exception as e:
|
|
|
|
| 81 |
logging.warning(f"Error limpiando {file}: {e}")
|
| 82 |
|
| 83 |
def agregar_glitch(video, intervalo=40):
|
| 84 |
+
"""Agrega glitch cada X segundos SIN alterar velocidad"""
|
| 85 |
+
glitch = VideoFileClip(FX_GLITCH)
|
|
|
|
| 86 |
duracion_video = video.duration
|
| 87 |
|
| 88 |
# Crear glitches en intervalos
|
|
|
|
| 91 |
glitch_clip = glitch.set_start(t).set_pos("center")
|
| 92 |
glitches.append(glitch_clip)
|
| 93 |
|
|
|
|
| 94 |
return CompositeVideoClip([video] + glitches)
|
| 95 |
|
| 96 |
async def procesar_video(video_input, texto_tts, voz_seleccionada):
|
|
|
|
| 99 |
intro = VideoFileClip(INTRO_VIDEO)
|
| 100 |
outro = VideoFileClip(OUTRO_VIDEO)
|
| 101 |
video_original = VideoFileClip(video_input)
|
| 102 |
+
audio_original = video_original.audio
|
| 103 |
|
| 104 |
# Duraci贸n del video editado (sin intro/outro)
|
| 105 |
duracion_video = video_original.duration
|
| 106 |
|
| 107 |
# Procesar audio
|
| 108 |
+
audio_final = await procesar_audio(
|
| 109 |
+
texto_tts,
|
| 110 |
+
voz_seleccionada,
|
| 111 |
+
duracion_video,
|
| 112 |
+
audio_original
|
| 113 |
+
)
|
| 114 |
|
| 115 |
# Agregar glitch al video original
|
| 116 |
video_con_glitch = agregar_glitch(video_original, intervalo=40)
|
|
|
|
| 130 |
tmp.name,
|
| 131 |
codec="libx264",
|
| 132 |
audio_codec="aac",
|
| 133 |
+
fps=video_original.fps,
|
| 134 |
threads=4,
|
| 135 |
verbose=False
|
| 136 |
)
|