cv::Mat图像操作

图像读写

复制代码
//include  header
#include <opencv2/imgcodecs.hpp>

/**
Currently, the following file formats are supported:
Windows bitmaps - *.bmp, *.dib (always supported)
JPEG files - *.jpeg, *.jpg, *.jpe (see the Note section)
JPEG 2000 files - *.jp2 (see the Note section)
Portable Network Graphics - *.png (see the Note section)
WebP - *.webp (see the Note section)
Portable image format - *.pbm, *.pgm, *.ppm *.pxm, *.pnm (always supported)
Sun rasters - *.sr, *.ras (always supported)
TIFF files - *.tiff, *.tif (see the Note section)
OpenEXR Image files - *.exr (see the Note section)
Radiance HDR - *.hdr, *.pic (always supported)
Raster and Vector geospatial data supported by GDAL (see the Note section)
*/
Mat cv::imread	(	const String & 	filename,
int 	flags = IMREAD_COLOR 
);
bool cv::imwrite	(	const String & 	filename,
InputArray 	img,
const std::vector< int > & 	params = std::vector< int >() 
);

图像ROI选取

复制代码
cv::Mat roi=frame(cv::Rect(x, y, roi_WIDTH, roi_HEIGHT));

图像多通道分离合并

复制代码
//include header
#include <opencv2/core.hpp>
/**
void cv::split	(	const Mat & 	src,
Mat * 	mvbegin 
);
void cv::merge	(	const Mat * 	mv,
size_t 	count,
OutputArray 	dst 
);
*/
cv::Mat  src,dst;
std::vector<cv::Mat> imgplanes;
cv::split(src,imgplanes);
cv::merge(imgplanes,imgplanes.size(),dst);

图像串联组合

复制代码
cv::Mat img_encode, img_encode1, img_encode2;
//水平串联
cv::hconcat(img_camera[0], img_camera[1], img_encode1);
cv::hconcat(img_camera[2], img_camera[3], img_encode2);
//垂直串联
cv::vconcat(img_encode1, img_encode2, img_encode);

Camera实时数据/视频回放

Camera实时数据

复制代码
#include <opencv2/core.hpp>
#include <opencv2/videoio.hpp>
#include <opencv2/highgui.hpp>
#include <iostream>
#include <stdio.h>
using namespace cv;
using namespace std;
int main(int, char**)
{
    Mat frame;
    //--- INITIALIZE VIDEOCAPTURE
    VideoCapture cap;
    // open the default camera using default API
    // cap.open(0);
    // OR advance usage: select any API backend
    int deviceID = 0;             // 0 = open default camera
    int apiID = cv::CAP_ANY;      // 0 = autodetect default API
    // open selected camera using selected API
    cap.open(deviceID, apiID);
    // check if we succeeded
    if (!cap.isOpened()) {
        cerr << "ERROR! Unable to open camera\n";
        return -1;
    }
    //--- GRAB AND WRITE LOOP
    cout << "Start grabbing" << endl
        << "Press any key to terminate" << endl;
    for (;;)
    {
        // wait for a new frame from camera and store it into 'frame'
        cap.read(frame);
        // check if we succeeded
        if (frame.empty()) {
            cerr << "ERROR! blank frame grabbed\n";
            break;
        }
        // show live and wait for a key with timeout long enough to show images
        imshow("Live", frame);
        if (waitKey(5) >= 0)
            break;
    }
    // the camera will be deinitialized automatically in VideoCapture destructor
    return 0;
}

视频回放

复制代码
cv::VideoCapture capture(videoPath);
for (;;)
{
   capture >> frame;
}
相关推荐
麦麦麦造2 分钟前
国外网友的3个步骤,实现用Prompt来写Prompt!超简单!
人工智能
闲看云起15 分钟前
从BERT到T5:为什么说T5是NLP的“大一统者”?
人工智能·语言模型·transformer
小麦矩阵系统永久免费31 分钟前
小麦矩阵系统:让短视频分发实现抖音快手小红书全覆盖
大数据·人工智能·矩阵
新加坡内哥谈技术31 分钟前
Chrome的“无处不在”与推动Web平台演进的使命
人工智能
kailp42 分钟前
突破效率与质量边界:深入解析MiniMax-Remover视频物体移除方案
人工智能·ai·大模型·gpu算力·图片渲染
超人不会飛1 小时前
vue3 markdown组件|大模型应用专用
前端·vue.js·人工智能
虫无涯1 小时前
Doc2X为一切AI文档服务的基础设施,将PDF转换为Word、HTML、LaTeX、Markdown等
人工智能
倔强的石头1061 小时前
卷积神经网络(CNN):从图像识别原理到实战应用的深度解析
人工智能·神经网络·cnn
爆改模型1 小时前
【ICCV2025】计算机视觉|即插即用|ESC:颠覆Transformer!超强平替,ESC模块性能炸裂!
人工智能·计算机视觉·transformer
虫无涯1 小时前
一种专为AI代理设计的内存层,能够在交互过程中记忆、学习和进化
人工智能