当前位置: 首页 > article >正文

OpenCV识别视频中物体运动并截取保存

功能很简单:输入原始视频,输出视频中有画面变化的部分

适合理解基本框架,可以在这个基础上增加各种酷炫时髦的功能 [doge]

※注释非常保姆级※

import cv2
import numpy as np
import os
from datetime import datetime

# 检测两帧之间变化
def detect_motion(frame1,frame2,threshold):
    # 计算两帧之间的绝对差异  
    diff=cv2.absdiff(frame1,frame2)
    # 将差异图像转换为灰度图
    gray = cv2.cvtColor(diff, cv2.COLOR_BGR2GRAY)  
    # 对灰度图进行高斯模糊,减少噪声  
    blur=cv2.GaussianBlur(gray,(5,5),0)
    # 对模糊后的图像进行二值化处理,设置阈值  
    # thresh为二值化后的差异图像,其中运动物体为白色(255),背景为黑色(0)
    _,thresh=cv2.threshold(blur,threshold,255,cv2.THRESH_BINARY)
    return thresh

# 保存运动帧
# 参数threshold为差异阈值,当像素差异大于此值时,认为是运动,可自行调整
def save_motion_frames(video_path,output_folder,threshold=25):
    # 打开视频文件  
    cap=cv2.VideoCapture(video_path)
    # 截取视频文件名,去掉扩展名如.mp4等,命名输出文件时用
    video_name=video_path[-14:-4]
    # 时-分-秒,命名输出文件时用
    edit_time=datetime.now().strftime("%H-%M-%S")

	# 获取视频的帧率和分辨率  
    # PS:这个参数是每秒有多少帧,可以自己设定,数值增大相当于视频加速
    fps = cap.get(cv2.CAP_PROP_FPS)  
    width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))  
    height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))  

    # 使用XVID编解码器  
    fourcc = cv2.VideoWriter_fourcc(*'XVID')  
    # 创建VideoWriter对象
    out = cv2.VideoWriter(os.path.join(output_folder, f'{video_name}-{edit_time}.avi'), fourcc,fps, (width, height)) 

    # 读取第一帧
    # cap.read()可以类比吃豆人,吃掉就向前进,下一口是新的帧
    ret,prev_frame=cap.read()
    # 循环读取视频的每一帧  
    while ret:
        # 读取下一帧
        ret,curr_frame=cap.read()
        # 如果读完则跳出循环
        if not ret:
            break
        # 检测两帧之间有没有变化(即motion中有非零像素)  
        motion=detect_motion(prev_frame,curr_frame,threshold)
        # 如果有变化,则把后一帧写入VideoWriter对象
        if np.any(motion):
            out.write(curr_frame)
        # 读取框往后移动一帧,继续循环
        prev_frame=curr_frame
    # 释放视频文件
    out.release()
    cap.release

output_folder = r"C:\Users\86171\Documents\Temp"  # 输出文件夹路径  
source=input('source file: ') #需要处理的视频文件夹路径
#遍历获取需要处理的视频
videos=[]
for root,dirs,files in os.walk(source):
    for file in files:
        file_path = os.path.join(root,file)  
        videos.append(file_path)
for video_path in videos: 
# 调用函数,保存包含运动的视频片段  
    save_motion_frames(video_path, output_folder)


http://www.kler.cn/a/231845.html

相关文章:

  • 【ARTS】【LeetCode-704】二分查找算法
  • 【k8s】k8s部署Argo CD
  • MyBatis Plus 的 InnerInterceptor:更轻量级的 SQL 拦截器
  • HOW - 查看分支创建时间(含 git reflog 和 git log 区别)
  • 数据结构——算法基础
  • Java实现微店商品详情接口调用的完整指南
  • netstat: 未找到命令
  • C++面试宝典第27题:完全平方数之和
  • 常用排序算法(Java版本)
  • 【数据结构】堆(创建,调整,插入,删除,运用)
  • 巴尔加瓦算法图解:算法运用。
  • css1字体属性
  • 【数据结构】二叉树的顺序结构及链式结构
  • [VulnHub靶机渗透] dpwwn: 1
  • 解析spritf和sscanf与模拟常用字符串函数strchr,strtok(二)
  • mysql的慢sql优化
  • (41)速算机器人
  • 工作与生活平衡:在生活中寻找和谐
  • Python 潮流周刊#38:Django + Next.js 构建全栈项目
  • uniapp小程序端使用计算属性动态绑定style样式踩坑
  • Docker安装ElasticSearch8.9.0
  • 【buuctf--被偷走的文件】
  • 美赛结束后,还可以转学术论文发表!
  • 编码技巧——在项目中使用Alibaba Cloud Toolkit远程部署
  • Wireshark不显示Thrift协议
  • 开源活动汇集网站