Opencv3.4.0實現(xiàn)視頻中的幀保存為圖片功能
現(xiàn)在有一個收集人臉的需求,每一張照片只有一個人。我的解決辦法是用收集錄制一段視頻,然后上傳到PC上。在PC上使用OpenCV將圖片中的每一幀保存為JPG圖片。
以下是代碼:
import time
import cv2
if __name__ == '__main__':
# 填寫視頻的絕對路徑
vidcap = cv2.VideoCapture('/home/shushi/video/獵場.mp4')
success, image = vidcap.read()
start_time = time.time()
print(start_time)
while success:
end_time = time.time()
file_name = str(end_time).replace('.', '')
# 每隔三秒截屏
if 3 == int(end_time - start_time):
start_time = end_time
# 保存JGP 的絕對路徑
cv2.imwrite('/home/shushi/video/' + file_name + ".jpg", image) # save frame as JPEG file
success, image = vidcap.read()
if cv2.waitKey(10) == 27: # exit if Escape is hit
break
將視頻放到與Python文件同級目錄下,然后運行程序,你就會得到視頻幀對應(yīng)的JPG圖片了:

小編再為大家分享一段代碼:OpenCV按視頻幀進行截取,作者是Haku_yyf
#include <opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
#include <iostream>
int main(int argc, char **argv)
{
//打開視頻文件
cv::VideoCapture cap("E:\\New folder\\DSC_3543.MOV");
if (!cap.isOpened())
{
std::cout << "不能打開視頻文件" << std::endl;
return -1;
}
//從3000ms開始播放視頻
//cap.set(CV_CAP_PROP_POS_MSEC, 3000);
//獲取視頻的幀速率
double fps = cap.get(cv::CAP_PROP_FPS);
double width = cap.get(cv::CAP_PROP_FRAME_WIDTH);
double height = cap.get(cv::CAP_PROP_FRAME_HEIGHT);
//std::cout << fps << std::endl;
//std::cout << width << std::endl;
//std::cout << height << std::endl;
cv::VideoWriter wrt("C:\\Users\\Administrator\\Desktop\\1.avi", CV_FOURCC('M', 'J', 'P', 'G'), fps, cv::Size(width, height));
int cout = 0;
while (true)
{
cv::Mat frame;
//從視頻中讀取一個幀
bool bSuccess = cap.read(frame);
++cout;
if (!bSuccess)
{
std::cout << "不能從視頻文件讀取幀" << std::endl;
break;
}
//在MyVideo窗口上顯示當前幀
if (cout>=fps*1 && cout<=fps*56)//取視頻1-56秒內(nèi)容
{
std::cout << "正在截取..."<<(int)(((cout-fps)/(fps*(56-1)))*100)<<"%" << std::endl;
wrt << frame;
}
if (cout>fps*57)
{
std::cout << "ENd!!!" << std::endl;
break;
}
}
system("pause");
return 0;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Qt采用線程以隊列方式實現(xiàn)下發(fā)數(shù)據(jù)
在C++中隊列是一種常用的數(shù)據(jù)結(jié)構(gòu)之一,一種特殊的線性表,一般采用先進先出的方式。本文主要為大家介紹了Qt如何以隊列方式實現(xiàn)下發(fā)數(shù)據(jù),感興趣的可以了解一下2022-10-10
C++實現(xiàn)LeetCode(56.合并區(qū)間)
這篇文章主要介紹了C++實現(xiàn)LeetCode(56.合并區(qū)間),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07
基于Protobuf C++ serialize到char*的實現(xiàn)方法分析
本篇文章是對Protobuf C++ serialize到char*的實現(xiàn)方法進行了詳細的分析介紹。需要的朋友參考下2013-05-05
c++靜態(tài)局部變量和靜態(tài)函數(shù)示例

