1
votes

P6

650 652

255

P6 indicates that it is a PPM image. The next two fields are the width and height of the image. The last field gives the maximum pixel value. At the end of the header is a \n and then the binary pixel data. The image is in color so there are three bytes (red, green, blue). The goal of my readPPM function is to return the pixel data in a one-dimensional array of unsigned chars, plus the width and height of the image. The goal of my writePPM function (I haven't done anything for that function yet) is to write the PPM format image to an empty file from the given information returned from my readPPM function. I'm still not sure how to make this program work so I don't store the 650 in width and 652 in height. I'll worry about that once I can actually read and write the text files.

Update: I've successfully stored the header (P6, 650, 652, and 255)) in their right variables (I know because I tried printing their values and they came out right). My output is shown below. I was wondering what those nonsense characters below the maximum were. Are those the binary pixel data? If so, then I just need to write my writePPM function.

Output: PSix: P6

Width: 650

Height: 652

maximum: 255

?ɡ?Ƞ?ɢ?ˤ?ɢ?Ş?ĝ?Ǡ?ʤ?ɣ?ɡ?ɡ?ǟ?Ĝ?ŝ?Ƞ?ȡ?ʣ?ʣ?ȡ?Ŝ?Ŝ?Ȟ?ʠ?̤?ƞ?Ơ?ʤ?ʦ?ʦ?ɧ?Ƥ?ǥ?Ȧ?ɩ?ʪ?ʫ?ʫ?ʪ?ʨ?ɤ?Ǡ?ʢ?̤?ȡ?ȡ?ʥ?ɥ?ʧ?Ģ?ǥ?Ƥ?Ģ? ????Ƥ????ǥ?ʨ?ɧ?ʨ?ɧ?ɧ?ͨ?ϧ?ʟ?ˠ?Х?Φ?ͥ?ˣ?ǟ??Ơ?ʦ?ɥ?Ġ????????????? ?????ħ?Ũ???????©?Ǯ?????????????Ǩ?˭?ū?????????????????????????鴢紣㴢ⳡ޴?ܴᷟ?⺡㻢Ḥ⹥޴?ݳ?۱?ܲ?۱?خ?׭?ٯ?֮?ѫ?Ъ?̨?մ?յ?Ǫ?̲?ٿ?һ????ư?ɳ?ɳ?ɱ?ɱ?˰?ˮ?ɪ?Ȧ?ͫ?ֵ?ұ?Ť?¡?ʩ?Ӳ?Ϯ?ͫ?ϭ?ѯ?ѯ?Ϭ?̭?˰?Ͷ?͵?˳?ʱ?Ǯ?ȯ?ε?ӷ?ϳ?̯?ɬ?̫?ͬ?ͭ?˪?ΰ?ͮ?ί?Ӵ?Ӷ?ϲ?ˮ?ɬ?ʭ?Ѵ?ҵ?г?ϲ?ˮ?ȫ?ɬ?ǩ?ϱ?в?˭?ʬ?˭?̭?ί?ͮ?ͮ?ͮ?ί?ˬ?ȩ?ʫ?ͮ?ղ?ү?Ӳ?ֵ?Ҵ?ѳ?ϲ?ˮ?ȭ?˰?ˮ?ˮ?ͯ?̮?̬?ͯ?ˮ?̱?˲?ȯ?ƭ?Ư?Ů?®?¯?????????????????????????????????????¨?é?é?ū?¨???????????????????????????????ī?ī?ī?Ŭ?Ŭ?ī?ū?ū?é???????ĭ?Ů?®???????????©??????????ȫ?ȫ?Ȫ?ɫ?̭?̭?˭?ʬ?ɫ?ʬ?ʮ?˯?˯?˯?˯?Ȭ?Ȫ?ɫ?̮?ͯ?ϱ?ѳ?ӵ?Ѵ?б?ϰ?ϭ?ά?Ѯ?Ա?Ӱ?Э?Ϭ?ү?ү?Э?ά?ѯ?ױ?ӭ?ϩ?ͧ?ϧ?ѩ?Ԭ?ذ?խ?ѩ?Ϧ?Ϧ?Ч?ҩ?ҩ?ҩ?ת?ث?׭?خ?ׯ?֮?կ?կ?Ԭ?խ?ج?ج?ܬ?߰?㳩䴨峨ݫ?٧?ެ?䲧峨䲧䲧Ⱗ䲩붮?ﺲ국굯???????걦뱥ﶥ???????????????????????????????????????±????ð?????????????????????????????????????????????????æ?ũ?ç?é?Ī?ë???????£?Ʀ?Ʀ?ƥ?Ť?Ť?ƥ?ɧ?ʨ?ͫ?ά?ʩ?Ť?â?ţ?Ǩ?ť?Ƨ?ˬ?ɭ?¦???????????????????????????????ç???????????????????????????????????????????????????????????????????????????????????????????????????????????????????ñ?°?ñ??????????î????????????????????????鲯豮汭尬䯫汭곮췱洫ᱧద嵫緭䴪᯦᯦䲩洫鴬鴬鴬국국贩춬??????뵩괪???????????겱⪭????겳???뵫贩贩趫긭긭긭跩綨깫컭궩糦뵩뷩켨컪鸧綨浧絬鷮鷰峬洫???긭跩긭캱캳깲綯㳩ᱧ㳧嵩㵨᳦᳤ⴥ乩缬轭轭缬ߴ?۰?ߴ?幬

main.cc

int main() {

char fileName[50] = "binary_pixels.txt";
int width = 0;  // width of the image
int height = 0; // heigt of the image
int size = 128; // size of the array

// read the PPM file and store its contents inside an array and return 
// the pointer to that array to pixelArray
unsigned char* pixelArray[size] = readPPM(fileName, &width, &height);

// print the contents of the array
for (int i = 0; i < 128; i++) {
    printf("%s\n", pixelArray[i]);
} // end of for loop

} // end of main

readPPM.cc

unsigned char readPPM(const char* fileName, char* pSix, int* width,         
int* height, int* maximum) { 

// open the file to read just the header reading
FILE* fr = fopen(fileName, "r");

// formatted read of header
fscanf(fr, "%s", pSix);

// check to see if it's a PPM image file
if (strncmp(pSix, "p6" , 10) != 0) {
    printf("They are not the same\n");
} else {
    printf("They are the same\n");
}

// read the rest of header
fscanf(fr, "%d\n %d\n", width, height);

fscanf(fr, "%d\n", maximum);

// check to see if they were stored properly
printf("PSix: %s\n", pSix);
printf("Width: %d\n", *width);
printf("Height: %d\n", *height);
printf("maximum: %d\n", *maximum);

// allocate array for pixels
unsigned char* pixels = new unsigned char[width * height];

// unformatted read of binary pixel data
while (fread(pixels, sizeof(pixel), 128, fr)) {
    printf("%s", pixels);
} // end of for loop

// close file
fclose(fr);

// return the array
return pixels;

} // end of readPPM
2
If your program shall be clean c code you may not use new. In C it is done with malloc() (include stdlib.h).Scheff's Cat
The type of pixelArray in main is wrong. It must be unsigned char* pixelArray (without [size]).Scheff's Cat
I've successfully stored the header (P6, 650, 652, and 255)) in their right variables (I know because I tried printing their values and they came out right). My output is shown below. I was wondering what those nonsense characters below the maximum were. Are those the binary pixel data? If so, then I just need to write my writePPM function.asilvester635
It should be new unsigned char[width * height * 3]. Also, it should be fread(pixels, 1, width * height * 3, fr)sameerkn

2 Answers

1
votes
//struct to hold a pixel.
struct rgb
{
    char r;
    char g;
    char b;
};

//struct to hold the image and its info.
struct image
{
    char p;
    int format;
    int width;
    int height;
    int intensity;
    //struct rgb **rgb;
    unsigned char *pixels;
};

int main(void) 
{
    struct image m;
    FILE *fp = //fopen(...);

    fscanf(fp, "%c%d\n", &m.p, &m.format);

    fscanf(fp, "%d %d\n", &m.width, &m.height);

    fscanf(fp, "%d\n", &m.intensity);

    printf("%c%d\n", m.p, m.format);
    printf("%d %d\n", m.width, m.height);
    printf("%d\n", m.intensity);

    //allocate array to hold the pixels
    m.pixel = (unsigned char*)malloc(m.width*m.heigth*3*sizeof(unsigned char));

    //read pixels into m.pixel
    return 0;
}
0
votes

You are not reading the char into the correct location. pixels is already a pointer to chars so you should pass it as is to fscanf:

fscanf(fr, "%c", pixels)

Of course there are other issues but I this should let you pass this road block.