花屏检测。

import cv2
import numpy as np

def is_frames_corrupted(frame1, frame2, threshold=0.99):
    difference = cv2.absdiff(frame1, frame2)
    mean_difference = np.mean(difference)
    similarity = 1 - (mean_difference / 255.0)
    return similarity >= threshold

def find_glitch_in_video(video_path, threshold=0.99):
    cap = cv2.VideoCapture(video_path)

    if not cap.isOpened():
        print("Error opening video file")
        return

    ret, prev_frame = cap.read()
    prev_frame = cv2.cvtColor(prev_frame, cv2.COLOR_BGR2GRAY)

    while cap.isOpened():
        ret, curr_frame = cap.read()

        if not ret:
            break

        curr_frame_gray = cv2.cvtColor(curr_frame, cv2.COLOR_BGR2GRAY)
        if is_frames_corrupted(prev_frame, curr_frame_gray, threshold):
            print("Glitch found in the video")
            cap.release()
            return True

        prev_frame = curr_frame_gray

    print("No glitch found in the video")
    cap.release()
    return False

if __name__ == "__main__":
    video_path = "path/to/your/video.mp4"
    find_glitch_in_video(video_path)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值