opencv3读取视频并保存为图片

#include <iostream>
#include <vector>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

void readvideoandsaveimage(string video, string path)
{
  VideoCapture capture(video);
  long totalFrameNumber = capture.get(CV_CAP_PROP_FRAME_COUNT);
  cout << "total frames is:" << totalFrameNumber << "." << endl;
  //设置开始帧
  long frameToStart = 1;
  capture.set(CV_CAP_PROP_POS_FRAMES, frameToStart);
  //设置结束帧
  int frameToStop = 1000;

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

  if (!capture.isOpened())
  {
    cerr << "Failed to open a video" << endl;
    return;
  }

  Mat frame;
  int num = 1;
  string filename;
  char temp_file[15];

  while (!stop)
  {
    capture >> frame;
    if (frame.empty())
    {
      //break;
      continue;
    }
    _itoa_s(num, temp_file, 4, 10); //4表示字符长度,10表示十进制,_itoa_s实现整型转字符串
    filename = temp_file;
    filename = path + filename + ".jpg";

    imshow("Extractedframe", frame);

    imwrite(filename, frame);

    int c = waitKey(delay);
    if ((char)c == 27 || currentFrame > frameToStop)
    {
      stop = true;
    }
    //按下按键后会停留在当前帧,等待下一次按键
    if (c >= 0)
    {
      waitKey(0);
    }

    num++;
    currentFrame++;
  }
  capture.release();
  waitKey(0);
}

int main(int argc, char** argv)
{
  string videoFromfile = "D:\\images\\1.mp4"; //读取视频
  string Imagespath = "D:\\images\\2018-09-22\\"; // 保存图片的文件夹路径一定要有,因为OpenCV不会自动创建文件夹
  readvideoandsaveimage(videoFromfile, Imagespath);
  return 0;
}

------------------------------------------------------------------运行效果:

原文地址:https://www.cnblogs.com/herd/p/9691034.html

时间: 2024-10-13 00:37:50

opencv3读取视频并保存为图片的相关文章

OpenCV3读取视频或摄像头

我们可以利用OpenCV读取视频文件或者摄像头的数据,将其保存为图像,以用于后期处理.下面的实例代码展示了简单的读取和显示操作: 1 // This is a demo introduces you to reading a video and camera 2 #include <iostream> 3 #include <string> 4 #include <sstream> 5 using namespace std; 6 7 // OpenCV include

【EMGU】读取视频AVI文件+保存任意帧为图片

文章简介:对拍取的视频需要手动截取或者分帧截取图片,本文拟实现此功能.可多次.任意帧截取. 操作说明:空格键开始截取,回车键退出视频. 开发环境:EMGU2.4.9 + VS2010 +Win7(64). public void VideoCatch(string filepath) { try { IntPtr CatchFrame =CvInvoke.cvCreateFileCapture(filepath); CvInvoke.cvNamedWindow("打开视频"); //

在opencv下读取视频保存为图片

VideoCapture capture; capture.open("D:\\car.avi");//读取视频 对于视频下一帧的读取: capture>>frameImg;//读取视频流下一帧控制,字符重载 对于视频的图片保存 std::stringstream ss;//存储图片路径保存信息 ss<<"D:/output/image_"<<setfill('0')<<setw(3)<<(nCount-1

读取视屏文件,保存帧图片为ppm文件

ffmpeg跟sdl的学习过程:一.版本信息:ffmpeg-3.0.2.tar.bz2SDL2-2.0.4.tar.gz二.编译过程:1.ffmgeg的编译:./configure --enable-shared --disable-yasm --prefix=/usr/local/ffmpegmakemake install 2.sdl的编译:./configure --prefix=/usr/local/sdlmakemake install 3.系统环境配置:查看/etc/ld.so.co

Silverlight读取Zip文件中的图片与视频

首先看看Demo的截图: 下面我将一步步展示实现这个Demo的过程,这个需求就是读出Zip文件中的图片与视频. Demo整体架构: 首先我们准备几张图片和视频,然后将其压缩至resource.zip文件中,做完之后,我们建立一个resource.xml文件记录压缩包内的资源 <?xml version="1.0" encoding="utf-8" ?> <files> <file type="video" name=

python 视频逐帧保存为图片

import cv2 import os def save_img(): video_path = r'F:\test\video1/' videos = os.listdir(video_path) for video_name in videos: file_name = video_name.split('.')[0] folder_name = video_path + file_name os.makedirs(folder_name,exist_ok=True) vc = cv2.V

快速把微信里想保存的图片视频转存到电脑

微信聊天经常看到喜欢的图片和视频,保存在手机里又占有太多空间,删掉又舍不得,怎么办?给你一个手机后台自动把微信保存的图片视频转存到电脑办法 1.电脑安装个FTP服务,点此下载 http://kaiji.org/soft/serv-u.rar2.手机安装个手机瘦身大师,点此下载 http://www.meibu.com/soft/ftp_c.apk 下载需要用浏览器打开下载,在微信中无法下载的. 手机瘦身大师是自动在手机后台工作的,你一保存微信里的视频,就会每天自动转存一次,你要立刻转的话,进入手

机器学习进阶-图像基本处理-视频的读取与处理 1.cv2.VideoCapture(视频的载入) 2.vc.isOpened(载入的视频是否可以打开) 3.vc.read(视频中一张图片的读取) 4.cv2.cvtColor(将图片转换为灰度图)

1.vc = cv2.VideoCapture('test.mp4') #进行视频的载入 2.vc.isOpened() # 判断载入的视频是否可以打开 3.ret, frame = vc.read()  #进行单张图片的读取,ret的值为True或者Flase, frame表示读入的图片 4.cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)  #表示将图片转换为灰度图 代码: import cv2 vc = cv2.VideoCapture('test.mp4')

Opencv:视频中人脸检测并保存人脸图片

# OpenCV版本的视频检测 import cv2 # 图片识别方法封装 def discern(img): gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) cap = cv2.CascadeClassifier( "C:\Python36\Lib\site-packages\opencv-master\data\haarcascades\haarcascade_frontalface_default.xml" ) faceRects = c