光流法-opencv python
2024-08-27 01:47:38
import cv2
import numpy as np
cap = cv2.VideoCapture("D:/Workspace/week2/test/test_256_12.mp4") ret, frame1 = cap.read()
prvs = cv2.cvtColor(frame1,cv2.COLOR_BGR2GRAY)
hsv = np.zeros_like(frame1)
hsv[...,1] = 255
num = 1
while(1):
ret, frame2 = cap.read()
next = cv2.cvtColor(frame2,cv2.COLOR_BGR2GRAY)
flow = cv2.calcOpticalFlowFarneback(prvs,next, None, 0.5, 3, 6, 3, 5, 1.25, 0)
mag, ang = cv2.cartToPolar(flow[...,0], flow[...,1])
hsv[...,0] = ang*180/np.pi/2
hsv[...,2] = cv2.normalize(mag,None,0,255,cv2.NORM_MINMAX)
rgb = cv2.cvtColor(hsv,cv2.COLOR_HSV2BGR)
cv2.imshow("frame",frame2)
cv2.imshow("flow",rgb)
k = cv2.waitKey(30) & 0xff
if k == 27:
break
elif k == ord('s'):
cv2.imwrite('opticalfb.png',frame2)
cv2.imwrite('opticalhsv.png',rgb)
prvs = next cap.release()
cv2.destroyAllWindows()
最新文章
- No.009:Palindrome Number
- cocos2d-js去掉左下角的三行数字(帧数)
- Last non-zero Digit in N!(阶乘最后非0位)
- [UE4]AnimDynamics简介
- Linux IPC POSIX 信号量
- linux包之findutils之find和xargs命令
- hdu 1847 Good Luck in CET-4 Everybody!(简单博弈SG)
- TImage 的一些操作
- Hibernate - SQLQuery
- mac 布置 git仓库服务器
- 算法题C#
- Angular.js之指令学习笔记
- 【转】44款Java 网络爬虫开源软件
- 如何部署 Calico 网络?- 每天5分钟玩转 Docker 容器技术(67)
- Java-Properties用法-入门
- Protocol Buffers(3):阅读一个二进制文件
- 【转载】【吵架】能力 说清自己的能力。表达清楚 ;别人发飙你也要撕b;换位思考,把自己当领导层
- NandFlash和iNand【转】
- mysql 8.0 错误The server requested authentication method unknown to the client
- [Java]类的生命周期(上)类的加载和连接[转]