2012-06-15 4 views
1

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 진수 문자열로 변환해야합니다. 이 작업을 수행하는 더 쉬운 방법이 있습니까? 나는 지금 당장 약간 혼란 스럽다. 어떤 도움을 주시면 감사하겠습니다.

+0

왜 3 차원 배열? O_o –

+0

@EitanT : 컬러 평면? –

+0

비트 심도에 대해 3 바이트 : RGB –

답변

0

글쎄, 당신은 그래서 여기에 C 태그 ++되는 문제는 C++로 그 방법은 다음과 같습니다

#include <sstream> 

template <typename T> 
std::string ToBinary(T value) 
{ 
    std::stringstream sstream; 
    while (value > 0) 
    { 
     sstream << static_cast<char>((value % 2) + 48); 
     value /= 2; 
    } 
    std::string result = sstream.str(); 
    std::reverse(result.begin(), result.end()); 
    return result; 
} 

for (i = 0; i < 1; i++) { /* This should only give you the first row */ 
    std::cout << "Row " << i << std::endl; 
    for (j = 0; j < 1; j++) { /* look at the first element on each row */ 
     std::cout << " "; 
     for (k = 0; k < 3; k++) { 
      std::cout << ToBinary(databuff[i][j][k]); 
     } 
     std::cout << std::endl; 
    } 
    std::cout << std::endl; 
} 
관련 문제