当前位置:   article > 正文

python 用OpenCV 将图片转视频_cv2.videowriter

cv2.videowriter
  1. import os
  2. import cv2
  3. import numpy as np
  4. cv2.VideoWriter()参数 cv2.VideoWriter() 是 OpenCV 中用于创建视频文件的类。它的参数如下:
  5. filename:保存视频的文件名。
  6. fourcc:指定视频编解码器的 FourCC 代码,用于将视频压缩成指定格式,例如:“XVID”、“MJPG”, "mp4v"等。可以使用 cv2.VideoWriter_fourcc() 函数来获取 FourCC 代码。
  7. fps:指定视频帧率,即每秒显示的帧数。
  8. frameSize:指定视频帧的大小,即视频的分辨率,可以使用 (width, height) 形式的元组来指定。
  9. isColor:指定是否为彩色视频。如果为 True,则为彩色视频;如果为 False,则为灰度视频。
  10. 其中,前三个参数是必需的,后两个参数是可选的。例如:
  11. fps = 25
  12. # cv2.VideoWriter('output.avi', cv2.VideoWriter_fourcc(*'XVID'), fps, (640, 480))
  13. def resize_img(target_size, image_paths):
  14. #target_size = (1000, 1000) # 所有图片缩放设置一致尺寸,目标尺寸
  15. #image_paths= './images'
  16. path_new = './images_new'
  17. if not os.path.exists(path_new):
  18. os.makedirs(path_new)
  19. filelists = []
  20. imglist = []
  21. for i in os.listdir(image_paths):
  22. file_path = os.path.join(image_paths, i)
  23. print(file_path)
  24. img = cv2.imdecode(np.fromfile(file_path, dtype=np.uint8), cv2.IMREAD_COLOR)
  25. size = img.shape
  26. h, w = size[0], size[1]
  27. target_h, target_w = target_size[1], target_size[0]
  28. # 确定缩放的尺寸
  29. scale_h, scale_w = float(h / target_h), float(w / target_w)
  30. print(f'scale_h:{scale_h}, scale_w:{scale_w}')
  31. scale = max(scale_h, scale_w) # 选择最大的缩放比率
  32. new_w, new_h = int(w / scale), int(h / scale)
  33. # 缩放后其中一条边和目标尺寸一致
  34. resize_img = cv2.resize(img, (new_w, new_h))
  35. # 图像上、下、左、右边界分别需要扩充的像素数目
  36. top = int((target_h - new_h) / 2)
  37. bottom = target_h - new_h - top
  38. left = int((target_w - new_w) / 2)
  39. right = target_w - new_w - left
  40. print(f'top:{top} bottom:{bottom} left:{left} right:{right}')
  41. cv2.imwrite(os.path.join(path_new, f'new_{i}'), resize_img) # 写入本地文件
  42. # 填充至 target_w * target_h
  43. pad_img = cv2.copyMakeBorder(resize_img, top, bottom, left, right, cv2.BORDER_CONSTANT, value=[0, 0, 0])
  44. # cv2.imshow('img', pad_img)
  45. # cv2.waitKey(1000)
  46. filelists.append(os.path.join(path_new, f'new_{i}'))
  47. imglist.append(pad_img)
  48. return filelists, imglist
  49. def cut_img(scale):
  50. # 读取本地图片文件夹
  51. path = './images'
  52. path_new = './images_new'
  53. if not os.path.exists(path_new):
  54. os.makedirs(path_new)
  55. filelists = []
  56. imglist = []
  57. for i in os.listdir(path):
  58. file_path = os.path.join(path, i)
  59. print(file_path)
  60. img = cv2.imdecode(np.fromfile(file_path, dtype=np.uint8), cv2.IMREAD_COLOR)
  61. size = img.shape
  62. h, w = size[0], size[1]
  63. rate1 = scale.split(':')
  64. w1 = int((w - w * int(rate1[0]) / int(rate1[1])) / 2)
  65. w2 = int(w - (w - w * int(rate1[0]) / int(rate1[1])) / 2)
  66. resize_img = img[0:h, w1:w2]
  67. cv2.imwrite(os.path.join(path_new, f'new_{i}'), resize_img) # 写入本地文件
  68. filelists.append(os.path.join(path_new, f'new_{i}'))
  69. imglist.append(resize_img)
  70. return filelists, imglist
  71. def cut_img1(images, scale):
  72. # 接收图片链接
  73. imglist = []
  74. filelists = []
  75. for i in images:
  76. img_url = i
  77. file_name = img_url.split('/')[-1]
  78. path_new = f'./images_new/{file_name}'
  79. try:
  80. res = requests.get(img_url)
  81. except:
  82. continue
  83. if 'RIFF' in str(res.content)[:500] or 'GIF' in str(res.content)[:500]:
  84. file_name = file_name.split('.')[0] + '.jpg'
  85. path_new1 = f'./images_new/{file_name}'
  86. img = Image.open(BytesIO(res.content)).convert('RGB')
  87. img.save(path_new1)
  88. img = cv2.imdecode(np.fromfile(path_new1, dtype=np.uint8), cv2.IMREAD_COLOR)
  89. else:
  90. image = np.asarray(bytearray(res.content), dtype="uint8")
  91. img = cv2.imdecode(image, cv2.IMREAD_COLOR)
  92. size = img.shape
  93. h, w = size[0], size[1]
  94. rate1 = scale.split(':')
  95. w1 = int((w - w * int(rate1[0]) / int(rate1[1])) / 2)
  96. w2 = int(w - (w - w * int(rate1[0]) / int(rate1[1])) / 2)
  97. resize_img = img[0:h, w1:w2]
  98. imglist.append(resize_img)
  99. filelists.append(resize_img.shape)
  100. return filelists, imglist
  101. def image_to_video():
  102. scale = '1:1' # 裁剪比例,并保持高度不变
  103. # scale = '3:4'
  104. # scale = '9:16'
  105. # 前提是所有图片尺寸一致,将图片按比例裁剪
  106. filelists, imglist = cut_img(scale)
  107. # target_size = (1000, 1000) # 指定尺寸
  108. # image_paths = './images' # 本地图片文件夹路径
  109. # 缩放, 将所有图片尺寸缩放或者扩大到指定尺寸
  110. # filelists, imglist = resize_img(target_size, image_paths)
  111. fourcc = cv2.VideoWriter.fourcc(*'avc1') #avc1模式下生成的视频上传到oss后链接可以在浏览器访问 mp4v模式下生成的视频需要用ffmpeg将视频格式转成H264
  112. im = cv2.imread(filelists[0])
  113. print(im.shape)
  114. shape1 = (im.shape[1], im.shape[0]) #需要转为视频的图片的尺寸, 视频的分辨率
  115. print('shape1:', shape1)
  116. fps = 1
  117. writer = cv2.VideoWriter('./output.mp4', fourcc, fps , shape1)
  118. # for file_path in filelists:
  119. # img = cv2.imread(file_path)
  120. # writer.write(img)
  121. for i in imglist:
  122. writer.write(i)
  123. writer.release()
  124. image_to_video()

 我们无法打开output3.mp4。这可能是因为文件类型不受支
持、文件扩展名不正确或文件已损坏,0xC00D36C4

如果生成的视频报这个错,一般是视频的分辨率 设置的不匹配

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号