##1、什么是图像,对图像进行处理是神马操作 一副图像可以定义为二维的函数z = f(x,y),其中x、y是其空间坐标,而其值z的大小就是函数在该点的灰度值。


我特意截取了灰白色和黑色边界的数据,通过数据我们可以看到,图片的大小为256x256,而其边界坐标是纵坐标y(竖直方向)为127-128,灰白色的数值大小为230,黑色为0。每个坐标位置我们称之为一个像素,而对应坐标数值的大小称之为灰度值。这样看起来应该是比较直观的,图像就是二维的数据集合,我们的图像处理就是对这些数值进行转换。说比较难说清楚,让我们做个小变动,我把边界上的一部分为230的值置为0之后会发生什么事情呢?就像下面一样。


- 人机互动
- 物体识别
- 图像分割
- 人脸识别
- 动作识别
- 运动跟踪
- 机器人
- 运动分析
- 机器视觉
- 结构分析
- 汽车安全驾驶 应用领域是非常广泛的,甚至一些AR/VR也需要用到OpenCV进行计算机视觉处理。 ##4、具体使用示例 OpenCV现在已经出到OpenCV3了,先跑个Demo看下效果过过瘾,目前的运行环境是VisualStudio2017+OpenCV3,当然也可以在Android环境下使用,但是OpenCV3本身是C++实现,在Android上使用不仅需要真机测试,还需要JNI调用,学习阶段使用起来不太方便。 先来个平滑滤波,具体原理也暂时先不解释,效果上来讲就是对图片进行模糊处理。先贴上代码,核心代码就是blur(),由它进行均值滤波操作。
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
using namespace cv;
int main( )
{
//【1】载入原始图
Mat srcImage = imread("orange.jpg");
//【2】显示原始图
imshow( "均值滤波【原图】", srcImage );
//【3】进行均值滤波操作
Mat dstImage;
blur( srcImage, dstImage, Size(15, 15));
//【4】显示效果图
imshow( "均值滤波【效果图】" ,dstImage );
waitKey( 0 );
}


代码实现起来很简单,这就是OpenCV的强大之处了,图片的加载,显示,以及图片的操作,这些实现的方法都极其简洁。 对于均值滤波背后的算法刚开始讲解起来会比较麻烦一点,因为会涉及到一些卷积、'核'以及线性滤波、非线性滤波,空间滤波以及频域滤波一些概念,这些得慢慢来,后续会尽量讲到的。