OpenCV获取视频的每一帧并保存为.jpg图片

本文实例为大家分享了OpenCV获取视频的每一帧并保存为图片的具体代码,供大家参考,具体内容如下

#include<opencv2\opencv.hpp>
#include <iostream>
#include <stdio.h>
#include<fstream> 

using namespace std;
using namespace cv;

//获取视频中的人脸

int main()
{
 //打开视频文件:其实就是建立一个VideoCapture结构
 VideoCapture capture("1.mp4");
 //检测是否正常打开:成功打开时,isOpened返回ture
 if (!capture.isOpened())
  cout << "fail toopen!" << endl;

 //获取整个帧数
 long totalFrameNumber = capture.get(CV_CAP_PROP_FRAME_COUNT);
 cout << "整个视频共" << totalFrameNumber << "帧" << endl;
 //设置开始帧()
 long frameToStart = 1;
 capture.set(CV_CAP_PROP_POS_FRAMES, frameToStart);
 cout << "从第" << frameToStart << "帧开始读" << endl;

 //设置结束帧
 int frameToStop = 30;

 if (frameToStop < frameToStart)
 {
  cout << "结束帧小于开始帧,程序错误,即将退出!" << endl;
  return -1;
 }
 else
 {
  cout << "结束帧为:第" << frameToStop << "帧" << endl;
 }

 //获取帧率
 double rate = capture.get(CV_CAP_PROP_FPS);
 cout << "帧率为:" << rate << endl;
 //定义一个用来控制读取视频循环结束的变量
 bool stop = false;

 //承载每一帧的图像
 Mat frame;

 //显示每一帧的窗口
 namedWindow("Extractedframe");

 //两帧间的间隔时间:
 //int delay = 1000/rate;
 double delay = 1000 / rate;

 //利用while循环读取帧
 //currentFrame是在循环体中控制读取到指定的帧后循环结束的变量
 long currentFrame = frameToStart;

 //滤波器的核
 int kernel_size = 3;
 Mat kernel = Mat::ones(kernel_size, kernel_size, CV_32F) / (float)(kernel_size*kernel_size);

 while (!stop)
 {
  //读取下一帧
  if (!capture.read(frame))
  {
   cout << "读取视频失败" << endl;
   return -1;
  }

  cout << "正在读取第" << currentFrame << "帧" << endl;
  imshow("Extractedframe", frame);

  cout << "正在写第" << currentFrame << "帧" << endl;
  stringstream str;
  str << currentFrame << ".jpg";
  cout << str.str() << endl;
  imwrite(str.str(), frame);

  //waitKey(intdelay=0)当delay≤ 0时会永远等待;当delay>0时会等待delay毫秒
  //当时间结束前没有按键按下时,返回值为-1;否则返回按键
  //int c = waitKey(delay);
  int c = waitKey(1000);
  //按下ESC或者到达指定的结束帧后退出读取视频
  if ((char)c == 27 || currentFrame > frameToStop)
  {
   stop = true;
  }
  //按下按键后会停留在当前帧,等待下一次按键
  if (c >= 0)
  {
   waitKey(0);
  }
  currentFrame++;

 }
 //关闭视频文件
 capture.release();
 waitKey(0);
 return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • opencv实现读取视频保存视频

    不得不说opencv是个强大的东东,以前做一个项目的一个模块时使用到进行图形处理,这次是想将一个视频的播放放慢,以前在网上看到opencv有这个功能,今天就不小心尝试了下,东西不多,主要是做个小记录还有一点要注意的小问题说一下,代码不多,基本上也都是copy的网上的 #include <iostream> #include <assert.h> #include <opencv/cv.h> #include <opencv/highgui.h> #inclu

  • Opencv3.4.0实现视频中的帧保存为图片功能

    现在有一个收集人脸的需求,每一张照片只有一个人.我的解决办法是用收集录制一段视频,然后上传到PC上.在PC上使用OpenCV将图片中的每一帧保存为JPG图片. 以下是代码: import time import cv2 if __name__ == '__main__': # 填写视频的绝对路径 vidcap = cv2.VideoCapture('/home/shushi/video/猎场.mp4') success, image = vidcap.read() start_time = ti

  • OpenCV获取视频的每一帧并保存为.jpg图片

    本文实例为大家分享了OpenCV获取视频的每一帧并保存为图片的具体代码,供大家参考,具体内容如下 #include<opencv2\opencv.hpp> #include <iostream> #include <stdio.h> #include<fstream> using namespace std; using namespace cv; //获取视频中的人脸 int main() { //打开视频文件:其实就是建立一个VideoCapture结构

  • 用OpenCV将视频分解成单帧图片,图片合成视频示例

    本文做的是基于opencv将视频帧转成图片输出,由于一个视频包含的帧数过多,经常我们并不是需要它的全部帧转成图片,因此我们希望可以设置每隔多少帧再转一次图片(本文设置为30帧),若有人需求是只需要前多少帧,也可以类似的改写下代码即可. 程序一: #include <iostream> #include "cv.h" #include "opencv2/opencv.hpp" using namespace std; using namespace cv;

  • opencv利用视频的前n帧求平均图像

    本文实例为大家分享了opencv利用视频的前n帧求平均图像的具体代码,供大家参考,具体内容如下 自己写的哈,可以用该小程序对视频求解平均模型. //OpenCV中如何累加多幅图像并取平均值 #include "cv.h" #include "highgui.h" int main(int argc,char *argv[]) { int nframe = 50;//利用前nfram帧求解平均图 CvCapture *capture = cvCreateFileCap

  • Python OpenCV获取视频的方法

    之前有文章,使用Android平台的OpenCV接入了视频,控制的目标是手机的摄像头,这是OpenCV的好处,使用OpenCV可以使用跨平台的接口实现相同的功能,减少了平台间移植的困难.正如本文后面,将使用类似的接口,从笔记本的摄像头获取视频,所以,尝试本文代码需要有一台有摄像头的电脑. 不过,需要说明的的是,OpenCV的强项在于图像相关的处理,而不是视频的编解码,所以,不要使用OpenCV做多余的事情,我们使用OpenCV接入视频或者图片的目的,是为了对视频或图片进行处理. 关于Python

  • JavaCV实现获取视频每帧并保存

    兴趣使然写的代码,因为没有接触过JavaCV,所以查了很久的API还有依赖包,也使用了openCV来写过,但是还是遇到很多问题.希望小伙伴指出不足,互相学习. 环境配置: JavaCV1.4.1(下载Jar包,解压并提取所需要的Jar.这点耗时比较长,萌新完全不知道需要用什么,看源码及例子推出) Java版本:Java10 具体代码: package VideoProcessing; import org.bytedeco.javacv.FFmpegFrameGrabber; import or

  • java使用OpenCV从视频文件中获取帧

    本文实例为大家分享了java使用OpenCV从视频文件中获取帧的具体代码,供大家参考,具体内容如下 实现功能:使用Java获取mp4.mov.avi等视频文件中的图像帧,每秒获取一帧图像,并保存 环境要求:需要安装Opencv,安装FFmpeg,下载javacv包 操作系统:本次实验使用的Ubuntu系统 实验代码 import com.googlecode.javacv.cpp.opencv_highgui; import org.opencv.core.Core; import org.op

  • Java获取视频时长及截取帧截图详解

    前言 只是最近碰到有这方面的项目需求,所以简单 Mark 下本文.下面的示例是参考过他人分享的文章,之后本人再自行实践.调整和测试过的,希望对有这方面需求的人有所帮助. 示例 添加依赖 <dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv-platform</artifactId> <version>1.4.4</version> </depe

  • 使用opencv将视频帧转成图片输出

    本文做的是基于opencv将视频帧转成图片输出,由于一个视频包含的帧数过多,经常我们并不是需要它的全部帧转成图片,因此我们希望可以设置每隔多少帧再转一次图片(本文设置为30帧),若有人需求是只需要前多少帧,也可以类似的改写下代码即可. 本文代码如下: #include <iostream> #include "cv.h" #include "opencv2/opencv.hpp" using namespace std; using namespace

  • python+opencv实现视频抽帧示例代码

    1.数据集简述: 虽然有主流庞大的COCO.VOC数据集,但是科研人员仍需要特殊领域要求的数据集,所以采用人工实地采集的方式进行收集数据集图像:通过拍照收集图像过于繁琐,所以通常是将摄像头无规则的移动旋转以及远近拉缩,进而录制视频:再通过视频抽帧的方式得到大量的图像,再将这些图像进行人工标注处理. 博主通过一个水下录制视频为例子,当这类图像在网上鲜有存在时,要求有关技术人员进行实拍采集,下图即为采集得到的视频. 为了避免不符合项目要求的数据增强,博主要求技术人员在录制视频时最大程度地让摄像头进行

  • C#获取视频某一帧的缩略图的方法

    本文实例讲述了C#获取视频某一帧的缩略图的方法.分享给大家供大家参考.具体实现方法如下: 读取方式:使用ffmpeg读取,所以需要先下载ffmpeg.网上资源有很多. 原理是通过ffmpeg执行一条命令获取视频某一帧的缩略图. 首先,需要获取视频的帧高度和帧宽度,这样获取的缩略图才不会变形. 获取视频的帧高度和帧宽度可以参考:http://www.jb51.net/article/57475.htm. 获取到视频的帧高度和帧宽度后,还需要获取缩略图的高度和宽度,这是按比例缩放的. 比如你存放缩略

随机推荐