基本的思路如下:
1. 視頻文件轉圖片
2.對圖片處理,生成字符畫
3. 合成字符畫到視頻
主要代碼如下,需要修改的為路徑,如果需要生成多種不同的效果,可以根據像素的值進行個性化設計。
# coding:utf-8
# Copyright@hitzym
# video2img
# Dec,7,2017
import cv2
vc=cv2.VideoCapture("~/video.mp4")
c=1
if vc.isOpened():
rval,frame=vc.read()
else:
rval=False
while rval:
rval,frame=vc.read()
rows, cols, channel = frame.shape
# frame2=cv2.resize(frame,(cols/3,rows/3),fx=0,fy=0,interpolation=cv2.INTER_AREA)
if ( c%5 == 0): #every 5 fps write frame to img
cv2.imwrite(('./yourImgPath/'+str(c)+'.jpg'),frame)
# cropped001 = frame2[0:300,300:600] #y change from 0 to 300 x change from 300 to 600
# cv2.imwrite('./cropped/'+str(c)+'_001.jpg',cropped001)
c=c+1
cv2.waitKey(1)
vc.release()
《群交流605018913》
PIL修代碼:
#-*- coding: UTF-8 -*-
from PIL import Image
from PIL import ImageDraw
from PIL import ImageFont
import matplotlib.pyplot as plt
import numpy as np
import time
def pic(srd_img_file_path, dst_img_file_path = None, scale = 2, sample_step = 3):
start_time = int(time.time())
#讀取圖片信息
old_img = Image.open(srd_img_file_path)
pix = old_img.load()
width = old_img.size[0]
height = old_img.size[1]
print ("width:%d, height:%d" % (width, height))
#創建新圖片
canvas = np.ndarray((height*scale, width*scale, 3), np.uint8)
canvas[:, :, :] = 255
new_image = Image.fromarray(canvas)
draw = ImageDraw.Draw(new_image)
#創建繪制對象
font = ImageFont.truetype("consola.ttf", 10, encoding="unic")
char_table = list('happy new year ')
# font = ImageFont.truetype('simsun.ttc', 10)
# char_table = list(u'新年快樂')
#開始繪制
pix_count = 0
table_len = len(char_table)
for y in range(height):
for x in range(width):
if x % sample_step == 0 and y % sample_step == 0:
draw.text((x*scale, y*scale), char_table[pix_count % table_len], pix[x, y], font)
pix_count += 1
# 保存
if dst_img_file_path is not None:
new_image.save(dst_img_file_path)
print("used time : %d second, pix_count : %d" % ((int(time.time()) - start_time), pix_count))
print(pix_count)
new_image.show()
pic("input.jpg", "output.jpg")
具體代碼待添加,是在原作者的基礎之上修改得到的。顯示結果如下