纯C语言实现图像处理?

哪位大哥知道如何用纯C语言(不能用TurboC,windowsAPI和MFC)对BMP图像实行二值化处理,最好有源代码,非常感谢!!好的话我肯定追加分数!!!... 哪位大哥知道如何用纯C语言(不能用Turbo C ,windows API 和 MFC)对BMP图像实行二值化处理,最好有源代码,非常感谢!!
好的话我肯定追加分数!!!
展开
 我来答
弹击
推荐于2018-03-02 · TA获得超过121个赞
知道答主
回答量:70
采纳率:0%
帮助的人:90.8万
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#define ONE 255
#define ZERO 0
/*
typedef struct tagBITMAPFILEHEADER { // bmfh
WORD bfType;
DWORD bfSize;
WORD bfReserved1;
WORD bfReserved2;
DWORD bfOffBits;
} BITMAPFILEHEADER;
typedef struct tagBITMAPINFOHEADER{ // bmih
DWORD biSize;
LONG biWidth;
LONG biHeight;
WORD biPlanes;
WORD biBitCount
DWORD biCompression;
DWORD biSizeImage;
LONG biXPelsPerMeter;
LONG biYPelsPerMeter;
DWORD biClrUsed;
DWORD biClrImportant;
} BITMAPINFOHEADER;
*/
void main (int argc,char *argv[])
{
FILE *fi,*fo;//I/O file
char fin[80],fon[80];//I/O file name
unsigned char **ri,**ro;
unsigned char buff;
long w,h;
int t;
int i,j;
if(argc<3)
{
printf("orginfile name:");
scanf("%s",fin);
printf("resultfile name:");
scanf("%s",fon);
}else{
sscanf(argv[1],"%s",fin);
sscanf(argv[2],"%s",fon);
}
if(argc==4)
sscanf(argv[4],"%d",&t);
else{
printf("theshold [0,255]:");
scanf("%d",&t);
}

if (((fi=fopen(fin,"rb"))==NULL)||((fo=fopen(fon,"wb"))==NULL))
{
puts("\nfile open failed");
return;
}

fseek(fi,18L,SEEK_SET);
fread(&w,sizeof(long),1,fi);
fread(&h,sizeof(long),1,fi);

fseek(fi,0L,SEEK_SET);

ri=(unsigned char **)malloc(sizeof(unsigned *)*h);
for (i=0;i<h;i++)
*(ri+i)=(unsigned char *)malloc(sizeof(unsigned)*w);

ro=(unsigned char **)malloc(sizeof(unsigned *)*h);
for (i=0;i<h;i++)
*(ro+i)=(unsigned char *)malloc(sizeof(unsigned)*w);
//分配失败后果自负!

for (i=0;i<32;i++){
fread(&buff,sizeof(buff),1,fi);
fwrite(&buff,sizeof(buff),1,fo);}
for (i=0;i<h;i++)
for (j=0;j<w;j++)
fread(*(ri+i)+j,sizeof(unsigned char),1,fi);

for (i=0;i<h;i++)
for (j=0;j<w;j++)
*(*(ro+i)+j)=((*(*(ri+i)+j)<=t)?ZERO:ONE);
for (i=0;i<h;i++)
for (j=0;j<w;j++)
fwrite(*(ro+i)+j,sizeof(unsigned char),1,fo);
fclose(fo);
}
匿名用户
2018-03-02
展开全部
这个不难吧?虽然我不用c,可是说下怎么做,首先打开一个BMP文件,然后按照bmp格式解析到一个数组中,接着进行二值化(这个有很多方法),最后将数组中的数据写入一个新的BMP文件就可以了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
魏女骆灵雨
2020-05-31 · TA获得超过3785个赞
知道大有可为答主
回答量:3107
采纳率:30%
帮助的人:264万
展开全部
#include
<stdio.h>
#include
<stdlib.h>
#include
<conio.h>
#define
ONE
255
#define
ZERO
0
/*
typedef
struct
tagBITMAPFILEHEADER
{
//
bmfh
WORD
bfType;
DWORD
bfSize;
WORD
bfReserved1;
WORD
bfReserved2;
DWORD
bfOffBits;
}
BITMAPFILEHEADER;
typedef
struct
tagBITMAPINFOHEADER{
//
bmih
DWORD
biSize;
LONG
biWidth;
LONG
biHeight;
WORD
biPlanes;
WORD
biBitCount
DWORD
biCompression;
DWORD
biSizeImage;
LONG
biXPelsPerMeter;
LONG
biYPelsPerMeter;
DWORD
biClrUsed;
DWORD
biClrImportant;
}
BITMAPINFOHEADER;
*/
void
main
(int
argc,char
*argv[])
{
FILE
*fi,*fo;//I/O
file
char
fin[80],fon[80];//I/O
file
name
unsigned
char
**ri,**ro;
unsigned
char
buff;
long
w,h;
int
t;
int
i,j;
if(argc<3)
{
printf("orginfile
name:");
scanf("%s",fin);
printf("resultfile
name:");
scanf("%s",fon);
}else{
sscanf(argv[1],"%s",fin);
sscanf(argv[2],"%s",fon);
}
if(argc==4)
sscanf(argv[4],"%d",&t);
else{
printf("theshold
[0,255]:");
scanf("%d",&t);
}
if
(((fi=fopen(fin,"rb"))==NULL)||((fo=fopen(fon,"wb"))==NULL))
{
puts("\nfile
open
failed");
return;
}
fseek(fi,18L,SEEK_SET);
fread(&w,sizeof(long),1,fi);
fread(&h,sizeof(long),1,fi);
fseek(fi,0L,SEEK_SET);
ri=(unsigned
char
**)malloc(sizeof(unsigned
*)*h);
for
(i=0;i<h;i++)
*(ri+i)=(unsigned
char
*)malloc(sizeof(unsigned)*w);
ro=(unsigned
char
**)malloc(sizeof(unsigned
*)*h);
for
(i=0;i<h;i++)
*(ro+i)=(unsigned
char
*)malloc(sizeof(unsigned)*w);
//分配失败后果自负!
for
(i=0;i<32;i++){
fread(&buff,sizeof(buff),1,fi);
fwrite(&buff,sizeof(buff),1,fo);}
for
(i=0;i<h;i++)
for
(j=0;j<w;j++)
fread(*(ri+i)+j,sizeof(unsigned
char),1,fi);
for
(i=0;i<h;i++)
for
(j=0;j<w;j++)
*(*(ro+i)+j)=((*(*(ri+i)+j)<=t)?ZERO:ONE);
for
(i=0;i<h;i++)
for
(j=0;j<w;j++)
fwrite(*(ro+i)+j,sizeof(unsigned
char),1,fo);
fclose(fo);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
明靓剧坚
2019-08-09 · TA获得超过3789个赞
知道大有可为答主
回答量:3093
采纳率:30%
帮助的人:204万
展开全部
我建议你看一下《c语言编程宝典》这本电子书。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式