⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 morphology.h

📁 将数字图像处理的一般算法都集中在一个MFC的框架中
💻 H
字号:
#ifndef _INSIDE_VISUAL_CPP_MORPHOLOGY
#define _INSIDE_VISUAL_CPP_MORPHOLOGY
#include "ImageCenterDib.h"

//结构元素对,该结构专门为击中击不中变换而定义
struct ElementPair
{
	int hitElement[9];
	int missElement[9];
};

//形态学处理类
class Morphology:public ImgCenterDib
{
public:
	//输出图像每像素位数
	int m_nBitCountOut;

	//输出图像位图数据指针
	unsigned char * m_pImgDataOut;

	//输出图像颜色表
	LPRGBQUAD m_lpColorTableOut;
private:
	//输出图像的宽
	int m_imgWidthOut;

	//输出图像的高
	int m_imgHeightOut;

	//结构元素(模板)指针
	int *m_maskBuf;

	//结构元素宽
	int m_maskW;

	//结构元素高
	int m_maskH;

	//定义8个方向的击中击不中变换结构元素对
	ElementPair m_hitMissMask[8];
public:
	//不带参数的构造函数
	Morphology();

	//带参数的构造函数
	Morphology(CSize size, int nBitCount, LPRGBQUAD lpColorTable, 
		unsigned char *pImgData);

	//析构函数
	~Morphology();

	//返回输出图像的尺寸
	CSize GetDimensions();

	//结构元素(模板)输入函数,在调用其它形态学处理函数前必须先调用此函数
	void InputMask(int *mask,int maskW, int maskH);

	//二值腐蚀
	void BinaryErosion();

	//二值膨胀
	void BinaryDilation();

	//二值开
	void BinaryOpen();

	//二值闭
	void BinaryClose();

	//二值内边界
	void BinaryInnerEdge();

	//二值外边界
	void BinaryOuterEdge();

	//二值形态学边界
	void BinaryContour();

	//击中击不中细化
	void MorphoThinning();

	//灰值腐蚀
	void GrayErosion();

	//灰值膨胀
	void GrayDilation();

	//灰值开
	void GrayOpen();

	//灰值闭
	void GrayClose();

	//灰值形态学梯度
	void GrayGradient();

	//灰值波锋检测
	void GrayTopHatPeak();

	//灰值波谷检测
	void GrayTopHatVally();

	//灰值峰谷检测器
	void GrayTopHatPeakVally();
private:
	//二值腐蚀基本运算,背景为黑色,目标为白色,二值开、闭、形态学梯度等操作都要调
	//用这个函数
	void BasicErosionForBinary(unsigned char *imgBufIn, unsigned char *imgBufOut,
		int imgWidth,int imgHeight,int *maskBuf, int maskW, int maskH);

	//二值膨胀基本运算,背景为黑色,目标为白色,二值开、闭、形态学梯度等操作都要调用
	//这个函数
	void BasicDilationForBinary(unsigned char *imgBufIn, unsigned char *imgBufOut,
		int imgWidth,int imgHeight,int *maskBuf, int maskW, int maskH);
					 

	//定义击中击不中变换的结构元素对
	void DefineElementPair();

	//击中击不中变换
	void HitAndMiss(unsigned char *imgBufIn, unsigned char *imgBufOut,
		int imgWidth,int imgHeight,ElementPair hitMissMask);

	//灰值腐蚀基本运算,灰值开、闭、形态学梯度等操作都要调用这个函数
	void BasicErosionForGray(unsigned char *imgBufIn, unsigned char *imgBufOut,
		int imgWidth,int imgHeight,int *maskBuf, int maskW, int maskH);
					
	//灰值膨胀基本运算,灰值开、闭、形态学梯度操作等都要调用这个函数
	void BasicDilationForGray(unsigned char *imgBufIn, unsigned char *imgBufOut,
		int imgWidth,int imgHeight,int *maskBuf, int maskW, int maskH);
					
};
#endif // _INSIDE_VISUAL_CPP_MORPHOLOGY

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -