【计算机视觉学习】OpenCV基础(一)简单的图像处理

前言

本文为本系列第一篇文章,涉及有关opencv中图像处理的基本概念及操作,用于快速入门。

像素与通道

基本概念

相比起人眼所看到的色彩斑斓的画面,在数理世界中,图像仅仅被表示为一个个矩阵。

矩阵的x-y坐标所表示位置对应的区域被称为像素,比如上图中橙色区域所示。

色彩是由不同颜色通道组合而成的。上图有三个颜色通道,分别是三原色红(pixel2)、绿(pixel1)、蓝(pixel0)。

  • 对于黑白图像,仅需要一个通道,存储的是0/1值,所以也被称为二进制图像
  • 对于灰度图像,需要两个通道
  • 对于彩色图像,则需要三个通道

OpenCV相关实现

在Opencv中有一个矩阵(Matrix)类------Mat,它可用来表示任意类型和大小的矩阵。

  • cv::Mat::at<typenamet>(row,col)可用于获取单个像素。
    • 灰度图像的typenamet可使用任何数字格式
    • 彩色图像的typenamet对应Vec3b类(名称释义:向量,三个组件,一个字节)

图像灰度处理

示例代码

cpp 复制代码
#include "opencv2/core.hpp"
#include "opencv2/highgui.hpp"
#include <string>
#include <sstream>
#include <iostream>

using namespace std;
using namespace cv;

int main()
{
    Mat gray = imread("图片路径.jpg", IMREAD_GRAYSCALE);

    //此处默认在当前项目路径下生成一张名为Gray.jpg的灰度图片,也可自定义路径
    imwrite("Gray.jpg", gray);
    //用于展示图片的框体名字叫Gray pic
    imshow("Gray pic", gray);
    //等待用户按下按键后退出
    waitKey(0);
    return 0;
}

关于imread中的可选参数:

  • 上述代码中使用的IMREAD_GRAYSCALE将图像转为8位无符号的灰度图像
  • IMREAD_COLOR将图像转为8位无符号的彩色图像
  • IMREAD_UNCHANGED如果原图是16位/32位的,返回对应深度的图像;如果不是,返回8位图像

参考资料

  • 《Learn Opencv 4 by Building Projects Second Edition》David Millan Escriva等著
相关推荐
FL16238631292 小时前
[cmake]基于C++使用纯opencv部署ppocrv5v6的onnx模型
开发语言·c++·opencv
Dick5074 小时前
ROS2 视觉感知、目标检测与 TF 控制闭环复盘:从 /camera/image_raw 到 /cmd_vel 的机器人目标跟随实现
人工智能·计算机视觉·目标跟踪
DXM05215 小时前
第14期|高阶分割模型:Transformer/SegFormer遥感应用
人工智能·python·神经网络·算法·计算机视觉·cnn·ageo
chase_my_dream6 小时前
LeGO-LOAM 详细源码流程解读
c++·计算机视觉·自动驾驶
2401_885665197 小时前
基于OpenCV的模板匹配OCR实战:银行卡与身份证数字识别完整教程
人工智能·python·opencv·计算机视觉·ocr
再一次等风来8 小时前
YOLO26 实测记录:从模型下载、预测验证到 ONNX Runtime 推理部署
yolo·计算机视觉·onnx·yolo26
大奎帝国8 小时前
Segearth-R2-02
人工智能·机器学习·计算机视觉
大奎帝国10 小时前
Segearth-R2-03
深度学习·机器学习·计算机视觉
YOLO数据集集合10 小时前
无人机航拍RGBT双模态行人检测数据集 | 可见光红外对齐 低空小目标检测 多模态计算机视觉基准数据
人工智能·深度学习·目标检测·计算机视觉·无人机
jay神10 小时前
基于 YOLOv8 + CRNN 的车牌识别系统
深度学习·yolo·目标检测·计算机视觉·车牌识别