学校課題でc言語をもちいて、簡単なビットマップ画像の編集の課題があり、プログラムを組んだのですがうまく動きません。
あるファイルから画像をよみとり、白い部分を透明化して別の画像の左下に貼り付けたいのですが表示結果は下数行にわたって途切れ途切れに線が入っているだけになってしまいます。おそらく下にあるfwrite部分が怪しいと思うのですがどうでしょう?
透過は貼り付ける画像の白いピクセルは元画像の色のままにするようにして実装しています。
#include <stdio.h>
#include <stdlib.h>
typedef struct bmp{
unsigned int r;
unsigned int g;
unsigned int b;
int t;
} bmp;
int main(void) {
FILE fp,fp2;
bmp **pic,**pic2;
char data[50];
int i,j;
int x,y,ofset,pad,x2,y2,pad2;
short int pb,pb2;
printf("file name:");
scanf("%s",data);
printf("%s\n",data);
if((fp=fopen(data,"rb+"))==NULL){
printf("File not found.\n");
return 0;
}
fseek(fp,0x0012,SEEK_SET);
fread(&x,4,1,fp);
fread(&y,4,1,fp);
fseek(fp,0x001c,SEEK_SET);
fread(&pb,2,1,fp);
printf("Horizontal size=%d Vertical size=%d,\n",x,y);
printf("Bit length per pixel=%d\n",pb);
fseek(fp,0x000a,SEEK_SET);
fread(&ofset,4,1,fp);
printf("offset:%d\n",ofset);
if(xpb/8%4!=0){
pad=(4-xpb/8%4)%4;
}
fseek(fp,ofset,SEEK_SET);
pic=(bmp **)malloc(sizeof(bmp *)*y);
for(i=0;i<y;i++){
pic[i]=(bmp *)malloc(sizeof(bmp)*x);
}
for(i=0;i<y;i++){
for(j=0;j<x;j++){
fread(&pic[i][j].b,1,1,fp);
fread(&pic[i][j].g,1,1,fp);
fread(&pic[i][j].r,1,1,fp);
if((pic[i][j].b==255)&&(pic[i][j].g==255)&&(pic[i][j].r==255)){ pic[i][j].t=1; } else{ pic[i][j].t=0; } } fseek(fp,pad,SEEK_CUR);
}
if((fp2=fopen("bg256.bmp","rb+"))==NULL){
printf("File not found.\n");
return 0;
}
fseek(fp2,0x0012,SEEK_SET);
fread(&x2,4,1,fp2);
fread(&y2,4,1,fp2);
fseek(fp2,0x001c,SEEK_SET);
fread(&pb2,2,1,fp2);
printf("Horizontal size=%d Vertical size=%d,\n",x2,y2);
printf("Bit length per pixel=%d\n",pb2);
fseek(fp2,0x000a,SEEK_SET);
if((x2)*(pb2)/8%4!=0){ pad2=(4-(x2)*(pb2)/8%4)%4; }
fseek(fp2,ofset,SEEK_SET);
pic2=(bmp **)malloc(sizeof(bmp *)*y2);
for(i=0;i<y2;i++){
pic2[i]=(bmp *)malloc(sizeof(bmp)*x2);
}
for(i=0;i<y2;i++){
for(j=0;j<x2;j++){
fread(&pic2[i][j].b,1,1,fp2);
fread(&pic2[i][j].g,1,1,fp2);
fread(&pic2[i][j].r,1,1,fp2);
//printf("%d%d%d ",pic2[i][j].r,pic2[i][j].g,pic2[i][j].b);
}
// printf("\n "); fseek(fp2,pad2,SEEK_CUR);
}
fseek(fp2,ofset,SEEK_SET);
for(i=0;i<y;i++){ for(j=0;j<x;j++){ if(pic[i][j].t=0){ fwrite(&pic[i][j].b,1,1,fp2); fwrite(&pic[i][j].g,1,1,fp2); fwrite(&pic[i][j].r,1,1,fp2); } else{ fwrite(&pic2[i][j].b,1,1,fp2); fwrite(&pic2[i][j].g,1,1,fp2); fwrite(&pic2[i][j].r,1,1,fp2); } } fseek(fp2,x2+pad2,SEEK_CUR); }
fclose(fp);
fclose(fp2);
free(pic);
free(pic2);
return 0;
}
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。