1、图像在内存中存储方式,图像矩阵的大小取决于颜色模型,取决于所有的通道数;还有重要的颜色空间缩减的概念:因为如果是RGB的话,使用uchar的话,就有256^3的结合方法。所以要用到颜色缩减的方法,就是利用在每个像素值里抽选一部分像素值,而不是选择全部像素值。利用的公式是Inew=(Iold/10)*10来计算。

总结来看:就是对图像矩阵遍历每一个像素,然后对像素值进行公式运算。

2、LUT函数:Look up table操作,就是对于像素图像进行批量查找、扫描与操作图像。计时函数:getTickCount()和getTickFrequency()函数。

3、访问图像中像素的三类方法,参照opencv蓝皮书的111页,(colorReduce()函数的三种写法:(这个是用来减少颜色空间的函数)

//这种做法是第一种做法用指针来做。
void colorReauce(Mat& inputImage, Mat& outputImage, int div)
{
outputImage = inputImage.clone();//这个是将图片复制;
int rowNumber = outputImage.rows;//
int colNumber = outputImage.cols*outputImage.channels();这个是找出每列中元素的个数,找出通道中的个数,参照那个图片颜色空间的通道数目。灰度图是通道数为1,彩色图是通道数为3;
for (int i = ; i < rowNumber; i++)
{
uchar* data = outputImage.ptr<uchar>(i);//获取第i行的首地址;
for (int j = ; j < colNumber; j++)
{
data[j] = data[j] / div*div + div / ;//处理每个像素 ;
}
}
}

第一种是用指针的方法访问元素;

第二种做法是用迭代器来处理像素;类似与STL库中的迭代器;

第三种做法是用动态地址来计算,就是将蓝色、红色和绿色来进行分别测量;(image.at<vec3b>(j, i)[channe]=value;tips:注意这个通道的顺序是BGR,不是RGB)

4、ROI区域图像叠加&图像混合

感兴趣区域:ROI(这个是简化工作工程的图片区域,是从图像中选择一个图像区域中)

定义这个区域有两种方法:(1)使用矩形区域Rect(2)指定感兴趣行或列的范围(Range)Range是指从起始索引到终止索引,

(1)Mat imageROI;

Mat imageROI = image(Rect(500,250,logo.cols,logo.rows));//这个是定义ROI区域的

(2)imageROI = image(Range(250,250+logoImage.rows),Range(200,200+logoIamge.cols));

5、addWeighted()函数 (计算数组加权和)double alpha、double beta和 double gamma这个分别代表数组的权重。参照ROI蓝皮书的118页的代码;

(tips:两幅图片一定要同样的类型和尺寸,因为我们做的是两张图片的加权,两张图片不相同不能运算)

6、初级图像混合:addWeighted函数,参照前面的代码(https://blog.csdn.net/poem_qianmo/article/details/20911629

addWeighted的矩阵表达式是:dst = src1[I]*alpha+ src2[I]*beta + gamma;

7、分离颜色通道、多通道图像混合;通过split和merge方法来进行。

(1)通道分离:split()函数,是一个多通道数组分离几个单通道数组;

split函数:void split(const Mat& src, Mat *mvbegin);

void split(InputArray m, OutputArrayOfArrays mv);

公式:mv[c](I)=src(I)c

8、输入XML和YAML文件

xml和YAML文件是用来做数据的存储和传输用的,我们训练玩的特征点数据是存储在这里的。

9、阈值化

固定阈值操作:Threshold函数

函数Threshold()对单通道数组应用固定阈值操作,典型对于灰度图像进行阈值操作得到二值图像,compare()函数可以达到目的;

double threshold(InputArray src, OutputArray dst, double thresh, double maxval, int type)

  • 第一个参数,InputArray类型的src,输入数组,填单通道,8或32位浮点类型Mat即可
  • 第二个参数,OutputArray类型的dst,函数调用后的运算结果存在这里,这个参数用来存放输出结果,且和第一个参数中的Mat变量有一样尺寸和类型;
  • 第三个参数,double类型的thresh,阈值的具体值。
  • 第四个参数,double类型的maxval,当第五个参数阈值类型type取CV_THRESH_BINARY 或者 CV_THRESE_INV时阈值类型最大值;
  • 第五个参数,int类型的type,阈值类型。threshold()函数支持的对图像取阈值的方法由其确定

自适应阈值操作:adaptiveThreshold()函数;

void adaptiveThreshold(InputArray src, OutputArray dst, double maxValue, int adaptiveMethod, int thresholType, int blockSize, double c)

  • 第一个参数,InputArray类型的src,输入图像;

第二个参数,OutputArray类型的dst,这个类型和尺寸和源图像相同;

10、RotatedRect()函数

RotatedRect该类表示平面上的旋转矩形,有三个属性:

  1. 矩形中心点(质心)
  2. 边长(长和宽)

3.旋转角度

opencv core组件进阶的更多相关文章

  1. opencv 3 core组件进阶(3 离散傅里叶变换;输入输出XML和YAML文件)

    离散傅里叶变换 #include "opencv2/core/core.hpp" #include "opencv2/imgproc/imgproc.hpp" ...

  2. opencv 3 core组件进阶(2 ROI区域图像叠加&图像混合;分离颜色通道、多通道图像混合;图像对比度,亮度值调整)

    ROI区域图像叠加&图像混合 #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp&g ...

  3. opencv 3 core组件进阶(1 访问图像中的像素)

    访问图像像素的三类方法 ·方法一 指针访问:C操作符[ ]; ·方法二 迭代器iterator; ·方法三 动态地址计算. #include <opencv2/core/core.hpp> ...

  4. OpenCV之Core组件进阶

    颜色空间缩减 利用C++类型转换时向下取整操作,实现定义域内颜色缩减.表达式如下 Inew = (Iold/10)*10 简单的颜色空间缩减算法可由以下两步组成: (1)遍历图像矩阵的每个元素 (2) ...

  5. core组件进阶

    访问图像像素 存储方式 BGR连续存储有助于提升图像扫描速度. isContinuous()判断是否是连续存储. 颜色空间缩减 仅用这些颜色中具有代表性的很小的部分,就足以达到同样的效果. 将现有颜色 ...

  6. OpenCV4Android——No implementation found for native Lorg/opencv/core/Mat;.n_Mat ()J

    ok 12-17 08:13:10.461: W/dalvikvm(540): No implementation found for native Lorg/opencv/core/Mat;.n_M ...

  7. java.lang.UnsatisfiedLinkError: No implementation found for long org.opencv.core.Mat.n_Mat()

    Android调试openCV4Android的时候出现以下错误 java.lang.UnsatisfiedLinkError: No implementation found for long or ...

  8. .Net Core组件化视图(部分视图)

    .Net Core组件化视图(部分视图) 1.背景 1.以前我们使用.Net的时候使用部分视图的方式在,.Net Core 中能在单独处理逻辑的部分视图没有了,但是我们还是想使用现在的.Net Cor ...

  9. Vue基础二之全局API、实例属性和全局配置,以及组件进阶(mixins)的详细教程(案列实现,详细图解,附源码)

    本篇文章主要是写Vue.directive().Vue.use()等常用全局API的使用,vm.$props.vm.$options.vm.$slots等实例属性的使用,以及Vue全局配置.组件的mi ...

随机推荐

  1. postgresql排序分页时数据重复问题

    当同时排序又分页时,如果排序的字段X不是唯一字段,当多个记录的X字段有同一个值时顺序是随机的. 这个有可能造成分页时数据重复的问题.某一页又把上一页的数据查出来了,其实数据库只有一条记录. 解决办法: ...

  2. linux内核完全剖析——基于0.12内核-笔记(1)-CPU 数据通信

    CPU数据通信总线 CPU通过地址线.数据线.控制信号组成的本地总线(或称为内部总线)与系统其它部分进行数据通信. 地址总线 地址总线用于内存或I/O设备的地址,即指明需要读/写数据的具体位置. 数据 ...

  3. ReportViewer 安装

    选择“工具”>“Nuget包管理器”>“程序包管理器控制台” 执行命令:Install-Package Microsoft.ReportingServices.ReportViewerCo ...

  4. MySQL运维之---mysqldump备份、select...into outfile、mysql -e 等工具的使用

    1.mysqldump备份一个数据库 mysqldump命令备份一个数据库的基本语法: mysqldump -u user -p pwd dbname > Backup.sql 我们来讲解一下备 ...

  5. Azure DevKit(AZ3166)源码找不到头文件问题

    Get “Error Presented: #include errors detected” when opening a project The error message is Error Pr ...

  6. 1.3Windows控制台的简单操作:

    目录: 1.控制台的打开 2.盘符的跳转 3.跳转到某个文件夹 4.展示文件 5.清屏 6.历史记录 7.拖动添加路径 8.自动补齐 9.正常退出 1.打开控制台:系统图标键 + R,输入cmd,按回 ...

  7. windows中使用git和开源中国

    现学现卖,学了忘忘了学. 非常感谢OSC提供了这么好的一个国内的免费的git托管平台.这里简单说下TortoiseGit操作的流程.很傻瓜了首先你要准备两个软件,分别是msysgit和tortoise ...

  8. saltstack二次开发(二)

    Saltstack的api Salt-api有两种方式,一种是函数的形式,有人家定义好的函数,我们可以直接调用,直接写python代码调用函数或者类就可以了.第二种形式是salt-api有封装好的ht ...

  9. python reload(sys)找不到,name 'reload' is not defined和Python3异常-AttributeError: module 'sys' has no att

    基于python3.6.1版本,在一个.py文件中,加入这3行:import requests, re, sysreload(sys)sys.setdefaultencoding("utf- ...

  10. 构造方法,this关键字,static关键字,封装

    1.构造方法 定义:构造方法是指实例化对象的方法 语法:[修饰符]  类名(参数){    } 根据有无参数分为有参构造和无参构造 1)有参构造 语法:[修饰符]  类名(type 实例变量,int ...