数字图像处理均衡化灰度拉伸C++实现

/// <summary>
/// 均衡化灰度拉伸
/// </summary>
/// <param name="lpdst">输出图像数据</param>
/// <param name="lpsrc">输入图像数据</param>
/// <param name="width">图像宽度</param>
/// <param name="height">图像高度</param>
void equalize_gray(unsigned char *lpdst, const unsigned char *lpsrc, int width, int height)
{
	RLIB_RENAME(width, width_x_height);
	width_x_height *= height;

	int k = 0;
	int counts[256] = { 0 };
	// 保存灰度值个数
	for (; k < width_x_height; ++k) {
		++counts[lpsrc[k * 4]];
	}

	// 灰度映射表
	unsigned char gray_map[256];
	double calc_result = 255.0f / width_x_height;

	gray_map[0] = static_cast<unsigned char>(counts[0] * calc_result);

	int m;
	int temp;
	RLIB_RENAME(height, temp_2);
	for (k = 1; k < RLIB_COUNTOF(gray_map); ++k) {
		for (m = 0, temp = 0, temp_2 = 0; m <= k; m += 2)
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值