c语言图片灰度化

时间: 2023-07-02 13:15:54 浏览: 73
将彩色图片转换为灰度图片的方法通常是将R、G、B三个通道的值进行加权平均。C语言中可以使用以下代码实现图片的灰度化: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #pragma pack(2) // 结构体字节对齐方式为 2 字节对齐 typedef struct { unsigned short bfType; // 位图文件类型,必须为 0x4D42 unsigned int bfSize; // 位图文件大小 unsigned short bfReserved1; // 保留字节1 unsigned short bfReserved2; // 保留字节2 unsigned int bfOffBits; // 从文件头到实际位图数据的偏移字节数 } BMPFILEHEADER; typedef struct { unsigned int biSize; // 信息头大小 int biWidth; // 图像宽度 int biHeight; // 图像高度 unsigned short biPlanes; // 位平面数,必须为1 unsigned short biBitCount; // 每像素位数 unsigned int biCompression; // 压缩类型 unsigned int biSizeImage; // 压缩图像大小字节数 int biXPelsPerMeter; // 水平分辨率 int biYPelsPerMeter; // 垂直分辨率 unsigned int biClrUsed; // 颜色表中实际使用的颜色数 unsigned int biClrImportant; // 重要的颜色数 } BMPINFOHEADER; typedef struct { unsigned char b; // 蓝色分量 unsigned char g; // 绿色分量 unsigned char r; // 红色分量 } RGB; int main() { BMPFILEHEADER bmpFileHeader; BMPINFOHEADER bmpInfoHeader; RGB **rgbData; // RGB 数组 unsigned char **grayData; // 灰度数组 FILE *fpIn, *fpOut; int width, height, i, j; float rWeight = 0.299, gWeight = 0.587, bWeight = 0.114; // 加权平均系数 fpIn = fopen("color.bmp", "rb"); // 以二进制方式读取 BMP 图像文件 fpOut = fopen("gray.bmp", "wb"); // 以二进制方式写入 BMP 图像文件 fread(&bmpFileHeader, sizeof(BMPFILEHEADER), 1, fpIn); // 读取 BMP 文件头 fread(&bmpInfoHeader, sizeof(BMPINFOHEADER), 1, fpIn); // 读取 BMP 信息头 width = bmpInfoHeader.biWidth; height = abs(bmpInfoHeader.biHeight); rgbData = (RGB **) malloc(height * sizeof(RGB *)); // 分配 RGB 数组内存 grayData = (unsigned char **) malloc(height * sizeof(unsigned char *)); // 分配灰度数组内存 for (i = 0; i < height; i++) { rgbData[i] = (RGB *) malloc(width * sizeof(RGB)); grayData[i] = (unsigned char *) malloc(width * sizeof(unsigned char)); } fseek(fpIn, bmpFileHeader.bfOffBits, SEEK_SET); // 定位到位图数据 // 读取 RGB 数组 for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { fread(&rgbData[i][j], sizeof(RGB), 1, fpIn); } } // 将 RGB 数组转换为灰度数组 for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { grayData[i][j] = (unsigned char) (rgbData[i][j].r * rWeight + rgbData[i][j].g * gWeight + rgbData[i][j].b * bWeight); } } // 写入 BMP 文件头和信息头 fwrite(&bmpFileHeader, sizeof(BMPFILEHEADER), 1, fpOut); fwrite(&bmpInfoHeader, sizeof(BMPINFOHEADER), 1, fpOut); // 写入灰度数组 for (i = 0; i < height; i++) { fwrite(grayData[i], sizeof(unsigned char), width, fpOut); } fclose(fpIn); fclose(fpOut); for (i = 0; i < height; i++) { free(rgbData[i]); free(grayData[i]); } free(rgbData); free(grayData); return 0; } ``` 这段代码中使用了位图文件头(BMPFILEHEADER)和位图信息头(BMPINFOHEADER),分别描述了 BMP 图像文件的基本信息,例如图像的宽度、高度、每像素位数等。RGB 数组用于存储每个像素的 R、G、B 三个通道的值。灰度数组用于存储每个像素的灰度值,灰度值通过加权平均计算得到。最后将灰度数组写入新的 BMP 图像文件中,从而实现了图片的灰度化。

相关推荐

最新推荐

recommend-type

基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip

基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip基于Android Studio的个人记账应用帮助用户轻松管理和跟踪他们的财务源码.zip
recommend-type

基于python实现树莓派和传感器的植物生长环境评估信息系统

【作品名称】:基于python实现树莓派和传感器的植物生长环境评估信息系统 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】:基于python实现树莓派和传感器的植物生长环境评估信息系统
recommend-type

优质资源,Yearning Mysql SQL审核平台

Yearning Mysql SQL审核平台(使用go语言)
recommend-type

c语言课程设计-职工资源管理系统.rar

void displayMenu() { printf("\n+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++\n"); printf("+ 职工资源管理系统 +\n"); printf("+ +\n"); printf("+ 1. 录入职工信息 +\n"); printf("+ 2. 显示全部职工信息 +\n"); printf("+ 3. 根据工号查询
recommend-type

华为OD机试D卷 - 来自异国的客人 - 免费看解析和代码.html

私信博主免费获取真题解析以及代码
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。