mirror of https://github.com/menyifang/DCT-Net
update
parent
b63066fa9a
commit
d3c83d8a62
@ -0,0 +1,42 @@
|
||||
import cv2, argparse
|
||||
import imageio
|
||||
from tqdm import tqdm
|
||||
import numpy as np
|
||||
from modelscope.outputs import OutputKeys
|
||||
from modelscope.pipelines import pipeline
|
||||
from modelscope.utils.constant import Tasks
|
||||
|
||||
def process(args):
|
||||
style = args.style
|
||||
print('choose style %s'%style)
|
||||
|
||||
reader = imageio.get_reader(args.video_path)
|
||||
fps = reader.get_meta_data()['fps']
|
||||
writer = imageio.get_writer(args.save_path, mode='I', fps=fps, codec='libx264')
|
||||
|
||||
if style == "anime":
|
||||
style = ""
|
||||
else:
|
||||
style = '-' + style
|
||||
|
||||
model_name = 'damo/cv_unet_person-image-cartoon' + style + '_compound-models'
|
||||
img_cartoon = pipeline(Tasks.image_portrait_stylization, model=model_name)
|
||||
|
||||
for _, img in tqdm(enumerate(reader)):
|
||||
result = img_cartoon(img[..., ::-1])
|
||||
res = result[OutputKeys.OUTPUT_IMG]
|
||||
writer.append_data(res[..., ::-1].astype(np.uint8))
|
||||
writer.close()
|
||||
print('finished!')
|
||||
print('result saved to %s'% args.save_path)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
parser = argparse.ArgumentParser()
|
||||
parser.add_argument('--video_path', type=str, default='PATH/TO/YOUR/MP4')
|
||||
parser.add_argument('--save_path', type=str, default='res.mp4')
|
||||
parser.add_argument('--style', type=str, default='anime')
|
||||
|
||||
args = parser.parse_args()
|
||||
|
||||
process(args)
|
Loading…
Reference in New Issue