纯C语言实现解析单色位图文件获取颜色值

2023-10-27 09:45

本文主要是介绍纯C语言实现解析单色位图文件获取颜色值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在绘制单色位图时,需要考虑字节对齐问题。字节对齐是指数据存储在内存中时按照多字节对齐的原则进行存放,以提高访问效率。

为了实现这个函数,可以按照以下步骤进行:

  1. 计算每行像素数据的实际占用字节数:每个像素占用1个BIT位,即1/8个字节。 

  2. 计算每行像素数据的补齐字节数:为了满足字节对齐要求,需要计算每行像素数据需要补齐的字节数。 

  3. 计算每行像素数据所需的总字节数:包括实际占用字节数和补齐字节数。 总字节数 = 实际占用字节数 + 补齐字节数

  4. 遍历行数和列数,根据索引计算出当前像素在pData数组中的位置: 像素位置 = 行索引 * 总字节数

  5. 根据列索引计算当前像素所在的BIT位在一个BYTE中的偏移量: 偏移量 = 7 - (列索引 % 8)

  6. 根据位运算的方式,将当前像素的值写入pData中的相应位置: if(pData[像素位置]  & 偏移量);

注意一点:标准的单色位图文件遵循从下至上、从左至右的方式扫描并存储

完整利用纯C语言解析单色位图文件获取颜色值的代码实现如下:

typedef char			int8_t;
typedef unsigned char	uint8_t;
typedef unsigned short	uint16_t;
typedef unsigned int	uint32_t;
typedef int				int32_t;#pragma pack(push, 1) // 字节对齐设置为1字节
typedef struct {uint16_t bfType;uint32_t bfSize;uint16_t bfReserved1;uint16_t bfReserved2;uint32_t bfOffBits;
} BMPFileHeader;typedef struct {uint32_t biSize;int32_t biWidth;int32_t biHeight;uint16_t biPlanes;uint16_t biBitCount;uint32_t biCompression;uint32_t biSizeImage;int32_t biXPelsPerMeter;int32_t biYPelsPerMeter;uint32_t biClrUsed;uint32_t biClrImportant;
} BMPInfoHeader;#pragma pack(pop)// 提取单色位图的颜色
void DrawBitmap8(CDC *pDC, const uint32_t x, const uint32_t y, const uint32_t w, const uint32_t h, const uint8_t *pData) 
{uint32_t	index = 0, bitOffset = 0, pixelByte = 0, pixelValue = 0;uint32_t	bytesPerLine = 0;uint32_t	row = 0, col = 0, startX = 0, startY = 0;// 单色位图对齐计算方法bytesPerLine = (w + 7) / 8;bytesPerLine += (bytesPerLine % sizeof(size_t)) ? sizeof(size_t) - bytesPerLine % sizeof(size_t) : 0;for (row = 0; row < h; row++)		// 先按行扫描{for (col = 0; col < w; col++)	// 再按列扫描{// 获取当前像素在 pData 中的索引index = bytesPerLine * row + col / 8;// 获取当前像素在字节中的位偏移bitOffset = 7 - (col % 8);// 获取当前像素值(字节)pixelByte = pData[index];// 获取当前像素值的位状态pixelValue = (pixelByte >> bitOffset) & 1;startX = x + col;startY = y + h - 1 - row;	// 单色位图文件是从下向上再按行扫描// 绘制像素if(!pixelValue)	// 黑色pDC->SetPixel(startX, startY, RGB(0, 0, 0));elsepDC->SetPixel(startX, startY, RGB(0, 255, 0));}}
}// 纯C语言解析单色BMP文件并绘制在xy位置
int32_t loadBitmap8(const int8_t *pFile, CDC *pDC, const uint32_t x, const uint32_t y)
{BMPFileHeader	fileHeader; BMPInfoHeader	infoHeader;uint32_t		bytesPerLine = 0;uint8_t			*pixelData = NULL;FILE			*file = NULL;file = fopen(pFile, "rb");if (file == NULL) {printf("无法打开位图文件\n");return -1; }fread(&fileHeader, sizeof(BMPFileHeader), 1, file);fread(&infoHeader, sizeof(BMPInfoHeader), 1, file);// 检查位图文件是否是单色位图if (infoHeader.biBitCount != 1) {printf("不支持的位图类型\n");fclose(file);return -1; }// 根据位图信息计算行字节数和补齐字节数bytesPerLine = (infoHeader.biWidth + 7) / 8;bytesPerLine += (bytesPerLine % sizeof(size_t)) ? sizeof(size_t) - bytesPerLine % sizeof(size_t) : 0;// 分配像素数据内存pixelData = (uint8_t *)malloc(bytesPerLine * infoHeader.biHeight);if (pixelData == NULL) {printf("内存分配失败\n");fclose(file);return -1; }// 读取像素数据fseek(file, fileHeader.bfOffBits, SEEK_SET);fread(pixelData, bytesPerLine * infoHeader.biHeight, 1, file);fclose(file);// 从x,y点开始绘制w,h的单色位图DrawBitmap8(pDC, x, y, infoHeader.biWidth, infoHeader.biHeight, pixelData);// 绘制完毕释放内存free(pixelData);pixelData = NULL;return 0;
}

运行效果如下:

注意:CDC这个类为MFC专用的绘图函数,请自行实现SetPixel这个函数即可,如有需要完整工程在评论区留邮箱即可!

这篇关于纯C语言实现解析单色位图文件获取颜色值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/286049

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依

利用python实现对excel文件进行加密

《利用python实现对excel文件进行加密》由于文件内容的私密性,需要对Excel文件进行加密,保护文件以免给第三方看到,本文将以Python语言为例,和大家讲讲如何对Excel文件进行加密,感兴... 目录前言方法一:使用pywin32库(仅限Windows)方法二:使用msoffcrypto-too