c語言提取圖片,c語言圖片讀取

本文目錄一覽:

用c語言如何讀取和保存jpg圖片文件?

#include stdio.h

#include stdlib.h

#include windows.h

int file_size(char* filename)//獲取文件名為filename的文件大小。

{

FILE *fp = fopen(filename, “rb”);//打開文件。

int size;

if(fp == NULL) // 打開文件失敗

return -1;

fseek(fp, 0, SEEK_END);//定位文件指針到文件尾。

size=ftell(fp);//獲取文件指針偏移量,即文件大小。

fclose(fp);//關閉文件。

return size;

}

int main ()

{

int size=0;

size=file_size(“qw”);

printf(“%d\n”,size);

FILE * pFile,*qw;

char *buffer=(char*)malloc(sizeof(char)*size);

qw   =fopen(“qw”,”r”);

pFile = fopen ( “qwe” , “wb” );

printf(“%d==\n”,pFile);

printf(“%d\n”,size);

fread(buffer,1,size,qw);

fwrite (buffer , sizeof(byte), size , pFile );

fclose (pFile);

rename(“qwe”,”Groot.jpg”);

return 0;

}

擴展資料:

c語言讀取TXT文件:

#include stdio.h

#include stdlib.h

#include string.h

#define MAX_LINE 1024

int main()

{

char buf[MAX_LINE];  /*緩衝區*/

FILE *fp;            /*文件指針*/

int len;             /*行字符個數*/

if((fp = fopen(“test.txt”,”r”)) == NULL)

{

perror(“fail to read”);

exit (1) ;

}

while(fgets(buf,MAX_LINE,fp) != NULL)

{

len = strlen(buf);

buf[len-1] = ‘\0’;  /*去掉換行符*/

printf(“%s %d \n”,buf,len – 1);

}

return 0;

}

C語言如何讀取jpg格式的圖片

有這樣一個二進制文件,大小在100M左右,裡面存放了多張JPG圖片,文件格式如下:

無關數據區

JPG圖片數據區

無關數據區

JPG圖片數據區

無關數據區

JPG圖片數據區

……

已知JPG圖片起始標誌為:“FF D8 FF E0 00 10 4A”,結束標誌為:“FF D9”。

現想把這些JPG圖片數據從該文件中讀出來,生成一個個單獨的圖片文件,該如何做呢?

幫你寫了個程序, 測試了只含有一個圖片信息的文件

int len=0;

int filesn=0;

void ReadJpg(CFile *sfp,const char *dstfile,unsigned char a,unsigned char b)

{

CFile nf;

nf.Open(dstfile,CFile::modeCreate|CFile::modeWrite|CFile::typeBinary);

unsigned t=0,t1=0;

nf.Write(a,sizeof(char));

nf.Write(b,sizeof(char));

while(1)

{

sfp-Read(t,sizeof(char));

len++;

nf.Write(t,sizeof(char));

if(t==0xFF)

{

sfp-Read(t1,sizeof(char));

len++;

if(t1==0xD9)

break;

else

nf.Write(t1,sizeof(char));

}

}

nf.Close();

}

調用:

void test()

{

CFile fp;

fp.Open(“86b05621.jpg”,CFile::modeRead|CFile::typeBinary);//文件名改一下

unsigned char a=0,b=0;

len=0;

while(1)

{

fp.Read(a,sizeof(char));

len++;

if(len=fp.GetLength())

break;

if(a==0xFF)

{

fp.Read(b,sizeof(char));

len++;

if(b==0xD8)

{

filesn++;

char filename[256];

sprintf(filename,”Jpg %d.jpg”,filesn);

ReadJpg(fp,filename,a,b);

}

}

}

fp.Close();

}

思路是,先得到FF的值,然後再判斷下一位是否是0xD8, 但這裡要說明一下,如果你的其它數據信息里也含有FF D8值的話就會出錯了, 所以為保險起見,應該再多比較幾位, JPG的頭是固定的,再往下就是EF E0 00 1E, 建議樓主再往下比較四位比較保險(在程序中稍作修改即可)

你是不是在 分析某個 遊戲的或程序的資源文件呀,如果是的話,這個資源文件應該配有一個 索引文件!或在其文件自身。索引可以列表索引,鏈表形示……

如果是你自已生成的文件包,最好加上索引,因為這樣可以提高效率!

c語言,怎樣讀取一個BMP圖片?

#ifndef IMAGE_H

#define IMAGE_H

void image_info(FILE* file);

void image_save(FILE *file);

void image_gray();

void image_binarization();

void image_opposite();

void image_channel(); //抽取RGB通道

void image_bright();//改變圖像亮度

typedef struct BMP

{

//14字節

unsigned short bfType; //文件標識 2字節 必須為BM

unsigned int bfSize; //文件大小 4字節

unsigned short bfReserved1; //保留,每字節以”00″填寫 2字節

unsigned short bfReserved2; //同上 2字節

unsigned int bfOffBits; //記錄圖像數據區的起始位置(圖象數據相對於文件頭字節的偏移量)。 4字節

//40字節

unsigned int biSize; //表示本結構的大小 4字節

int biWidth; //位圖的寬度 4字節

int biHeight; //位圖的高度 4字節

unsigned short biPlanes; //永遠為1 , 2字節

unsigned short biBitCount; //位圖的位數 分為1 4 8 16 24 32 2字節

unsigned int biCompression; //壓縮說明 4字節

unsigned int biSizeImage; //表示位圖數據區域的大小以字節為單位 4字節

int biXPelsPerMeter; //用象素/米表示的水平分辨率 4字節

int biYPelsPerMeter; //用象素/米表示的垂直分辨率 4字節

unsigned int biClrUsed; //位圖使用的顏色索引數 4字節

unsigned int biClrImportant; //對圖象顯示有重要影響的顏色索引的數目 4字節

} BMP;

int line_byte;

unsigned char *imagedata;

extern BMP bmp;

extern int line_byte;

extern unsigned char *imagedata;

#endif

//image_rw.c文件

#includestdio.h

#includestdlib.h

#include”image.h”

void image_info(FILE *file)

{

int times=3; //輸入文件名次數。

char bmp_name[10]; //文件名

printf(“\nplease enter a file name for reading:”);

do

{

if (times3)

{

printf(“\nplease enter a file name for reading again:”);

}

fflush(stdin);

gets(bmp_name);

//printf(“\n%s”,bmp_name);

file=fopen(bmp_name,”rb+”); //打開一個文件進行讀寫操作。

–times;

if (file==NULL)

{

printf(“\nerror opening %s for reading! “,bmp_name);

}

else

{

break;

}

}

while(times!=0);

if (times==0)

{

printf(“\nsorry, shutdown!”);

exit(1);

}

//讀取圖像信息

fseek(file,0L,0); //讀取圖像文件類型

fread(bmp,sizeof(BMP),1,file);

printf(“\n bmp tpye: %u”,bmp.bfType);

printf(“\n bmp size: %u”,bmp.bfSize);

printf(“\n bmp reserved1: %u”,bmp.bfReserved1);

printf(“\n bmp reserved2: %u”,bmp.bfReserved2);

printf(“\n bmp offBits: %u”,bmp.bfOffBits);

printf(“\n bmp bisize: %u”,bmp.biSize);

printf(“\n bmp biWidth: %d”,bmp.biWidth);

printf(“\n bmp biHeight: %d”,bmp.biHeight);

printf(“\n bmp biplans: %u”,bmp.biPlanes);

printf(“\n bmp biBitCount: %u”,bmp.biBitCount);

printf(“\n bmp biCompression: %u”,bmp.biCompression);

printf(“\n bmp biSizeImage: %u”,bmp.biSizeImage);

printf(“\n bmp biXPelsPerMeter: %d”,bmp.biXPelsPerMeter);

printf(“\n bmp biYPelsPerMeter: %d”,bmp.biYPelsPerMeter);

printf(“\n bmp biClrUsed: %u”,bmp.biClrUsed);

printf(“\n bmp biClrImportant: %u\n”,bmp.biClrImportant);

line_byte=(bmp.biWidth*bmp.biBitCount/8+3)/4*4; //獲得圖像數據每行的數據個數

//printf(“dfsa%u”,bmp.line_byte);

//bmp.imagedata=NULL;

imagedata=(unsigned char*)malloc(bmp.biSizeImage);

fseek(file,(long)bmp.bfOffBits,0);

fread(imagedata,sizeof(unsigned char),bmp.biSizeImage,file);

fclose(file);

}

//保存圖像

void image_save(FILE *file)

{

int times=3; //輸入文件名次數。

char bmp_name[10]; //文件名

//int i; //記錄數據區個數

printf(“\nplease enter a file name for writeing:”);

do

{

if (times3)

{

printf(“\nplease enter a file name for writeing again:”);

}

fflush(stdin);

gets(bmp_name);

printf(“\n%s”,bmp_name);

file=fopen(bmp_name,”wb+”); //打開一個文件進行讀寫操作。

–times;

if (file==NULL)

{

printf(“\nerror opening %s for writing”,bmp_name);

}

else

{

break;

}

}

while(times!=0);

if (times==0)

{

printf(“\nsorry, shutdown!”);

exit(1);

}

//寫文件頭

printf(“\n%s”,bmp_name);

fseek(file,0L,0); //圖像文件類型

fwrite((bmp.bfType),sizeof(short),1,file);

printf(“\n bmp tpye: %d”,bmp.bfType);

fseek(file,2L,0); //圖像文件大小

fwrite((bmp.bfSize),sizeof(int),1,file);

printf(“\n bmp size: %d”,bmp.bfSize);

fseek(file,6L,0); //圖像文件保留字1

fwrite((bmp.bfReserved1),sizeof(short),1,file);

printf(“\n bmp reserved1: %d”,bmp.bfReserved1);

fseek(file,8L,0); //圖像文件保留字2

fwrite((bmp.bfReserved2),sizeof(short),1,file);

printf(“\n bmp reserved2: %d”,bmp.bfReserved2);

fseek(file,10L,0);//數據區的偏移量

fwrite((bmp.bfOffBits),sizeof(short),1,file);

printf(“\n bmp offBits: %d”,bmp.bfOffBits);

fseek(file,14L,0);//文件頭結構大小

fwrite((bmp.biSize),sizeof(int),1,file);

printf(“\n bmp bisize: %d”,bmp.biSize);

fseek(file,18L,0);//圖像的寬度

fwrite((bmp.biWidth),sizeof(int),1,file);

printf(“\n bmp biWidth: %d”,bmp.biWidth);

fseek(file,22L,0);//圖像的高度

fwrite((bmp.biHeight),sizeof(int),1,file);

printf(“\n bmp biHeight: %d”,bmp.biHeight);

fseek(file,24L,0);//圖像的面數

fwrite((bmp.biPlanes),sizeof(short),1,file);

printf(“\n bmp biplans: %d”,bmp.biPlanes);

fseek(file,28L,0);//圖像一個像素的字節數

fwrite((bmp.biBitCount),sizeof(short),1,file);

printf(“\n bmp biBitCount: %d”,bmp.biBitCount);

fseek(file,30L,0);//圖像壓縮信息

fwrite((bmp.biCompression),sizeof(short),1,file);

printf(“\n bmp biCompression: %d”,bmp.biCompression);

fseek(file,34L,0);//圖像數據區的大小

fwrite((bmp.biSizeImage),sizeof(int),1,file);

printf(“\n bmp biSizeImage: %d”,bmp.biSizeImage);

fseek(file,38L,0);//水平分辨率

fwrite((bmp.biXPelsPerMeter),sizeof(int),1,file);

printf(“\n bmp biXPelsPerMeter: %d”,bmp.biXPelsPerMeter);

fseek(file,42L,0);//垂直分辨率

fwrite((bmp.biYPelsPerMeter),sizeof(int),1,file);

printf(“\n bmp biYPelsPerMeter: %d”,bmp.biYPelsPerMeter);

fseek(file,46L,0);//顏色索引數

fwrite((bmp.biClrUsed),sizeof(int),1,file);

printf(“\n bmp biClrUsed: %d”,bmp.biClrUsed);

fseek(file,50L,0);//重要顏色索引數

fwrite((bmp.biClrImportant),sizeof(int),1,file);

printf(“\n bmp biClrImportant: %d\n”,bmp.biClrImportant);

fseek(file,(long)(bmp.bfOffBits),0);

fwrite(imagedata,sizeof(unsigned char),bmp.biSizeImage,file);

fclose(file);

}

//pixProcess.c文件

#includestdio.h

#includestdlib.h

#includemath.h

#include”image.h”

//灰度化

void image_gray()

{

int i,j;

unsigned char tmp;

for (i=0;ibmp.biHeight;i++)

{

for (j=0;jline_byte/3;j++)

{

tmp=0.11*(*(imagedata+i*line_byte+j*3+0))+0.59*(*(imagedata+i*line_byte+j*3+1))+0.3*(*(imagedata+i*line_byte+j*3+2));

imagedata[i*line_byte+j*3+0]=tmp;

imagedata[i*line_byte+j*3+1]=tmp;

imagedata[i*line_byte+j*3+2]=tmp;

//printf(“\nnidsfh%d %d”,i,j);

}

}

}

//二值化

void image_binarization()

{

int i,j;

for (i=0;ibmp.biHeight;i++)

{

for (j=0;jline_byte;j++)

{

if ((*(imagedata+i*line_byte+j))128)

{

imagedata[i*line_byte+j]=0;

}

else

{

imagedata[i*line_byte+j]=255;

}

}

}

}

void image_opposite() //反相

{

int i,j;

for (i=0;ibmp.biHeight;i++)

{

for (j=0;jline_byte;j++)

{

imagedata[i*line_byte+j]=abs(255-imagedata[i*line_byte+j]);

}

}

}

void image_channel() //抽取RGB通道

{

int i,j;

char rgb;

printf(“\nplease enter a char(r/g/b): “);

fflush(stdin);

scanf(“%c”,rgb);

if (rgb==’b’)

{

for (i=0;ibmp.biHeight;i++)

{

for (j=0;jline_byte/3;j++)

{

imagedata[i*line_byte+3*j+1]=0;

imagedata[i*line_byte+3*j+2]=0;

}

}

}

else if(rgb==’g’)

{

for (i=0;ibmp.biHeight;i++)

{

for (j=0;jline_byte/3;j++)

{

imagedata[i*line_byte+3*j]=0;

imagedata[i*line_byte+3*j+2]=0;

}

}

}

else

{

for (i=0;ibmp.biHeight;i++)

{

for (j=0;jline_byte/3;j++)

{

imagedata[i*line_byte+3*j]=0;

imagedata[i*line_byte+3*j+1]=0;

}

}

}

}

void image_bright()//改變圖像亮度

{

int level;

int i,j;

printf(“\n please enter the level of brightness[-255 to 255] :”);

fflush(stdin);

scanf(“%d”,level);

for (i=0;ibmp.biHeight;i++)

{

for (j=0;jline_byte;j++)

{

if (level=0)

{

if ((imagedata[i*line_byte+j]+level)255)

imagedata[i*line_byte+j]=255;

else

imagedata[i*line_byte+j]+=level;

}

else

{

if ((imagedata[i*line_byte+j]-abs(level))0)

imagedata[i*line_byte+j]=0;

else

imagedata[i*line_byte+j]+=level;

}

}

}

}

//void image_create() //創建一幅24位BMP圖像文件。

//{

//main.c文件

#includestdio.h

#includestdlib.h

#includestring.h

#includeconio.h

#include”image.h”

BMP bmp;

int main()

{

FILE *file=NULL;

int choose;

char gono;

do

{

image_info(file); //imagedata已經分配了動態內存,但是沒有釋放

printf(“\n 1.image_opposite”);

printf(“\n 2.image_gray”);

printf(“\n 3.image_binarization”);

printf(“\n 4.image_channel”);

printf(“\n 5.image_brightness”);

//printf(“6.image_opposite”);

//printf(“7.image_opposite”);

printf(“\nchoose your options:”);

fflush(stdin);

scanf(“%d”,choose);

switch(choose)

{

case 1:

image_opposite();

image_save(file);

free(imagedata);

break;

case 2:

image_gray();

image_save(file);

free(imagedata);

break;

case 3:

image_binarization();

image_save(file);

free(imagedata);

break;

case 4:

image_channel();

image_save(file);

free(imagedata);

break;

case 5:

image_bright();

image_save(file);

free(imagedata);

break;

default:

printf(“\n wrong choose!”);

}

printf(“\nlet’s go on?(y/n):”);

fflush(stdin);

scanf(“%c”,gono);

if (gono==’n’)

{

printf(“\nbye bye!”);

break;

}

}

while(1);

return 0;

}

怎樣用C語言讀取一張圖片並進行簡單處理

圖片格式有很多種

bmp,

jpg,

gif,

png

等等

每種都有自己的格式。

處理圖片

一般流程

都是先讀取圖片文件,根據格式解析成位圖(bitmap)

然後對位圖進行處理。

所以

重點是解析。

這個是有很多的開源C庫的。

如何用c語言讀取圖片

#include

using namespace std;

#define Twoto1(i,j,w) i*w+j

void createimage(unsigned char *img, int w, int h)

{img = new unsigned char[w*h];}

void delateimage(unsigned char*img)

{delete []img;}

void readimage(unsigned char*img, int w, int h, char *fname)

{

FILE *fp;

fopen_s(fp,fname, “rb”);

if (fp == NULL){ cout “error” endl; return; }

size_t result;

result=fread(img , sizeof(unsigned char), w*h, fp);

if (result != w*h)

{

cout “Reading error” endl;

return;

}

else

cout “Reading Ok!” endl;

fclose(fp);

}

void mobanjuanji(unsigned char image, unsigned char*image1, int w, int h, float moban[5][5])

{

for (int i = 0; i for (int j = 0; j if (iw – 3 || jh – 3)

image1[Twoto1(i,j,w)] = 0;

else

{

float temp = 0;

for (int m = 0; m5; m++)

for (int n = 0; n5; n++)

{

temp += (image[Twoto1(i-2+m,j-2+n,w)] moban[m][n]);

}

if (temp255) image1[Twoto1(i, j, w)] = 255;

else if (temp0) image1[Twoto1(i, j, w)] = 0;

else image1[Twoto1(i, j, w)] = temp;

}

}

void saveimage(unsigned char *img, int w, int h, char *fname)

{

FILE *fp;

fopen_s(fp, fname, “wb”);

if (fp == NULL) { cout “error” endl; return; }

size_t result;

result = fwrite(img, sizeof(unsigned char), w*h, fp);

if (result != w*h)

{

cout “Write error” endl;

return;

}

else

cout “Write Ok!” endl;

fclose(fp);

}

void main()

{

unsigned char *img;

unsigned char *img1;

float moban[5][5] = { {0,0,0,0,0},{0, -1, 0, 1, 0 }, { 0, -2, 0, 2, 0 }, { 0, -1, 0, 1, 0 }, { 0,0,0,0,0 } };

//float moban[5][5] = { 0 };

int w = 512, h = 512;

createimage(img, w, h);

createimage(img1, w, h);

readimage(img, w, h, “E:\ss.raw”);

mobanjuanji(img, img1,w, h, moban);

saveimage(img, w, h, “E:\ss_1.raw”);

saveimage(img1, w, h, “E:\ss_2.raw”);

delateimage(img);

delateimage(img1);

}

擴展資料

C語言實現一個圖片的讀出和寫入

#include stdlib.h

#include windows.h

int file_size(char* filename)//獲取文件名為filename的文件大小。

{

FILE *fp = fopen(filename, “rb”);//打開文件。

int size;

if(fp == NULL) // 打開文件失敗

return -1;

fseek(fp, 0, SEEK_END);//定位文件指針到文件尾。

size=ftell(fp);//獲取文件指針偏移量,即文件大小。

fclose(fp);//關閉文件。

return size;

}

int main ()

{

int size=0;

size=file_size(“qw”);

printf(“%d\n”,size);

FILE * pFile,*qw;

char *buffer=(char*)malloc(sizeof(char)*size);

qw   =fopen(“qw”,”r”);

pFile = fopen ( “qwe” , “wb” );

printf(“%d==\n”,pFile);

printf(“%d\n”,size);

fread(buffer,1,size,qw);

fwrite (buffer , sizeof(byte), size , pFile );

fclose (pFile);

rename(“qwe”,”Groot.jpg”);

return 0;

}

原創文章,作者:WOGA,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/145852.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
WOGA的頭像WOGA
上一篇 2024-10-29 18:58
下一篇 2024-10-29 18:59

相關推薦

  • 用Python繪製酷炫圖片

    在本篇文章中,我們將展示如何使用Python繪製酷炫的圖片。 一、安裝Python繪圖庫 在使用Python繪製圖片之前,我們需要先安裝Python繪圖庫。Python有很多繪圖庫…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • 使用axios獲取返回圖片

    使用axios獲取返回圖片是Web開發中很常見的需求。本文將介紹如何使用axios獲取返回圖片,並從多個方面進行詳細闡述。 一、安裝axios 使用axios獲取返回圖片前,首先需…

    編程 2025-04-29
  • Python 圖片轉表格

    本文將詳細介紹如何使用Python將圖片轉為表格。大家平時在處理一些資料的時候難免會遇到圖片轉表格的需求。比如從PDF文檔中提取表格等場景。當然,這個功能也可以通過手動複製、粘貼,…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python緩存圖片的處理方式

    本文將從多個方面詳細闡述Python緩存圖片的處理方式,包括緩存原理、緩存框架、緩存策略、緩存更新和緩存清除等方面。 一、緩存原理 緩存是一種提高應用程序性能的技術,在網絡應用中流…

    編程 2025-04-29
  • Python如何抓取圖片數據

    Python是一門強大的編程語言,能夠輕鬆地進行各種數據抓取與處理。抓取圖片數據是一個非常常見的需求。在這篇文章中,我們將從多個方面介紹Python如何抓取圖片數據。 一、使用ur…

    編程 2025-04-29

發表回復

登錄後才能評論