矩阵和图像的操作
(1)cvAnd函数
其结构
复制代码
1
2
3
4
5
6
7void cvAnd( //将src1和src2按像素点取“位与运算” const CvArr* src1,//第一个矩阵 const CvArr* src2,//第二个矩阵 CvArr* dst,//结果矩阵 const CvArr* mask = NULL;//矩阵经行像素点与的“开关” );
程序实例
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16#include <cv.h> #include <highgui.h> #include <stdio.h> int main(int argc, char** argv) { IplImage *src1, *src2,*src3; src1=cvLoadImage("1.jpg"); src2=cvLoadImage("3.jpg"); src3=cvLoadImage("4.jpg"); cvAnd(src1,src2,src3); cvShowImage( "测试1", src1); cvShowImage( "测试2", src2); cvShowImage( "测试3", src3); cvWaitKey(); return 0; }
(2)cvAndS函数
其结构
复制代码
1
2
3
4
5
6
7void cvAndS(//使src1与value进行 位与运算 const CvArr* src1,//第一个矩阵 CvScalar value,//运算标量 CvArr* dst,//结果矩阵 const CvArr* mask = NULL;//运算开关 );
实例程序
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19#include <cv.h> #include <highgui.h> #include <stdio.h> int main(int argc, char** argv) { IplImage *src1, *src2,*src3; src1=cvLoadImage("1.jpg"); src2=cvLoadImage("5.jpg"); CvScalar cs; cs.val[1] = 100.0; cs.val[2] = 100.0; cs.val[0] = 100.0; cs.val[3] = 100.0; cvAndS(src1,cs,src1); cvShowImage( "测试1", src1); cvShowImage( "测试2", src2); cvWaitKey(); return 0; }
输出结果
(3)cvAvg函数
其结构
复制代码
1
2
3
4
5CvScalar cvAvg(//求出src的平均像素值 const CvArr* src,//目标矩阵 const CvArr* mark = NULL//像素开关 );
实例代码:我对上面那个机器猫的图像使用
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18#include <cv.h> #include <highgui.h> #include <iostream> #include <stdio.h> using namespace std; int main(int argc, char** argv) { IplImage *src1; src1=cvLoadImage("1.jpg"); CvScalar cs; cs = cvAvg(src1); cout<<cs.val[0] << endl; cout<<cs.val[1] << endl; cout<<cs.val[2] << endl; cout<<cs.val[3] << endl; getchar(); return 0; }
输出结果
(4)cvAvgSdv函数
其结构
复制代码
1
2
3
4
5
6CvScalar cvAvg(//求像素平均值和标准差 const CvArr* arr,//目标矩阵 CvScalar* mean,//平均值 CvScalar* std_dev,//标准差 const CvArr* mark = NULL//像素开关 );
程序实例:依然用的机器猫图片
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25#include <cv.h> #include <highgui.h> #include <iostream> #include <stdio.h> using namespace std; int main(int argc, char** argv) { IplImage *src1; src1=cvLoadImage("1.jpg"); CvScalar cs,cs1; cvAvgSdv(src1,&cs,&cs1); cout<<"平均值:"<<endl; cout<<cs.val[0] << endl; cout<<cs.val[1] << endl; cout<<cs.val[2] << endl; cout<<cs.val[3] << endl; cout <<endl; cout <<"标准差"<<endl; cout<<cs1.val[0] << endl; cout<<cs1.val[1] << endl; cout<<cs1.val[2] << endl; cout<<cs1.val[3] << endl; getchar(); return 0; }
输出结果
to be continued
最后
以上就是贪玩鸵鸟最近收集整理的关于《学习opencv》笔记——矩阵和图像操作——cvAnd、cvAndS、cvAvg and cvAvgSdv的全部内容,更多相关《学习opencv》笔记——矩阵和图像操作——cvAnd、cvAndS、cvAvg内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复