opencv视频抽帧对比图像,从第一帧开始,每隔30帧抽一次,如果不符合要求可以往前退四帧再进行比较,代码

时间: 2023-09-13 14:05:55 浏览: 56
### 回答1: 下面是一个基于 OpenCV 的 Python 实现,使用了视频的第一帧作为基准帧,每隔 30 帧抽取一帧进行比较,如果不符合要求,则向前移动 4 帧再进行比较。比较方法使用了 MSE(均方误差)来计算像素差异。 ```python import cv2 # 打开视频文件 cap = cv2.VideoCapture('video.mp4') # 读取第一帧作为基准帧 _, frame1 = cap.read() gray1 = cv2.cvtColor(frame1, cv2.COLOR_BGR2GRAY) # 视频帧率 fps = cap.get(cv2.CAP_PROP_FPS) # 每隔 30 帧抽取一帧进行比较 interval = int(fps * 30) while True: # 读取一帧 _, frame2 = cap.read() if not _: break # 转为灰度图 gray2 = cv2.cvtColor(frame2, cv2.COLOR_BGR2GRAY) # 计算当前帧与基准帧的 MSE mse = ((gray1 - gray2) ** 2).mean() # 如果不符合要求,则向前移动 4 帧再进行比较 if mse > 100: for i in range(4): _, frame2 = cap.read() if not _: break gray2 = cv2.cvtColor(frame2, cv2.COLOR_BGR2GRAY) mse = ((gray1 - gray2) ** 2).mean() if mse < 100: break # 显示当前帧 cv2.imshow('Frame', frame2) # 更新基准帧 gray1 = gray2.copy() # 每隔 interval 帧进行比较 for i in range(interval - 1): _, _ = cap.read() # 按下 q 键退出循环 if cv2.waitKey(1) == ord('q'): break cap.release() cv2.destroyAllWindows() ``` 其中,`cap.get(cv2.CAP_PROP_FPS)` 用于获取视频的帧率,`cv2.waitKey(1)` 用于等待用户按下键盘上的按键,其中 `1` 表示等待时间为 1 毫秒,避免界面卡死。 ### 回答2: 首先,我需要根据要求加载并处理视频文件。在OpenCV中,我们可以使用`cv2.VideoCapture()`函数来打开视频文件,并使用`read()`函数逐帧读取视频。 接下来,我会使用一个循环来遍历读取每一帧,并设置一个计数器来记录读取的帧数。在每次读取到的帧中,我会做以下处理: 1. 首先,我会检查当前帧是否为第一帧。如果是第一帧,我会直接将其保存为基准帧,并继续读取下一帧。 2. 如果当前帧是除第一帧外的30的倍数帧,我会比较当前帧与基准帧的差异。这可以通过使用`cv2.absdiff()`函数来计算两帧的差异图像。 3. 如果当前帧不符合要求,我会往前退四帧,然后再次比较差异。这可以通过使用`cv2.VideoCapture.set()`函数来设置视频的当前帧位置。 最后,我会根据差异图像是否超过某个阈值来决定是否保存当前帧。如果差异图像超过阈值,则可以使用`cv2.imwrite()`函数将当前帧保存为图像。 下面是实现代码的示例: ```python import cv2 # 打开视频文件 video = cv2.VideoCapture('path_to_video_file') # 读取基准帧 _, baseline_frame = video.read() frame_count = 0 # 记录帧数 while True: _, current_frame = video.read() frame_count += 1 if frame_count % 30 == 0: # 每隔30帧抽取一次 # 计算差异图像 diff = cv2.absdiff(baseline_frame, current_frame) # 如果差异图像超过阈值,保存当前帧 if cv2.mean(diff)[0] > threshold: cv2.imwrite(f'frame_{frame_count}.jpg', current_frame) if frame_count == total_frames: # 达到视频总帧数,退出循环 break if frame_count % 30 != 0: # 不是每隔30帧时,用当前帧更新基准帧 baseline_frame = current_frame ``` 请注意,在上述代码示例中,需要自行设置`threshold`变量的值来调整差异图像的阈值。另外,你需要替换代码中的`'path_to_video_file'`为你实际的视频文件路径。 ### 回答3: 在使用OpenCV对视频进行抽帧对比图像的过程中,可以按照以下步骤操作: 1. 导入所需的库文件和模块: ```python import cv2 import numpy as np ``` 2. 加载视频文件: ```python cap = cv2.VideoCapture('video.mp4') ``` 3. 定义要抽取的帧数间隔和回退的帧数: ```python frame_interval = 30 back_step = 4 ``` 4. 获取视频的总帧数: ```python total_frames = int(cap.get(cv2.CAP_PROP_FRAME_COUNT)) ``` 5. 逐帧对比图像: ```python prev_frame = None prev_diff = None for i in range(total_frames): ret, frame = cap.read() if not ret: break if i % frame_interval == 0: gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) if prev_frame is None: # 第一帧直接保存 prev_frame = gray else: prev_frame_diff = cv2.absdiff(prev_frame, gray) _, prev_frame_diff = cv2.threshold(prev_frame_diff, 30, 255, cv2.THRESH_BINARY) if prev_diff is not None: diff_with_last = cv2.absdiff(prev_diff, prev_frame_diff) _, diff_with_last = cv2.threshold(diff_with_last, 30, 255, cv2.THRESH_BINARY) if cv2.countNonZero(diff_with_last) > 0: # 不符合要求则回退 for _ in range(back_step): cap.set(cv2.CAP_PROP_POS_FRAMES, i - back_step) ret, frame = cap.read() if not ret: break gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) prev_frame_diff = cv2.absdiff(prev_frame, gray) _, prev_frame_diff = cv2.threshold(prev_frame_diff, 30, 255, cv2.THRESH_BINARY) diff_with_last = cv2.absdiff(prev_diff, prev_frame_diff) _, diff_with_last = cv2.threshold(diff_with_last, 30, 255, cv2.THRESH_BINARY) if cv2.countNonZero(diff_with_last) == 0: # 符合要求后退出循环 break # 显示结果 cv2.imshow('frame', frame) if cv2.waitKey(1) & 0xFF == ord('q'): break # 更新上一帧和上一帧的差异图 prev_frame = gray prev_diff = prev_frame_diff cap.release() cv2.destroyAllWindows() ``` 以上是一个简单的代码示例,用于视频抽帧对比图像并进行要求验证,每隔30帧抽取一次帧,并检查与前一帧的差异。如果不符合要求,则回退四帧再进行比较。希望对你有所帮助!

相关推荐

我现在有两个代码#!/usr/bin/env python2.7 -- coding: UTF-8 -- import time import cv2 from PIL import Image import numpy as np from PIL import Image if name == 'main': rtsp_url = "rtsp://127.0.0.1:8554/live" cap = cv2.VideoCapture(rtsp_url) #判断摄像头是否可用 #若可用,则获取视频返回值ref和每一帧返回值frame if cap.isOpened(): ref, frame = cap.read() else: ref = False #间隔帧数 imageNum = 0 sum=0 timeF = 24 while ref: ref,frame=cap.read() sum+=1 #每隔timeF获取一张图片并保存到指定目录 #"D:/photo/"根据自己的目录修改 if (sum % timeF == 0): # 格式转变,BGRtoRGB frame = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB) # 转变成Image frame = Image.fromarray(np.uint8(frame)) frame = np.array(frame) # RGBtoBGR满足opencv显示格式 frame = cv2.cvtColor(frame, cv2.COLOR_RGB2BGR) imageNum = imageNum + 1 cv2.imwrite("/root/Pictures/Pictures" + str(imageNum) + '.png', frame) print("success to get frame") #1毫秒刷新一次 k = cv2.waitKey(1) #按q退出 #if k==27:则为按ESC退出 if k == ord('q'): cap.release() break 和#!/usr/bin/env python2.7 coding=UTF-8 import os import sys import cv2 from pyzbar import pyzbar def main(image_folder_path, output_file_name): img_files = [f for f in os.listdir(image_folder_path) if f.endswith(('.png'))] qr_codes_found = [] print("Image files:") for img_file in img_files: print(img_file) for img_file in img_files: img_path = os.path.join(image_folder_path,img_file) img = cv2.imread(img_path) barcodes = pyzbar.decode(img) for barcode in barcodes: if barcode.type == 'QRCODE': qr_data = barcode.data.decode("utf-8") qr_codes_found.append((img_file, qr_data)) unique_qr_codes = [] for file_name, qr_content in qr_codes_found: if qr_content not in unique_qr_codes: unique_qr_codes.append(qr_content) with open(output_file_name,'w') as f: for qr_content in unique_qr_codes: f.write("{}\n".format(qr_content)) if name == "main": image_folder_path = '/root/Pictures' output_file_name = 'qr_codes_found.txt' main(image_folder_path,output_file_name)请使用ros创建节点将他们合在一个功能包中使得机器人在获得文本的同时又可以订阅拍的图片他用

以下代码是什么意思,请逐行解释:import tkinter as tk from tkinter import * import cv2 from PIL import Image, ImageTk import os import numpy as np global last_frame1 # creating global variable last_frame1 = np.zeros((480, 640, 3), dtype=np.uint8) global last_frame2 # creating global variable last_frame2 = np.zeros((480, 640, 3), dtype=np.uint8) global cap1 global cap2 cap1 = cv2.VideoCapture("./movie/video_1.mp4") cap2 = cv2.VideoCapture("./movie/video_1_sol.mp4") def show_vid(): if not cap1.isOpened(): print("cant open the camera1") flag1, frame1 = cap1.read() frame1 = cv2.resize(frame1, (600, 500)) if flag1 is None: print("Major error!") elif flag1: global last_frame1 last_frame1 = frame1.copy() pic = cv2.cvtColor(last_frame1, cv2.COLOR_BGR2RGB) img = Image.fromarray(pic) imgtk = ImageTk.PhotoImage(image=img) lmain.imgtk = imgtk lmain.configure(image=imgtk) lmain.after(10, show_vid) def show_vid2(): if not cap2.isOpened(): print("cant open the camera2") flag2, frame2 = cap2.read() frame2 = cv2.resize(frame2, (600, 500)) if flag2 is None: print("Major error2!") elif flag2: global last_frame2 last_frame2 = frame2.copy() pic2 = cv2.cvtColor(last_frame2, cv2.COLOR_BGR2RGB) img2 = Image.fromarray(pic2) img2tk = ImageTk.PhotoImage(image=img2) lmain2.img2tk = img2tk lmain2.configure(image=img2tk) lmain2.after(10, show_vid2) if __name__ == '__main__': root = tk.Tk() # img = ImageTk.PhotoImage(Image.open("logo.png")) heading = Label(root, text="Lane-Line Detection") # heading.configure(background='#CDCDCD',foreground='#364156') heading.pack() heading2 = Label(root, text="Lane-Line Detection", pady=20, font=('arial', 45, 'bold')) heading2.configure(foreground='#364156') heading2.pack() lmain = tk.Label(master=root) lmain2 = tk.Label(master=root) lmain.pack(side=LEFT) lmain2.pack(side=RIGHT) root.title("Lane-line detection") root.geometry("1250x900+100+10") exitbutton = Button(root, text='Quit', fg="red", command=root.destroy).pack(side=BOTTOM, ) show_vid() show_vid2() root.mainloop() cap.release()

最新推荐

recommend-type

javacv视频抽帧的实现过程详解(附代码)

主要介绍了javacv视频抽帧的实现过程详解(附代码),视频抽帧可以做一些处理,比如水印,去水印等操作,然后再合成视频,需要的朋友可以参考下
recommend-type

java使用OpenCV从视频文件中获取帧

主要为大家详细介绍了java使用OpenCV从视频文件中获取帧,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

python使用opencv按一定间隔截取视频帧

主要为大家详细介绍了python使用opencv按一定间隔截取视频帧,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

使用python-opencv读取视频,计算视频总帧数及FPS的实现

今天小编就为大家分享一篇使用python-opencv读取视频,计算视频总帧数及FPS的实现方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

opencv帧差法找出相差大的图像

主要为大家详细介绍了opencv帧差法找出相差大的图像,包含访问mat的像素值,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。