Spaces:
Runtime error
Runtime error
File size: 7,197 Bytes
7f88dd7 b4d7fed 56afb5e e08a64e 7022cc6 9365f85 6e911c2 9c951eb 6e911c2 9365f85 c96caf0 9e24192 7022cc6 277878d 7022cc6 6580737 7022cc6 5e47d3b 9365f85 b639502 8d5c6cf 9365f85 8d5c6cf c96caf0 8d5c6cf 9365f85 5bdf543 8d5c6cf 9365f85 4c19d70 3dbe3d9 9365f85 72640c1 cca509e 08fb439 432842f 72640c1 9c951eb 0e3908d 9c951eb 9bc8da2 8d5c6cf 5bdf543 8d5c6cf 72640c1 5bdf543 32c6768 5bdf543 1ee735f bcc8c8c 5bdf543 b44437d 72640c1 372e86a 8adb1e7 4c19d70 432842f 9e24192 e793092 7f88dd7 46fd8e8 34d9197 c173614 34d9197 6ef6ed7 34d9197 72640c1 6e911c2 968d89a 6e911c2 968d89a a11a136 6e911c2 72640c1 6e911c2 72640c1 7f88dd7 9e24192 e90bb7a cca509e 968d89a e90bb7a 8d5c6cf 9365f85 cca509e 968d89a 1161227 9365f85 51ede94 5bdf543 51ede94 9365f85 e90bb7a 968d89a e90bb7a 38722bf eaaccb1 5bdf543 b44437d 9e24192 8c0fcd2 6e911c2 1161227 cca509e 1161227 b44437d cca509e 9e24192 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 |
import gradio as gr
import yt_dlp
import os
import json
from rembg import remove as rm
import cv2
import uuid
from moviepy.video.io.ffmpeg_tools import ffmpeg_extract_subclip
import moviepy.video.io.ImageSequenceClip
uid=uuid.uuid4()
if not os.path.exists(f'{uid}-frames'): os.makedirs(f'{uid}-frames')
if not os.path.exists(f'{uid}-rembg'): os.makedirs(f'{uid}-rembg')
load_js = """
function(text_input, url_params) {
console.log(text_input, url_params);
const params = new URLSearchParams(window.location.search);
url_params = Object.fromEntries(params);
return [text_input, url_params]
}
"""
def rem_cv(inp):
cap = cv2.VideoCapture(f'{inp}')
kernel = cv2.getStructuringElement(cv2.MORPH_ELLIPSE,(3,3))
fgbg = cv2.bgsegm.createBackgroundSubtractorGMG()
while True:
ret, frame = cap.read()
fgmask = fgbg.apply(frame)
fgmask = cv2.morphologyEx(fgmask, cv2.MORPH_OPEN, kernel)
yield (fgmask)
def load_video(vid):
new_video_in = str(vid)
capture = cv2.VideoCapture(new_video_in)
fps = capture.get(cv2.CAP_PROP_FPS)
#print (f'FPS:: {fps}')
frame_count = int(capture.get(cv2.CAP_PROP_FRAME_COUNT))
capture.release()
return frame_count, fps
def capture_function(vid=None):
new_video_in = str(vid)
capture = cv2.VideoCapture(new_video_in)
frame_count = int(capture.get(cv2.CAP_PROP_FRAME_COUNT))
fbox=[]
cnt=0
frame_count1= int(frame_count)
for i in range(int(frame_count1)):
capture.set(cv2.CAP_PROP_POS_FRAMES, i)
ret, frame_f = capture.read(i)
frame_ff = cv2.cvtColor(frame_f, cv2.COLOR_BGR2RGB)
cv2.imwrite(f'{uid}-frames/{i}.png',frame_ff)
fbox.append(f'{uid}-frames/{i}.png')
return fbox,fbox
def im_2_vid(images,fps):
#width, height = Image.open(images[0]).size
this_im=cv2.imread(images[0])
height=this_im.shape[0]
width= this_im.shape[1]
print (width,height)
size = (width, height)
movie_clip = moviepy.video.io.ImageSequenceClip.ImageSequenceClip(images, fps)
movie_clip.write_videofile(f'{uid}-rembg/bg_removed-{uid}.mp4')
#codec = cv2.VideoWriter_fourcc(*'mp4v') #DIVX, DIVD
#video = cv2.VideoWriter("tmp_vid.mp4", codec, fps, size)
#for img in images:
# video.write(img)
return (f'{uid}-rembg/bg_removed-{uid}.mp4', f'{uid}-rembg/bg_removed-{uid}.mp4')
def rem_bg(vid):
new_video_in = str(vid)
capture = cv2.VideoCapture(new_video_in)
frame_count = int(capture.get(cv2.CAP_PROP_FRAME_COUNT))
fps = capture.get(cv2.CAP_PROP_FPS)
fbox2=[]
cnt=0
frame_count1= int(frame_count)
for i in range(int(frame_count1)-1):
capture.set(cv2.CAP_PROP_POS_FRAMES, i)
ret, frame_f = capture.read(i)
#frame_ff = cv2.cvtColor(frame_f, cv2.COLOR_BGR2RGB)
out = rm(frame_f)
print (i)
cv2.imwrite(f'{uid}-rembg/{i}.png',out)
fbox2.append(f'{uid}-rembg/{i}.png')
frame_num=f'Working on {i+1} of {frame_count1-1}'
yield fbox2,frame_num,None
frame_num=f'Done: {i+1} of {frame_count1-1}'
out_vid,_file = im_2_vid(fbox2, fps)
yield (fbox2,frame_num,out_vid)
def predict(text, url_params):
mod_url=""
mod=gr.HTML("")
out = None
valid=gr.update(visible=False)
mod_url = url_params.get('url')
print (mod_url)
return ["" + text + "", mod_url]
def dl(inp):
out = None
out_file=[]
try:
inp_out=inp.replace("https://","")
inp_out=inp_out.replace("/","_").replace(".","_")
os.system(f'yt-dlp "{inp}" --trim-filenames 100 -o "{inp_out}.mp4"')
out = f"{inp_out}.mp4"
except Exception as e:
print (e)
out = None
return out,out,out,out
def trim_vid(vid,start_time,end_time):
print (vid)
start_hr=int(start_time.split(":",2)[0])*360
start_min=int(start_time.split(":",2)[1])*60
start_sec=int(start_time.split(":",2)[2])
end_hr=int(end_time.split(":",2)[0])*360
end_min=int(end_time.split(":",2)[1])*60
end_sec=int(end_time.split(":",2)[2])
start=start_hr+start_min+start_sec
end=end_hr+end_min+end_sec
#vid = f"{uid}-tmp.mp4"
ffmpeg_extract_subclip(vid, start, end, targetname=f"{uid}-clip.mp4")
out= f"{uid}-clip.mp4"
return out,out
def other():
new_video_in = str(vid)
capture = cv2.VideoCapture(new_video_in)
frame_count = int(capture.get(cv2.CAP_PROP_FRAME_COUNT))
fps = capture.get(cv2.CAP_PROP_FPS)
fbox3=[]
frame_count1= int(frame_count)
start = (int(fps*int(start_f)))
capture.set(cv2.CAP_PROP_POS_FRAMES, i-1)
for i in range(int(frame_count1)):
capture.set(cv2.CAP_PROP_POS_FRAMES, i)
ret, frame_f = capture.read(i)
#frame_ff = cv2.cvtColor(frame_f, cv2.COLOR_BGR2RGB)
out = rm(frame_f)
print (i)
cv2.imwrite(f'{uid}-rembg/{i}.png',out)
fbox3.append(f'{uid}-rembg/{i}.png')
frame_num=f'Working on {i+1} of {frame_count}'
yield fbox2,frame_num,None
with gr.Blocks() as app:
with gr.Tab("Load"):
with gr.Row():
with gr.Column():
inp_url = gr.Textbox()
go_btn = gr.Button("Run")
outp_vid=gr.Video(format="mp4")
with gr.Column():
with gr.Row():
frame_count=gr.Textbox(label="Frame Count",interactive = False)
fps=gr.Textbox(label="FPS",interactive = False)
outp_file=gr.Files()
with gr.Row():
start_f = gr.Textbox(label = "Start", value = "0:00:00", placeholder = "0:00:23")
end_f = gr.Textbox(label = "End", value = "0:00:05", placeholder = "0:00:54")
trim_btn=gr.Button("Trim")
out_trim=gr.Video(format="mp4")
with gr.Tab("Frames"):
frame_btn = gr.Button("Get Frames")
with gr.Row():
with gr.Column():
frame_gal = gr.Gallery(columns=6)
with gr.Column():
frame_file = gr.Files()
with gr.Tab("Rem BG"):
with gr.Row():
with gr.Column():
rem_btn=gr.Button()
in_vid=gr.Video(format="mp4")
with gr.Column():
#rem_vid=gr.Video()
frame_num=gr.Textbox(label="Progress")
rem_vid=gr.Gallery(columns=6)
rem_bg_vid=gr.Video()
with gr.Row(visible=False):
text_input=gr.Textbox()
text_output=gr.Textbox()
url_params=gr.JSON()
def echo_fn(inp):
return inp
#outp_vid.change(echo_fn,outp_vid,[out_trim])
trim_btn.click(trim_vid,[outp_vid,start_f,end_f],[out_trim,in_vid])
outp_vid.change(load_video,outp_vid,[frame_count,fps]).then(echo_fn,outp_vid,[out_trim])
frame_btn.click(capture_function,[out_trim],[frame_gal,frame_file])
rem_btn.click(rem_bg,[out_trim],[rem_vid,frame_num,rem_bg_vid])
go_btn.click(dl,inp_url,[outp_vid,outp_file,out_trim])
app.load(fn=predict, inputs=[text_input,url_params], outputs=[text_output,text_input],_js=load_js)
app.launch()
|