前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >OpenCV mat类实现水平投影和垂直投影

OpenCV mat类实现水平投影和垂直投影

作者头像
chaibubble
发布2022-05-07 09:09:21
6980
发布2022-05-07 09:09:21
举报
文章被收录于专栏:深度学习与计算机视觉

图像经过灰度化和otsu阈值分割,分别绘制水平和垂直投影

代码语言:javascript
复制
#include<iostream>  
#include <cv.h>  
#include <highgui.h>  
#include <cvaux.h>  
#include <tchar.h> 

using namespace std ;
using namespace cv ;

int main()
{
	//原图
	Mat srcImage=imread("test.png");  
    imshow("原图",srcImage);  
	//灰度化
    cvtColor(srcImage,srcImage,CV_RGB2GRAY);  
	//otsu阈值分割
    threshold(srcImage,srcImage,0,255,CV_THRESH_OTSU+CV_THRESH_BINARY);   
    imshow("二值图",srcImage);  
	//计算垂直投影
    int *colheight =new int[srcImage.cols];    
	 //数组必须赋初值为零,否则出错。无法遍历数组。 
    memset(colheight,0,srcImage.cols*4);  
    int value;   
    for(int i=0;i<srcImage.rows;i++)   
        for(int j=0;j<srcImage.cols;j++)    
        {    
            value=srcImage.at<uchar>(i,j);  
            if(value==255)    
            {    
                colheight[j]++; 
            }    
  
        }    

        Mat histogramImage(srcImage.rows,srcImage.cols,CV_8UC1);  
        for(int i=0;i<srcImage.rows;i++)    
            for(int j=0;j<srcImage.cols;j++)    
            {    
                value=0;  //设置为黑色。  
                histogramImage.at<uchar>(i,j)=value;    
            }    
          
            for(int i=0;i<srcImage.cols;i++)    
                for(int j=0;j<colheight[i];j++)    
                {    
                    value=255;  //设置为白色  
                    histogramImage.at<uchar>(j,i)=value;  
                }    
                imshow("垂直投影",histogramImage); 
                //计算水平投影
				int *colheighttwo =new int[srcImage.rows];    
				//数组必须赋初值为零,否则出错。无法遍历数组。 
				memset(colheighttwo,0,srcImage.rows*4);  
				int valuetwo; 
				for(int i=0;i<srcImage.rows;i++)    
					for(int j=0;j<srcImage.cols;j++)    
					{    
						valuetwo=srcImage.at<uchar>(i,j);  
						if(valuetwo==255)    
						{    
							colheighttwo[i]++; 
						}    
					}    

					Mat plantImage(srcImage.rows,srcImage.cols,CV_8UC1);  //创建一个新的mat型
					//把这个图全部画成黑色
					for(int i=0;i<srcImage.rows;i++)    
						for(int j=0;j<srcImage.cols;j++)    
						{    
							valuetwo=0;  //设置为黑色。  
							plantImage.at<uchar>(i,j)=valuetwo;    
						}    

						for(int i=0;i<srcImage.rows;i++)    
							for(int j=0;j<colheighttwo[i];j++)    
							{    
								valuetwo=255;  //设置为白色  
								plantImage.at<uchar>(i,j)=valuetwo;  
							}    
							imshow("水平投影",plantImage); 
			             	waitKey(0);
			            	return 0;
}

效果:

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-01-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档