初入OpenCV

OpenCV简介

OpenCV是一个开源的跨平台计算机视觉库,它实现了图像处理和计算机视觉方面的很多通用算法。

应用场景:

目标识别:人脸、车辆、车牌、动物;

自动驾驶;医学影像分析;

视频内容理解分析:文字识别、公众人物识别、识别各类物品

OpenCV图像模式

位图模式

位图模式就是1位二进制深度的图像模式,只有黑白两种颜色。它可以由扫描或置入黑色的矢量线条图像生成,也只能由灰度模式转换而来。

灰度模式

灰度模式是8位二进制深度的图像模式,在全黑和全白间插有254个灰度等级的颜色来描绘灰度模式的图像,所有模式的图像都能转换成灰度模式。

RGB模式

简而言之就是彩色。

新建项目

进入Qt新建一个项目,打开.pro文件,添加以下代码

cpp 复制代码
INCLUDEPATH +=/usr/local/include/
LIBS+=/usr/local/lib/libopencv_world.so

引入头文件和域

cpp 复制代码
#include <opencv2/opencv.hpp>
using namespace cv;

加载图像

示例

我们来使用OpenCV来实现加载一张图片

cpp 复制代码
    Mat img=imread("image/dog.jpg");
    imshow("img",img); // 显示图片
    waitKey(0); // 等待用户操作

Mat类似于一个图片信息的类。

imread("path")读取图片信息,path为路径。

imshow()显示图片。

waitKey(0)类似于一个死循环等待用户操作,如果我们写waitKey(1000)就等待1s就消失,当然waitKey的话只要接收到键盘输入值就消失。

结果

处理图像像素点

示例

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

Mat image_process(Mat &img){
   int row=img.rows; // 获取行
   int col=img.cols * img.channels(); // 获取列

   // 改变图片像素点
   for(int i=0;i<row;i++){
       // 获取第i行地址
       uchar* data=img.ptr<uchar>(i);
       for(int j=0;j<col;j++){
           /*int q=rand()%col;
           data[q]=155;*/
           data[j]-=70;
       }
   }
   return img;
}

int main()
{
    // 读取图片信息
    // Mat:图片信息的类
    Mat img=imread("image/dog.jpg",IMREAD_GRAYSCALE);
    image_process(img);
    imshow("img",img);
    while(1){
        int key=waitKey(0); // 等待用户操作
        if(key==10)
            break;
    }
    return 0;
}

结果

简易毛玻璃特效

示例

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

// 毛玻璃特效
Mat img_glass(Mat &img)
{
    RNG rng;
    int random=0;
    for(int i=0;i<img.rows;i++)
    {
        for(int j=0;j<img.cols-5;j++)
        {
            random=rng.uniform(0,5);
            // at<>访问Mat数据域(BGR)
            img.at<Vec3b>(i,j)[0]=img.at<Vec3b>(i+random,j+random)[0]; // B
            img.at<Vec3b>(i,j)[1]=img.at<Vec3b>(i+random,j+random)[1]; // G
            img.at<Vec3b>(i,j)[2]=img.at<Vec3b>(i+random,j+random)[2]; // R
        }
    }
    return img;
}

int main()
{
    // 读取图片信息
    // Mat:图片信息的类
    Mat img=imread("image/dog.jpg");
    img_glass(img);
    imshow("img",img);
    while(1){
        int key=waitKey(0); // 等待用户操作
        if(key==10)
            break;
    }
    return 0;
}

结果

读取视频

示例

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;

int main()
{
    Mat frame;
    VideoCapture cap("video/carMove.mp4");
    while(cap.read(frame))
    {
        imshow("video",frame);
        waitKey(40);
    }

    return 0;
}
相关推荐
皇族崛起4 小时前
【视觉多模态】基于视觉AI的人物轨迹生成方案
人工智能·python·计算机视觉·图文多模态·视觉多模态
办公自动化软件定制化开发python4 小时前
基于PyQt5开发的文件智能查找工具,开源思路+完整实现,解决办公文件检索痛点
开发语言·qt
saoys4 小时前
Opencv 学习笔记:形态学开 / 闭运算(解决噪点与孔洞问题)
笔记·opencv·学习
Pyeako4 小时前
Opencv计算机视觉--边界填充&图像形态学
人工智能·python·opencv·计算机视觉·pycharm·图像形态学·边缘填充
CoovallyAIHub4 小时前
YOLO-Maste开源:首个MoE加速加速实时检测,推理提速17.8%!
深度学习·算法·计算机视觉
深蓝海拓4 小时前
PySide6,QEventLoop.exec()的使用
笔记·python·qt·学习·pyqt
_OP_CHEN4 小时前
【从零开始的Qt开发指南】(二十)Qt 多线程深度实战指南:从基础 API 到线程安全,带你实现高效并发应用
开发语言·c++·qt·安全·线程·前端开发·线程安全
曾帅1685 小时前
uniapp安卓启动图
android·opencv·uni-app
qq_401700416 小时前
CardLayout 实现自定义布局
qt
Rui_Freely6 小时前
Vins-Fusion之 SFM 滑窗内相机位姿及特征点3D估计(十三)
人工智能·算法·计算机视觉