// 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;
}

c语言实现24位彩色图像二值化相关推荐

  1. 【OpenCV 4开发详解】图像二值化

    本文首发于"小白学视觉"微信公众号,欢迎关注公众号 本文作者为小白,版权归人民邮电出版社发行所有,禁止转载,侵权必究! 经过几个月的努力,小白终于完成了市面上第一本OpenCV 4 ...

  2. OpenCV学习笔记(三)——图像像素(图像的最大(小)值、均值、标准差、比较运算、逻辑运算、图像二值化)

    目录 1 图像像素统计 1.1 图像像素的最大值和最小值 1.2 计算图像的均值和标准差 2 两图像间的像素操作 2.1 比较运算 2.2 逻辑运算 3 图像二值化 1 图像像素统计 数字图像可以用大 ...

  3. C语言数字图像处理---1.2 彩色图像灰度化和二值化

    本篇主要讲述32位彩色图像的灰度化和二值化内容. [彩色图像灰度化] 1.定义 在上一节中,我们介绍了8位单色灰度图,它使用0-255来表示一个像素,但在实际使用中,我们最常用的还是彩色图像灰度化.对 ...

  4. 还在纠结通道数、位深度?实验带你看懂关于灰度图像,二值化图像,彩色图像、图片通道数,位深度的全部内容

    数据加载相关 前言 图片的通道数.位深度 单通道 三通道 四通道 通道数之间的转化 二值化图像 小结 灰度图像 小结 pillow库 相关全部代码 前言 首先我们都知道,图像是由一个个像素点组成的.图 ...

  5. 【转】c#数字图像处理(二)彩色图像灰度化,灰度图像二值化

    转自:https://www.cnblogs.com/dearzhoubi/p/8571652.html 为加快处理速度,在图像处理算法中,往往需要把彩色图像转换为灰度图像,在灰度图像上得到验证的算法 ...

  6. c语言实现灰度图转换为二值图

    转载自:https://www.cnblogs.com/wd1001/p/4571916.html c语言实现灰度图转换为二值图 将上篇得到的灰度图转换为二值图,读取像素数据,低于某一值置0,否则设置 ...

  7. 卷积神经网络——24位彩色图像的卷积的详细介绍

    卷积用于图像处理: 卷积在函数方面的表现是一种连续的,可以用积分来表示,其实在初识积分的时候,我们就知道积分是通过离散数据求和得来的,这也决定了图像处理也可以运用到卷积的原理.在电脑中,图像其实是一个 ...

  8. Python使用openCV把原始彩色图像转化为灰度图、使用OpenCV把图像二值化(仅仅包含黑色和白色的简化版本)、基于自适应阈值预处理(adaptive thresholding)方法

    Python使用openCV把原始彩色图像转化为灰度图.使用OpenCV把图像二值化(仅仅包含黑色和白色的简化版本).基于自适应阈值预处理(adaptive thresholding)方法 目录

  9. python opencv二值化图像_python opencv,读取彩色图像,提取三通道,图像二值化,提取图像的边缘...

    python opencv,读取彩色图像,提取三通道,图像二值化,提取图像的边缘 python opencv 1,读取图像 2,图像变矩阵 3,图像转灰度图像 4,彩色图像是3D数组 5,灰度图像是2 ...

最新文章

  1. 后端开发开发mac装机和开发环境指南(新手版)
  2. Nomad技术手册:整体架构(Architecture)
  3. python—os模块、时间模块
  4. js 为表格增加行 动态
  5. NeurIPS 2021 | 视频压缩框架DCVC:从残差编码到条件编码,建模上下文
  6. 厉害了!牛顿法深度学习优化器,效果比肩SGD和Adam
  7. Spring : Factories这个是什么
  8. C语言中extern 全局变量,二进制文件与内存,static,const对栈,内存的使用情况
  9. 《隐秘的角落》:发生在IDC机房的隐秘事件
  10. 深度学习-对抗神经网络简介
  11. Coursera 斯坦福大学科学论文写作课程笔记(二)
  12. (5)air202读取串口数据并上传到阿里云显示
  13. 计算机专业毕业后大致的工作方向
  14. python python中max()函数的用法
  15. 计算机体系结构--进制及其运算
  16. 手把手教大家搭建微信公众号查题功能
  17. springboot 佛祖保佑,永无bug
  18. 【牛客】恒生公司2015秋招开发类笔试题
  19. Terracotta学习文档
  20. ctfshow XSS web316-web333 wp

热门文章

  1. 又猎一“狐”:一名外逃越南嫌疑人落网中
  2. AUTOCAD使用笔记
  3. 【图像Restoration】Learning Enriched Features for Real Image Restoration and Enhancement
  4. 京东手机评论分析(一):词云
  5. 计算机科学的影响因子,影响因子最高的计算机科学期刊(前50种).doc
  6. 【养生之道】男人养生的秘诀
  7. Linux文件系统目录结构详解
  8. 大厂技术实现 | 爱奇艺文娱知识图谱的构建与应用实践 @自然语言处理系列
  9. Flash鼠绘教程:临摹徐悲鸿的骏马图
  10. Windows系统——ATTCK红队评估实战靶场(二)——CS方式