首页 > 编程语言 > 详细

C++视频读取与视频保存

时间:2019-12-02 10:28:21      阅读:592      评论:0      收藏:0      [点我收藏+]
    VideoCapture cap("E:\\122.avi");    
    //计算视频帧数
    int VedioFPS = cap.get(CV_CAP_PROP_FPS);
    //cout << "视频帧率" << VedioFPS << endl;
    // 保存视频
    VideoWriter writer("LoadBeltTear.mp4", CV_FOURCC(M, J, P, G), VedioFPS, Size(ROI_Weidth, ROI_Height * 2));
    if (!cap.isOpened())
    {
        cout << "Error opening video stream or file" << endl;
        return -1;
    }
    Mat frame;
    while (1) {
        // Capture frame-by-frame
        cap >> frame;
        // If the frame is empty, break immediately
        if (frame.empty()) break;
        if (frame.channels() == 3) cvtColor(frame, frame, CV_RGB2GRAY);
                //******************
                // 处理图像
        //******************
        //在图像上打上标记
        cvtColor(frame(roi_rect), ROIimg, CV_GRAY2RGB);
        std::string str2 = "OriginalImage";
        cv::putText(ROIimg, str2, Point(roi_rect.width *0.5 - 20, 20), cv::FONT_HERSHEY_SIMPLEX, 0.3, cv::Scalar(0, 255, 255), 1);
        cv::putText(ROIimg, "LoadBelt", Point(0, 20), cv::FONT_HERSHEY_SIMPLEX, 0.5, cv::Scalar(0, 255, 255), 1);
        std::string str1 = "ImageProcessing";
        cv::putText(tempImg, str1, Point(roi_rect.width *0.5 - 30, 20), cv::FONT_HERSHEY_SIMPLEX, 0.3, cv::Scalar(0, 255, 255), 1);
        vconcat(ROIimg, tempImg, conbine);
        imshow("拼接", conbine);
        writer << conbine;
        char c = (char)waitKey(1);
        if (c == 27)
            break;
    }
    cap.release();
    destroyAllWindows();            

从视频文件中读取视频,对单帧图像进行相关处理,将处理后的图像整理成视频

C++视频读取与视频保存

原文:https://www.cnblogs.com/wangxiaobei2019/p/11968789.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!