题目:(P104)

使用cvCmp()创建一个掩码。加载一个真实的图像。使用cvsplit()将图像分割成红,绿,蓝三个单通道图像。

a.找到并显示绿图。

b.克隆这个绿图两次(分别命名为clone1和clone2)。

c.求出这个绿色平面的最大值和最小值。

d.将clone1的所有元素赋值为theash=(unsigned char)((最大值-最小值)/2.0)。

e.将clone2的所有元素复制为0,然后调用函数cvCmp(green_image,clone1,clone2,CV_CMP_GE)。现在clone2将是一个标识绿图中值超过thresh的掩码图像。

f.最后,使用cvSubS(green_image,thresh/2,green_image,clone2)函数并显示结果。

解答:

#include <cv.h>
#include <highgui.h> int main(int argc, const char** argv)
{
IplImage* srcImg = cvLoadImage(argv[1]); //load the image if (!srcImg)
{
printf("cannot open the file...\n");
return -1;
}
IplImage* rImg = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
IplImage* gImg = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
IplImage* bImg = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1); //创建单通道r,g,b图像
IplImage* clone1 = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
IplImage* clone2 = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
double green_maxPixel = 0;
double green_minPixel = 0; //绿色平面最大最小值
double thresh; //阈值thresh
cvSplit(srcImg, rImg, gImg, bImg, 0); //拆分3通道
//-------------------a小题 ------------------
cvNamedWindow("GreenImage0");
cvShowImage("GreenImage0", gImg);
//-------------------b小题---------------------
cvCopy(gImg, clone1);
cvCopy(gImg, clone2); //copy the gImg to clone1 and clone2
//-----------------c小题求绿色平面最大最小值-----------------
cvMinMaxLoc(gImg, &green_maxPixel, &green_minPixel);
//-------------------d小题-------------------------------
thresh = (unsigned char)(green_maxPixel - green_minPixel) / 2.0;
cvSet(clone1, cvScalar(thresh));
//----------------------e小题-----------------------
cvZero(clone2);
cvCmp(gImg, clone1, clone2, CV_CMP_GE);
//---------------------------f小题-------------------
cvSubS(gImg, cvScalar(thresh / 2), gImg, clone2);
cvNamedWindow("GreenImage1");
cvShowImage("GreenImage1", gImg);
cvWaitKey(0);
cvReleaseImage(&srcImg);
cvReleaseImage(&rImg);
cvReleaseImage(&gImg);
cvReleaseImage(&bImg);
cvDestroyWindow("GreenImage0");
cvDestroyWindow("GreenImage1");
return 0;
}

最新文章

  1. 参考bootstrap中的popover.js的css画消息弹框
  2. 【Java每日一题】20161226
  3. react6 事件传递参数
  4. 一次Promise 实践:异步任务的分组调度
  5. android开发时,finish()跟System.exit(0)的区别
  6. WinForm特效:桌面上的遮罩层
  7. PHP自动识别字符集并完成转码详解
  8. ubuntu install rpm package
  9. Codeforces Round #276 (Div. 1) B. Maximum Value 筛倍数
  10. Swift互用性:采用Cocoa设计模式(Swift 2.0版)-b
  11. iOS 9之分屏多任务(Split View)
  12. C语言的画图(圆形动画)
  13. 登陆模块的进化史,带大家回顾java学习历程(一)
  14. jmeter简单得压力测试
  15. squid故障汇总
  16. 堆排、python实现堆排
  17. 11.0-uC/OS-III就绪列表(优先级)
  18. shell命令,从字符串中提取数字
  19. 【Unity】使用AssetDatabase编辑器资源管理
  20. Codeforces 899E - Segments Removal

热门文章

  1. Xshell配色方案推荐
  2. laravel form 表单提交
  3. ACM1002:A + B Problem II
  4. geoserver中WMS服务详细说明
  5. 北京Uber优步司机奖励政策(2月26日)
  6. 深圳Uber司机本周(7.13-7.19凌晨4:00)的奖励政策
  7. CC2541广播机制和代码分析(未完成)
  8. android 学习十四 探索安全性和权限
  9. UPA深度性能报告解读
  10. 「日常训练」Kefa and Company(Codeforces Round #321 Div. 2 B)