OpenCV: 光流法python代码

https://blog.csdn.net/weixin_42284380/article/details/151273480

可以直接跑:

复制代码
import cv2
import numpy as np
 
cap = cv2.VideoCapture('../test-1920X1080.mp4')
 
# 获取第一帧并检测特征点
ret, old_frame = cap.read()
old_gray = cv2.cvtColor(old_frame, cv2.COLOR_BGR2GRAY)
p0 = cv2.goodFeaturesToTrack(old_gray, maxCorners=100, qualityLevel=0.3, minDistance=7)
 
# 创建随机颜色用于轨迹绘制
color = np.random.randint(0, 255, (100, 3))
 
# 用于保存特征点轨迹
trajectory = [[] for _ in range(len(p0))]
 
while True:
    ret, frame = cap.read()
    if not ret:
        break
    frame_gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
 
    # 计算光流
    p1, st, err = cv2.calcOpticalFlowPyrLK(old_gray, frame_gray, p0, None)
 
    # 选择良好匹配点
    good_new = p1[st == 1]
    good_old = p0[st == 1]
 
    # 更新轨迹
    for i, (new, old) in enumerate(zip(good_new, good_old)):
        a, b = new.ravel()
        trajectory[i].append((int(a), int(b)))
 
        # 绘制轨迹
        for j in range(1, len(trajectory[i])):
            cv2.line(frame, trajectory[i][j-1], trajectory[i][j], color[i].tolist(), 2)
 
    # 显示结果
    cv2.imshow('Frame', frame)
 
    # 更新前一帧和特征点
    old_gray = frame_gray.copy()
    p0 = good_new.reshape(-1, 1, 2)
 
    if cv2.waitKey(30) & 0xff == 27:
        break
 
cap.release()
cv2.destroyAllWindows()
相关推荐
洵有兮6 分钟前
python第四次作业
开发语言·python
kkoral7 分钟前
单机docker部署的redis sentinel,使用python调用redis,报错
redis·python·docker·sentinel
许泽宇的技术分享19 分钟前
解密Anthropic的MCP Inspector:从协议调试到AI应用开发的全栈架构之旅
人工智能·架构·typescript·mcp·ai开发工具
BoBoZz1921 分钟前
IterativeClosestPoints icp配准矩阵
python·vtk·图形渲染·图形处理
nopSled22 分钟前
AlphaAvatar:一个基于 LiveKit 的插件化实时 Omni-Avatar 架构
人工智能·语言模型
lovingsoft23 分钟前
如何看自己笔记本是不是ARM64
人工智能·测试管理
美狐美颜sdk42 分钟前
AI加持下的直播美颜sdk:动态贴纸功能的未来形态前瞻
人工智能·美颜sdk·直播美颜sdk·第三方美颜sdk·人脸美型sdk
test管家43 分钟前
PyTorch动态图编程与自定义网络层实战教程
python
火山引擎开发者社区1 小时前
Force 开发者日:火山引擎 Agent 开发者生态全面升级
人工智能·火山引擎
智算菩萨1 小时前
从对话系统到对话式智能体:对话式AI发展综述与2025年前沿整合
人工智能