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()
相关推荐
user29876982706543 分钟前
七、深入 Claude Code CLI 源码:斜杠命令系统详解
人工智能
念恒123067 分钟前
Python(复杂判断)
python·学习
无敌的黑星星17 分钟前
Java8 CompletableFuture 实战指南
linux·前端·python
KG_LLM图谱增强大模型24 分钟前
Palantir 本体论与知识图谱深度分析及实现路径
人工智能·知识图谱
yzx99101325 分钟前
项目名称:灵犀——基于大模型与知识图谱的全栈智慧创作与协同平台
人工智能·知识图谱
RAG专家26 分钟前
【KG²RAG】结合知识图谱解决RAG 文本块孤立问题
人工智能·知识图谱·rag·检索增强生成
小袁进化之路27 分钟前
黎跃春讲AI智能体运营工程师核心知识图谱(2026完整版)
人工智能·知识图谱
CyberwayTech28 分钟前
赛博威线上营销费用管理:咨询+系统,双轮驱动ROI增长
大数据·人工智能
StockTV28 分钟前
印度股票实时数据 NSE和BSE的实时行情、K 线及指数数据
java·开发语言·spring boot·python
一粒黑子28 分钟前
【实测】GitNexus实测:拖入GitHub链接秒出代码知识图谱,今天涨了857星
人工智能·gpt·安全·ai·大模型·ai编程