上面这段代码中,主要完成3个功能:
cv2.VideoCapture()函数读取视频原文件并生成一个视频类对象;video.get(7)获取视频的总帧数。
video.read()有两个返回值,第一个表示获取下一帧数据是否成功,第二个存储了下一帧的数据内容。
cv2.imwrite()用于将帧数据储存为图片。这部分代码功能应该说比较简单,主要是对OpenCV包的运用。
02.图片转换
严格来说在这部分功能中需要做两件事,一是将原图转换为字符串,二是将字符串画入图片。主要用到了PIL包中的Image、ImageFont、ImageDraw三个类。
1).生成字符串在这一步中,我们需要逐一读入上一步中生成的原图,获取像素尺寸,并将每一个像素根据颜色和亮度转换为相应的字符(下面这段代码就是像素到字符的功能函数),然后将所有字符拼接为一整个字符串。
这个过程中有一点需要特别注意:在遍历图片像素时,每个像素的尺寸相当于1,而用于填充的字符尺寸一般比较大,如果直接用字符替换图片像素,那么转换后的图片将会远远超出图片范围。为此,在进行像素遍历前,需要将原图按一定比例进行缩小,其中纵向比例为单个字符的高度,横向比例为单个字符的宽度,当然,为例使转换后的图片更加美观,也可以自行定义行间距和字符间距。
2).生成字符图在这一步中