24 비트 512x512 .bmp에서 3 차원 배열로 픽셀 값을 읽는 데 성공했습니다. 다음은 lena512.bmp라는 테스트 이미지에 대한 코드입니다.bmp의 3D 배열 요소를 16 진수에서 2 진수로 변환
...snip ...
FILE *fptr;
int i, j, k;
char *filename = "lena512.bmp";
//char *filename2 = "anotherimage.bmp";
//ofstream myfile;
unsigned char databuff[512][512][3];
BmpFileHeader fheader;
BmpInfoHeader iheader;
printf("sizeof: fheader: %d iheader: %d\n\n", sizeof(fheader),
sizeof(iheader));
if ((sizeof(fheader) != 14) || (sizeof(iheader) != 40)) {
printf("Header structs are not properly packed\n");
return 0;
}
if ((fptr = fopen(filename, "r")) == NULL) {
printf("Coulsn't open file %s for reading.\n", filename);
return 1;
};
if (fread(&fheader, sizeof(fheader), 1, fptr) != 1) {
printf("Couldn't read fheader.\n");
return 0;
}
if (fread(&iheader, sizeof(iheader), 1, fptr) != 1) {
printf("Couldn't read iheader.\n");
return 0;
}
printf(" fheader.type = %04x \n", fheader.type);
printf(" fheader.size = %u \n", fheader.size);
printf(" fheader.reserved1 = %u \n", fheader.reserved1);
printf(" fheader.reserved2 = %u \n", fheader.reserved2);
printf(" fheader.offset = %u \n", fheader.offset);
printf(" iheader.size = %u \n", iheader.size);
printf(" iheader.width = %u \n", iheader.width);
printf(" iheader.height = %u \n", iheader.height);
printf(" iheader.planes = %u \n", iheader.planes);
printf(" iheader.bits = %u \n", iheader.bits);
printf(" iheader.compression = %u \n", iheader.compression);
printf(" iheader.imagesize = %u \n", iheader.imagesize);
printf(" iheader.xresolution = %u \n", iheader.xresolution);
printf(" iheader.yresolution = %u \n", iheader.yresolution);
printf(" iheader.ncolors = %u \n", iheader.ncolors);
printf("iheader.importantcolors = %u \n", iheader.importantcolors);
printf("\n");
if ((iheader.height != 512) || (iheader.width != 512) || (iheader.bits != 24)) {
printf("This only works for 512x512 24-color bitmaps\n");
return 0;
}
if (fheader.offset != 54) {
printf("This only works if the offset is equal to 54\n");
return 0;
}
for (i = 0; i < iheader.height; i++) {
for (j = 0; j < iheader.width; j++) {
if (fread(&databuff[i][j][0], 3, 1, fptr) != 1) {
printf("Couldn't read colors for element [%d][%d]\n", i, j);
return 0;
}
}
}
//myfile.open("lena512bmp_24bit.txt");
for (i = 0; i < 1; i++) { /* This should only give you the first row */
printf("Row %2d:\n", i);
for (j = 0; j < 1; j++) { /* look at the first element on each row */
printf(" ");
for (k = 0; k < 3; k++) {
printf("%02x ", databuff[i][j][k]);
cout << databuff[i][j][k];
}
printf("\n");
}
printf("\n\n");
}
//myfile.close();
fclose(fptr);
return 0;
나는 또한 내가 부탁하려고 해요 질문에 상당히 관련이없는이 FIL에 bmp_headers.h
라는 헤더를 포함한다. 내 for
루프는 첫 번째 행의 첫 번째 3 요소 (이미지 헤더의 첫 번째 54 바이트 이후)를 고려하기 때문에 여기 출력은 37 51 9E
(16 진수로 표시)입니다. 512x512 이미지의 출력은 동일한 이미지의 16 진수 편집기에 표시된 값과 일치합니다. 이 배열의 모든 요소를 2 진수 문자열로 변환하여 표시하고 싶습니다. (예 : 37 51 9E
==>00110111 01010001 10011110
).
내가 올바르게 이해한다면이 배열을 문자열로 변환 한 다음 16 진수로 변환 한 다음 2 진수 문자열로 변환해야합니다. 이 작업을 수행하는 더 쉬운 방법이 있습니까? 나는 지금 당장 약간 혼란 스럽다. 어떤 도움을 주시면 감사하겠습니다.
왜 3 차원 배열? O_o –
@EitanT : 컬러 평면? –
비트 심도에 대해 3 바이트 : RGB –