C语言实现24位彩色图像二值化

本文实例为大家分享了C语言实现24位彩色图像二值化的具体代码,供大家参考,具体内容如下

// huiduhua.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include<stdio.h>
#include<windows.h>

int _tmain(int argc, _TCHAR* argv[])
{

 BITMAPFILEHEADER bfhead;
 BITMAPINFOHEADER bihead;
 RGBQUAD *pColorTable;
 unsigned char *pBmpBuf;
 FILE *fp1=fopen("鼠.bmp","rb");
 if(fp1==0)
  return 0;
 fread(&bfhead,14,1,fp1);   //将文件头读入内存
 fread(&bihead,40,1,fp1);   //将信息头读入内存
 int LineByte=(bihead.biWidth*24/8+3)/4*4; //保证每行字节数为4的整数倍

 pBmpBuf=new unsigned char[LineByte*bihead.biHeight]; //为数据区分配内存空间
 fread(pBmpBuf,LineByte*bihead.biHeight,1,fp1);       //将bmp数据区读入内存
 fclose(fp1); 

 printf("Width:%d, Height: %d,biBitCount:%d\n",bihead.biWidth,bihead.biHeight,bihead.biBitCount);

 //现将真彩图灰度化
 int LineByte1=(bihead.biWidth*8/8+3)/4*4;  //由于灰度化后每像素位数变为8,所以每行字节数发生改变,但仍要求为4的整数倍
 FILE *fp2=fopen("鼠2.bmp","wb");
 if(fp2==0)
  return 0;
 //更改文件头,并将其保存
 bfhead.bfSize=14+40+sizeof(RGBQUAD)*256+LineByte1*bihead.biHeight;   //更改文件大小
 bfhead.bfOffBits=14+40+sizeof(RGBQUAD)*256;   //更改偏移值
 fwrite(&bfhead,14,1,fp2);

 //更改信息头并将其保存
 bihead.biBitCount=8;    //更改每像素位数
 bihead.biSizeImage=LineByte1*bihead.biHeight;  //更改数据区大小
 fwrite(&bihead,40,1,fp2);

 //因为灰度化图像有颜色表,所以创建颜色表并保存
 pColorTable=new RGBQUAD[256];
 for(int i=0;i<256;i++)
  pColorTable[i].rgbRed = pColorTable[i].rgbGreen = pColorTable[i].rgbBlue = i;//使颜色表中每种颜色的R,G,B分量相等且等于索引值
 fwrite(pColorTable,sizeof(RGBQUAD),256,fp2);

 //改变数据区
 unsigned char *pBmpBuf1;
 pBmpBuf1=new unsigned char[LineByte1*bihead.biHeight];
 for(int i=0;i<bihead.biHeight;i++)
  for(int j=0;j<bihead.biWidth;j++)
  {
   unsigned char *pb1,*pb2;
   pb1=pBmpBuf+i*LineByte+j*3;
   int y=*(pb1)*0.299+*(pb1+1)*0.587+*(pb1+2)*0.114;
   pb2=pBmpBuf1+i*LineByte1+j;
   *pb2=y;
  }
  //二值化方法一:阈值设为127,灰度值小于127的置零,其他的置为255;

 //for(int i=0;i<bihead.biHeight;i++)
 // for(int j=0;j<bihead.biWidth;j++)
 // {
 //  unsigned char *pb;
 //  pb=pBmpBuf1+i*LineByte1+j;
 //  if(*pb<127)   //将每个像素值与127比较
 //   *pb=0;
 //  else
 //   *pb=255;
 // }
 //方法二:计算像素的平均值K,扫描图像的每个像素值如像素值大于K像素值设为255(白色),值小于等于K像素值设为0(黑色)
 int y=0;//像素和
 int k=0;//像素个数
 for(int i=0;i<bihead.biHeight;i++)
  for(int j=0;j<bihead.biWidth;j++)
  {
   unsigned char *pb;
   pb=pBmpBuf1+i*LineByte1+j;
   y=y+*pb;  //计算所有像素灰度值之和
   k++;      //统计像素个数
  }
 y=y/k; //求像素平均值
 for(int i=0;i<bihead.biHeight;i++)
  for(int j=0;j<bihead.biWidth;j++)
  {
   unsigned char *pb1;
   pb1=pBmpBuf1+i*LineByte1+j;
   if(*pb1<y)         //将每个像素值与平均值作比较
    *pb1=0;
   else
    *pb1=255;
  }

 fwrite(pBmpBuf1,LineByte1*bihead.biHeight,1,fp2);
 fclose(fp2);

 system("pause");
 return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C语言实现将彩色bmp图像转化为灰图、灰度图像反色

    本文实例为大家分享了C语言实现将彩色bmp图像转化为灰图.灰度图像反色的具体代码,供大家参考,具体内容如下 彩色图像转灰度图像 彩色(24位)bmp图像结构: typedef struct{ bitmapFileHeader bfHeader; bitmapInfoHeader biHeader; unsigned char *imgData; }bmp; 灰度(8位)bmp图像结构: typedef struct{ bitmapFileHeader bfHeader; bitmapInfoHe

  • C语言实现24位彩色图像二值化

    本文实例为大家分享了C语言实现24位彩色图像二值化的具体代码,供大家参考,具体内容如下 // huiduhua.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<stdio.h> #include<windows.h> int _tmain(int argc, _TCHAR* argv[]) { BITMAPFILEHEADER bfhead; BITMAPINFOHEADER bihead; RGBQUA

  • 基于c#图像灰度化、灰度反转、二值化的实现方法详解

    图像灰度化:将彩色图像转化成为灰度图像的过程成为图像的灰度化处理.彩色图像中的每个像素的颜色有R.G.B三个分量决定,而每个分量有255中值可取,这样一个像素点可以有1600多万(255*255*255)的颜色的变化范围.而灰度图像是R.G.B三个分量相同的一种特殊的彩色图像,其一个像素点的变化范围为255种,所以在数字图像处理种一般先将各种格式的图像转变成灰度图像以使后续的图像的计算量变得少一些.灰度图像的描述与彩色图像一样仍然反映了整幅图像的整体和局部的色度和亮度等级的分布和特征.图像的灰度

  • Python+OpenCV图像处理——图像二值化的实现

    简介:图像二值化就是将图像上的像素点的灰度值设置为0或255,也就是将整个图像呈现出明显的黑白效果的过程. 普通图像二值化 代码如下: import cv2 as cv import numpy as np #全局阈值 def threshold_demo(image): gray = cv.cvtColor(image, cv.COLOR_RGB2GRAY) #把输入图像灰度化 #直接阈值化是对输入的单通道矩阵逐像素进行阈值分割. ret, binary = cv.threshold(gray

  • 详解Python+OpenCV实现图像二值化

    目录 一.图像二值化 1.效果 2.源码 二.图像二值化(调节阈值) 1.源码一 2.源码二 一.图像二值化 1.效果 2.源码 import cv2 import numpy as np import matplotlib.pyplot as plt # img = cv2.imread('test.jpg') #这几行是对图像进行降噪处理,但事还存在一些问题. # dst = cv2.fastNlMeansDenoisingColored(img,None,10,10,7,21) # plt

  • c#实现图片二值化例子(黑白效果)

    C#将图片2值化示例代码,原图及二值化后的图片如下: 原图: 二值化后的图像: 实现代码: using System; using System.Drawing; namespace BMP2Grey { class Program { static void ToGrey(Bitmap img1) { for (int i = 0; i < img1.Width; i++) { for (int j = 0; j < img1.Height; j++) { Color pixelColor

  • C#数字图像处理之图像二值化(彩色变黑白)的方法

    本文实例讲述了C#数字图像处理之图像二值化(彩色变黑白)的方法.分享给大家供大家参考.具体如下: //定义图像二值化函数 private static Bitmap PBinary(Bitmap src,int v) { int w = src.Width; int h = src.Height; Bitmap dstBitmap = new Bitmap(src.Width ,src.Height ,System .Drawing .Imaging .PixelFormat .Format24

  • python验证码识别教程之灰度处理、二值化、降噪与tesserocr识别

    前言 写爬虫有一个绕不过去的问题就是验证码,现在验证码分类大概有4种: 图像类 滑动类 点击类 语音类 今天先来看看图像类,这类验证码大多是数字.字母的组合,国内也有使用汉字的.在这个基础上增加噪点.干扰线.变形.重叠.不同字体颜色等方法来增加识别难度. 相应的,验证码识别大体可以分为下面几个步骤: 灰度处理 增加对比度(可选) 二值化 降噪 倾斜校正分割字符 建立训练库 识别 由于是实验性质的,文中用到的验证码均为程序生成而不是批量下载真实的网站验证码,这样做的好处就是可以有大量的知道明确结果

  • python opencv 二值化 计算白色像素点的实例

    贴部分代码 #! /usr/bin/env python # -*- coding: utf-8 -*- import cv2 import numpy as np from PIL import Image area = 0 def ostu(img): global area image=cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 转灰度 blur = cv2.GaussianBlur(image,(5,5),0) # 阈值一定要设为 0 !高斯模糊 re

  • python图片二值化提高识别率代码实例

    这篇文章主要介绍了python图片二值化提高识别率代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下 import cv2from PIL import Imagefrom pytesseract import pytesseractfrom PIL import ImageEnhanceimport reimport string def createFile(filePath,newFilePath): img = Image

  • Android实现图像灰度化、线性灰度变化和二值化处理方法

    1.图像灰度化: public Bitmap bitmap2Gray(Bitmap bmSrc) { // 得到图片的长和宽 int width = bmSrc.getWidth(); int height = bmSrc.getHeight(); // 创建目标灰度图像 Bitmap bmpGray = null; bmpGray = Bitmap.createBitmap(width, height, Bitmap.Config.RGB_565); // 创建画布 Canvas c = ne

随机推荐