如何用C语言实现bmp图像对比度扩展
发表于:2025-02-16 作者:千家信息网编辑
千家信息网最后更新 2025年02月16日,这篇文章主要介绍"如何用C语言实现bmp图像对比度扩展",在日常操作中,相信很多人在如何用C语言实现bmp图像对比度扩展问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"如
千家信息网最后更新 2025年02月16日如何用C语言实现bmp图像对比度扩展
这篇文章主要介绍"如何用C语言实现bmp图像对比度扩展",在日常操作中,相信很多人在如何用C语言实现bmp图像对比度扩展问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"如何用C语言实现bmp图像对比度扩展"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
假设有一幅图,由于成象时光照不足,使得整幅图偏暗(例如,灰度范围从0到63);或者成象时光照过强,使得整幅图偏亮(例如,灰度范围从200到255),我们称这些情况为低对比度,即灰度都挤在一起,没有拉开。灰度扩展的意思就是把你所感性趣的灰度范围拉开,使得该范围内的象素,亮的越亮,暗的越暗,从而达到了增强对比度的目的。
图中的横坐标gold表示原图的灰度值,纵坐标gnew表示gold经过对比度扩展后得到了新的灰度值。a,b,c为三段直线的斜率,因为是对比度扩展,所以斜率b>1。g1old和g2old表示原图中要进行对比度扩展的范围,g1new和g2new表示对应的新值。用公式表示为:
实现代码:
#include#include #include #pragma pack(1) //全紧凑模式typedef struct { unsigned char bfType[2]; unsigned int bfSize; unsigned short bfReserved1; unsigned short bfReserved2; unsigned int bfOffBits;}bitmapFileHeader;typedef struct { unsigned int biSize; unsigned int biWidth; unsigned int biHeight; unsigned short biPlanes; unsigned short biBitCount; unsigned int biCompression; unsigned int biSizeImage; unsigned int biXPixPerMeter; unsigned int biYPixPerMeter; unsigned int biClrUsed; unsigned int biClrImportant;}bitmapInfoHeader;typedef struct{ unsigned char rgbBlue; unsigned char rgbGreen; unsigned char rgbRed; unsigned char rgbReserved;}rgbQUAD;typedef struct{ bitmapFileHeader bfHeader; bitmapInfoHeader biHeader; rgbQUAD palette[256]; unsigned char *imgData;}bmp;int main(){ FILE *fp; if((fp=fopen("d:\Temp\\test_gray.bmp","rb"))==NULL){ perror("can not open file!"); return -1; } //读入彩色bmp图像文件头,信息头和图像数据 bitmapFileHeader bfHeader; fread(&bfHeader,14,1,fp); bitmapInfoHeader biHeader; fread(&biHeader,40,1,fp); int imSize=biHeader.biSizeImage; int width=biHeader.biWidth; int height=biHeader.biHeight; int bitCount=biHeader.biBitCount; int lineBytes=(width*bitCount+31)/32*4; fseek(fp,bfHeader.bfOffBits,SEEK_SET); unsigned char*imageData=(unsigned char*)malloc(imSize*sizeof(unsigned char)); fread(imageData,imSize*sizeof(unsigned char),1,fp); fclose(fp); bmp b; memcpy(&(b.bfHeader),&bfHeader,sizeof(bfHeader)); memcpy(&(b.biHeader),&biHeader,sizeof(biHeader)); b.imgData=(unsigned char*)malloc(sizeof(unsigned char)*imSize); memset(b.imgData,0,sizeof(unsigned char)*imSize); for(int i=0;i<256;i++){ b.palette[i].rgbBlue=i; b.palette[i].rgbGreen=i; b.palette[i].rgbRed=i; } int i,j,temp; double m=1.5,g1=100.0,g2=200.0; //m在这里对应斜率b,因为"b"这个符号被bmp图像结构名占了 double a=(255.0-m*(g2-g1))/(255.0-(g2-g1)); for(i=0;i 到此,关于"如何用C语言实现bmp图像对比度扩展"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
对比度
图像
灰度
范围
语言
学习
斜率
原图
成象
时光
更多
帮助
实用
紧凑
接下来
代码
信息
公式
就是
彩色
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
灌云选择网络技术创新服务
网络安全行业怎么上班
江苏戴尔服务器维修维保
软件开发最好选什么笔记本
服务器管理部署网站
数据库设计实验茶叶管理系统
如何mdf导入数据库
服务器带内和带外配置
软件开发的技术总监岗位职责
幻想战姬服务器
怎样设置网络安全模式
数据库是一个磁盘文件
服务器cpu真的很好用吗
手机应用软件开发区网红
青岛公司软件开发
软件制图员如何转软件开发
如何通过页面去服务器找查询语句
php在软件开发新资待遇
光遇服务器什么时候到
软件开发费用怎么处理
淄川瓷砖管理软件开发
服务器配两个i9
删除数据库的注册表
金蝶怎么录初始数据库
形容那个网络技术的新词语
服务器macbook
鼠疫2怎么开服务器
闵行区个人软件开发诚信合作
曙光服务器单盘识别不到系统盘
网络安全管理的毕业论文