怎么用C语言实现BMP图像开运算处理
发表于:2025-11-15 作者:千家信息网编辑
千家信息网最后更新 2025年11月15日,这篇文章主要介绍"怎么用C语言实现BMP图像开运算处理",在日常操作中,相信很多人在怎么用C语言实现BMP图像开运算处理问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎
千家信息网最后更新 2025年11月15日怎么用C语言实现BMP图像开运算处理
这篇文章主要介绍"怎么用C语言实现BMP图像开运算处理",在日常操作中,相信很多人在怎么用C语言实现BMP图像开运算处理问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎么用C语言实现BMP图像开运算处理"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
开运算可以把比结构元素小的特定图像细节出去,同时保证不产生全局的几何失真。滤掉比结构元素小的突刺,切断细长搭接而起到分离作用。
运算:用B开启A就是选出了A中某些与B相匹配的点,这些点可由完全包含在A中的结构元素B的平移得到。也就是先腐蚀后加膨胀。
#include#include #include int main(int* argc, char** argv){ FILE* fp = fopen("./threshold.bmp", "rb"); if (fp == 0) return 0; BITMAPFILEHEADER fileHead; fread(&fileHead, sizeof(BITMAPFILEHEADER), 1, fp); BITMAPINFOHEADER infoHead; fread(&infoHead, sizeof(BITMAPINFOHEADER), 1, fp); int width = infoHead.biWidth; int height = infoHead.biHeight; int biCount = infoHead.biBitCount; int lineByte = (biCount*width / 8 + 3) / 4 * 4; RGBQUAD* pColorTable; pColorTable = new RGBQUAD[256]; fread(pColorTable, sizeof(RGBQUAD), 256, fp); unsigned char* pBmpBuf; pBmpBuf = new unsigned char[lineByte*height]; fread(pBmpBuf, lineByte*height, 1, fp); fclose(fp); // 新图 FILE* fop = fopen("open.bmp", "wb"); if (fop == 0) return 0; // 定义结构元素 // 腐蚀操作 int t = 0, d = 0, r = 0; for (int i = 1; i < height; ++i){ for (int j = 0; j < width - 1; ++j){ t = *(pBmpBuf + i*lineByte + j); // 当前点 d = *(pBmpBuf + (i - 1)*lineByte + j); // 下面点 r = *(pBmpBuf + i*lineByte + j + 1); // 右边点 if (t == 0 && d != 0){ *(pBmpBuf + (i - 1)*lineByte + j) = 0;//下边的置位1 } if (t == 0 && r != 0){ *(pBmpBuf + i*lineByte + j + 1) = 0;//右边的置位1 j = j + 1; } } } // 膨胀操作 // 初始化 unsigned char* pBmpBuf2; pBmpBuf2 = new unsigned char[lineByte*height]; for (int i = 0; i < height; ++i){ for (int j = 0; j < width; ++j){ *(pBmpBuf2 + i*lineByte + j) = 255; } } // 腐蚀操作 for (int i = 1; i < height; ++i){ for (int j = 0; j < width - 1; ++j){ t = *(pBmpBuf + i*lineByte + j); // 当前点 d = *(pBmpBuf + (i - 1)*lineByte + j); // 下面点 r = *(pBmpBuf + i*lineByte + j + 1); // 右边点 if (t == 0 && d == 0 && r == 0){ *(pBmpBuf2 + i*lineByte + j) = 0; // 当前点 } } } // 结构元素向上反转180度,对最下面一排处理 for (int j = 0; j < width - 1; ++j){ t = *(pBmpBuf + j); // 当前点 d = *(pBmpBuf + lineByte + j); // 上面点 r = *(pBmpBuf + j + 1); // 右边点 if (t == 0 && d == 0 && r == 0){ *(pBmpBuf2 + j) = 0; // 当前点 } } // 结构元素向右反转,对最右边一列处理 for (int i = 1; i < height; ++i){ t = *(pBmpBuf + i*lineByte + width - 1); d = *(pBmpBuf + (i - 1)*lineByte + width - 1); r = *(pBmpBuf + i*lineByte + width - 2); if (t == 0 && d == 0 && r == 0){ *(pBmpBuf2 + i*lineByte + width - 1) = 0; // 当前点 } } fwrite(&fileHead, sizeof(BITMAPFILEHEADER), 1, fop); fwrite(&infoHead, sizeof(BITMAPINFOHEADER), 1, fop); fwrite(pColorTable, sizeof(RGBQUAD), 255, fop); fwrite(pBmpBuf2, lineByte*height, 1, fop); fclose(fop); system("pause"); return 0;}
实验结果:

实验结果分析:效果图和原图差别不大。但细节如眼睛略微由区别。
到此,关于"怎么用C语言实现BMP图像开运算处理"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
处理
运算
元素
前点
结构
图像
右边
语言
学习
面点
更多
细节
结果
实验
帮助
实用
接下来
不大
也就是
作用
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
黑暗之魂为什么不能连服务器了
网络技术三种备份
易语言服务器怎么发数据
自然资源局网络安全风险点报
汇通交易系统连接不上服务器
关于区块链软件开发的论文
前端软件开发服务费
网络安全观和网络强国思想
网络安全的基本防护措施有
格力集团数据库
人事管理系统软件开发南京
数据库 新技术
西安的小说阅读软件开发公司
温州市网络技术有限公司
软件开发项目都有什么构架
数据库市场优势
网络安全产品公司画册模板
网络安全性保护措施
中国天文台陨石数据库
济南移动软件开发报价
网络意识网络安全稿
大学网络技术实训心得
东莞教育软件开发架构
如何在数据库插入相同数据
网络安全警示词
计算机操作与网络安全课件
掌握网络技术基本应用作业
河北发展软件开发资费
网警开展网络安全进校园宣传活动
英雄联盟连接服务器失败