#include<iostream> #include<opencv2/core/core.hpp> #include<opencv2/highgui/highgui.hpp> //计算一幅图像的hu矩 int main() { IplImage* src; src = cvCreateImage(cvSize(10,10),8,1); //这里是创建一幅图像 也可以自己加载一幅图像计算 cvZero(src); //把所以值都赋值为0 int xx,yy; for( yy = 0;yy<5;yy++){ for( xx = 0;xx<5;xx++){ cvSetReal2D(src,yy,xx,255); //把前5行5列的像素变为255 白色 } } /*cvNamedWindow("1"); cvShowImage("1",src);*/ double m00,m10,m01; //计算0阶矩和1阶矩 CvMoments moment; cvMoments(src,&moment,2); //2: 只要比0大的数都可以 表示像素255的点都用1来表示 m00 = cvGetSpatialMoment(&moment,0,0); m10 = cvGetSpatialMoment(&moment,1,0); m01 = cvGetSpatialMoment(&moment,0,1); double x = m10/m00; double y = m01/m00; CvHuMoments humoment; cvGetHuMoments(&moment,&humoment); //计算出hu矩的值 cvWaitKey(0); return 0; }
本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:


