linu下C语言之BMP图片操作编程(下)
前面提高了一个将BMP左转的程序,右转其实也是类似的操作,就不写了,这节,我们来实现,将一张BMP图进行灰度处理,代码贴上:
#include <stdio.h>
#include <fcntl.h>
#include <unistd.h>
#define RGB(r,g,b) ((r+g+b)/3)
typedef unsigned char U8 ;
typedef unsigned short U16 ;
typedef unsigned int U32 ;
#pragma pack(1)
struct bmp_header
{
//bmp header
U8 Signatue[2] ; // B M
U32 FileSize ; //文件大小
U16 Reserv1 ;
U16 Reserv2 ;
U32 FileOffset ; //文件头偏移量
//DIB header
U32 DIBHeaderSize ; //DIB头大小
U32 ImageWidth ; //文件宽度
U32 ImageHight ; //文件高度
U16 Planes ;
U16 BPP ; //每个相素点的位数
U32 Compression ;
U32 ImageSize ; //图文件大小
U32 XPPM ;
U32 YPPM ;
U32 CCT ;
U32 ICC ;
};
#pragma pack()
int main(int argc , char **argv)
{
if(argc != 4)
return -1 ;
int fd ;
int dest_fd ;
fd = open(argv[1] , O_RDONLY);
if(-1 == fd)
{
perror("open bmp file fail");
return -2 ;
}
dest_fd = open( argv[2] , O_RDWR | O_CREAT|O_TRUNC , 0777);
if(dest_fd < 0 )
{
perror("open rgb565 fail");
return -3 ;
}
int value = atoi(argv[3]);
struct bmp_header header ;
int ret ;
ret = read(fd , &header , sizeof(struct bmp_header));
printf(" Signatue[0] : %c \n " , header.Signatue[0] );
printf(" Signatue[1] : %c \n " , header.Signatue[1] );
printf(" FileSize : %d \n " , header.FileSize );
printf(" Reserv1 : %d \n " , header.Reserv1 );
printf(" Reserv2 : %d \n " , header.Reserv2 );
printf(" FileOffset : %d \n " , header.FileOffset );
printf(" DIBHeaderSize : %d \n " , header.DIBHeaderSize);
printf(" ImageWidth : %d \n " , header.ImageWidth );
printf(" ImageHight : %d \n " , header.ImageHight );
printf(" Planes : %d \n " , header.Planes );
printf(" BPP : %d \n " , header.BPP );
printf(" Compression : %d \n " , header.Compression );
printf(" ImageSize : %d \n " , header.ImageSize );
printf(" XPPM : %d \n " , header.XPPM );
printf(" YPPM : %d \n " , header.YPPM );
printf(" CCT : %d \n " , header.CCT );
printf(" ICC : %d \n " , header.ICC );
char buffer[header.ImageSize] ;
read(fd , buffer , header.ImageSize);
close(fd);
//改变地方
write(dest_fd , &header , sizeof(struct bmp_header));
int row , col ;
char *p = NULL ;
for(row = 0 ; row < 10 ; row++)
{
for(col = 0 ; col < 10 ; col++)
{
p = buffer + (row * 800 + col)*3 ;
*p = 255;
*(p+1)=255;
*(p+2)=255;
}
}
char data ;
for(row = 0 ; row < 480 ; row++)
{
for(col = 0 ; col < 800 ; col++)
{
p =( buffer+(row*800 + col)*3);
data = RGB((unsigned char)(*(p+2)) , (unsigned char)(*(p+1)) ,
(unsigned char )(*(p)));
if(data < value)
{
*p = 0;
*(p+1)=0;
*(p+2)=0;
}
else
{
*p = data;
*(p+1)=data;
*(p+2)=data;
}
write(dest_fd , p , 3);
}
}
close(dest_fd);
return 0 ;
}
linu下C语言之BMP图片操作编程(下)的更多相关文章
- linu下C语言之BMP图片操作编程(上)
BMP文件格式,也被称为位图图像文件或与设备无关的位图文件格式(DIB)或者只是一个位图,是 一个光栅图形 图像文件格式使用 来存储位图,数字,图片,独立的显示设备. 微软已经定义了一个特定的表示颜色 ...
- linu下C语言之BMP图片操作编程(中)
http://blog.csdn.net/morixinguan/article/details/50719472 关于BMP图的介绍之前已经说过了,最近要用到,又要重新开始学习. 现在实现一个让bm ...
- 【C】用C语言提取bmp图片像素,并进行K-means聚类分析——容易遇到的问题
关于bmp图片的格式,网上有很多文章,具体可以参考百度百科,也有例子程序.这里只提要注意的问题. (1)结构体定义问题:首先按照百度百科介绍的定义了结构体,但是编译发现重定义BITMAPFILEHEA ...
- C语言实现BMP图片生成
## #include <stdio.h> #include <stdlib.h> #include <string.h> typedef unsigned cha ...
- Go语言基础之接口(面向对象编程下)
1 接口 1.1 接口介绍 接口(interface)是Go语言中核心部分,Go语言提供面向接口编程,那么接口是什么? 现实生活中,有许多接口的例子,比如说电子设备上的充电接口,这个充电接口能干什么, ...
- .NET Core 图片操作在 Linux/Docker 下的坑
一.前言 .NET Core 目前更新到2.2了,但是直到现在在 .NET Core 本身依然不包括和图片有关的 Image.Bitmap 等类型.对于图片的操作在我们开发中很常见,比如:生成验证码. ...
- 位图文件格式及linux下C语言来操作位图文件
说到图片,位图(Bitmap)当然是最简单的,它是Windows显示图片的基本格式,其文件扩展名为*.BMP.由于没有经过任何的压缩,故BMP图片往往很大.在Windows下,任何格式的图片文件都要转 ...
- 嵌入式linux------SDL移植(am335x下显示bmp图片)
#include<stdio.h> #include "/usr/local/ffmpeg_arm/include/SDL/SDL.h" char *bmp_name[ ...
- bmp图片的有关操作
读取bmp图片 并生成新的bmp图片 #include "stdafx.h"#include <windows.h>#include <cmath>#inc ...
随机推荐
- 2015多校联赛 ——HDU5288(数学)
OO’s Sequence Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...
- 【USACO】又买饲料 单调队列dp
题目描述 约翰开车回家,又准备顺路买点饲料了(咦?为啥要说“又”字?)回家的路程一共有 E 公里, 这一路上会经过 N 家商店,第 i 家店里有 F i 吨饲料,售价为每吨 C i 元.约翰打算买 K ...
- ●BZOJ 4559 [JLoi2016]成绩比较(容斥)
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=4559 题解: 容斥,拉格朗日插值法. 结合网上的另一种方法,以及插值法,可以把本题做到 O( ...
- [bzoj4828][Ah/Hnoi2017]大佬
来自FallDream的博客,未经允许,请勿转载,谢谢. 人们总是难免会碰到大佬.他们趾高气昂地谈论凡人不能理解的算法和数据结构,走到任何一个地方,大佬的气场就能让周围的人吓得瑟瑟发抖,不敢言语. 你 ...
- nginx负载均衡及详细配置
接上篇nginx配置,然后再准备两台web服务器: nginx服务器:192.168.0.241 web1:192.168.0.141 web2:192.168.0.142 一.两台web服务器先安装 ...
- Oracle10g以上sysaux表空间的维护和清理
SYSAUX表空间在Oracle 10g中引入,其作为SYSTEM表空间的辅助表空间.之前,一些使用独立表空间或系统表空间的数据库组件,现在SYSAUX表空间中存在.通过分离这些组件,减轻了SYSTE ...
- WebApplicationContext类的作用
WebApplicationContext是实现ApplicationContext接口的子类.是专门为WEB应用准备的.作用: 1.它允许从相对于Web根目录的路径中加载配置文件完成初始化工作.从W ...
- redis锁处理并发问题
redis锁处理并发问题 redis锁处理高并发问题十分常见,使用的时候常见有几种错误,和对应的解决办法. set方式 setnx方式 setnx+getset方式 set方式 加锁:redis中se ...
- 如何joomla修改版权信息
1.在language\zh_CN目录下有一个zh-CN.mod_footer.ini文件,修改里面的内容: 2.具体模板的html\mod_footer目录下的default.php文件内(具体文件 ...
- leetcode刷题笔记231 2的幂
题目描述: 给定一个整数,写一个函数来判断它是否是2的幂. 题目分析: 判断一个整数是不是2的幂,可根据二进制来分析.2的幂如2,4,8,等有一个特点: 二进制数首位为1,其他位为0,如2为10,4为 ...