Spaces:
Runtime error
Runtime error
File size: 6,722 Bytes
7f88dd7 b4d7fed 56afb5e e08a64e 7022cc6 9365f85 c96caf0 5bdf543 9e24192 5bdf543 9e24192 7022cc6 277878d 7022cc6 6580737 7022cc6 5e47d3b 9365f85 b639502 8d5c6cf 9365f85 8d5c6cf c96caf0 8d5c6cf 9365f85 5bdf543 8d5c6cf 5bdf543 9365f85 51ede94 7022cc6 3dbe3d9 9365f85 72640c1 8d5c6cf 5bdf543 8d5c6cf 72640c1 8d5c6cf 5bdf543 1ee735f bcc8c8c 5bdf543 eaaccb1 72640c1 7022cc6 72640c1 7022cc6 2417919 fbaf836 2417919 9e24192 e793092 7f88dd7 46fd8e8 34d9197 c173614 34d9197 6ef6ed7 34d9197 72640c1 7f88dd7 72640c1 9e24192 e90bb7a 8d5c6cf e90bb7a 8d5c6cf 9365f85 72640c1 9365f85 51ede94 5bdf543 51ede94 9365f85 e90bb7a 38722bf eaaccb1 5bdf543 9e24192 8c0fcd2 72640c1 8d5c6cf e4cd716 eaaccb1 72640c1 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 205 206 207 |
import gradio as gr
import yt_dlp
import os
import json
from rembg import remove as rm
import cv2
import uuid
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}/{i}.png',frame_ff)
fbox.append(f'{uid}/{i}.png')
return fbox,fbox
def im_2_vid(images,fps):
#width, height = Image.open(images[0]).size
width, height = cv2.imread(images[0]).shape()
print (width,height)
size = (width, height)
codec = cv2.VideoWriter_fourcc(*'mp4v') #DIVX, DIVD
video = cv2.VideoWriter(vidName, codec, fps, size)
#Do not open images in 'Image' as well as 'CV2', else following error occurs
#<built-in function imread> returned NULL without setting an error
for img in images:
video.write(img)
return (video)
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)):
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_count}'
yield fbox2,frame_num,None
out_vid = im_2_vid(fbox2, fps)
return (fbox2,frame_num,out_vid)
def rem_bg_og(inp):
#transparent background .mov
#os.system(f'backgroundremover -i "{inp}" -tv -o "{inp}.mov"')
#video video to be overlayed output
#os.system(f' backgroundremover -i "/path/to/video.mp4" -tov "/path/to/videtobeoverlayed.mp4" -o "output.mov"')
#video over image file
#os.system(f'backgroundremover -i "/path/to/video.mp4" -toi "/path/to/videtobeoverlayed.mp4" -o "output.mov"')
#output to transparent GIF
#os.system(f'backgroundremover -i "/path/to/video.mp4" -tg -o "output.gif"')
#output to matte background
os.system(f'backgroundremover -i "{inp}" -mk -o "{inp}.matte.mp4"')
return f'{inp}.matte.mp4'
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_clip(inp):
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)
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"):
inp_url = gr.Textbox()
go_btn = gr.Button("Run")
with gr.Row():
with gr.Column():
outp_vid=gr.Video()
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.Tab("Trim"):
with gr.Row():
start_f=gr.Number(value=0)
end_f=gr.Number(value=1)
trim_btn=gr.Button("Trim")
with gr.Row():
in_trim = gr.Video()
out_trim=gr.Video()
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()
with gr.Column():
#rem_vid=gr.Video()
frame_num=gr.Textbox(label="Progress")
rem_vid=gr.Gallery(columns=6)
with gr.Row(visible=False):
text_input=gr.Textbox()
text_output=gr.Textbox()
url_params=gr.JSON()
in_trim.change(None,in_trim,out_trim)
trim_btn.click(trim_clip,in_trim,out_trim)
outp_vid.change(load_video,outp_vid,[frame_count,fps])
frame_btn.click(capture_function,[outp_vid],[frame_gal,frame_file])
rem_btn.click(rem_bg,[outp_vid],[rem_vid,frame_num])
go_btn.click(dl,inp_url,[outp_vid,in_vid,outp_file,in_trim])
app.load(fn=predict, inputs=[text_input,url_params], outputs=[text_output,text_input],_js=load_js)
app.launch()
|