由于专业原因,最近涉及到了OpenCV函数库的使用,我是结合C++。今天的目标是把一幅灰度图像的边缘进行提取,然后将其边缘坐标保存至文本(如.txt)。
当然,对于有C++编程基础的人来说这很简单,用ofstream类声明一个对象fout创建文本文件并进行写入即可:
1 ofstream fout("points2D.txt");
但是这里要注意的是,图像坐标读取函数cvGet2D(img, index1, index2)的使用,第一个参数是图像名称(指针),后两个参数分别是横纵坐标值。所以(j, i)顺序和我们以前接触的(i, j)相反,具体看一下代码:
1 for (int i=0;i< img->height;++i) { 2 for (int j=0;j<img->width;++j) { 3 cvScalar s; 4 s = cvGet2D(img,j,i); 5 if (s.val[0]==255) { 6 fout<<i<<" "<<j; 7 } 8 fout<<"\n"; 9 } 10 }
这样就把边缘点坐标都保存在了文件“points2D.txt”中了。
欢迎指正错误,大家一起交流、学习、进步。