Fixed ppm format, now creates image identical to original image

This commit is contained in:
Phuntsok Drak-pa 2018-11-27 13:36:24 +01:00
parent a88c108d41
commit 7d99a626e1
No known key found for this signature in database
GPG Key ID: 9CB34B6827C66D22
2 changed files with 1 additions and 14 deletions

View File

@ -212,7 +212,7 @@ void imageSavePPM(const char *t_filename, Image *t_img, uint8_t *t_data) {
/* write the header file */ /* write the header file */
fprintf(fp, "P6\n"); /* image format */ fprintf(fp, "P6\n"); /* image format */
fprintf(fp, "# Created by %s\n", CREATOR); /* comments */ fprintf(fp, "# Created by %s\n", CREATOR); /* comments */
fprintf(fp, "%lu %lu\n", t_img->sizeY, t_img->sizeY); /* image size */ fprintf(fp, "%lu %lu\n", t_img->sizeX, t_img->sizeY); /* image size */
fprintf(fp, "%d\n", RGB_COMPONENT_COLOR); /* rgb component depth */ fprintf(fp, "%d\n", RGB_COMPONENT_COLOR); /* rgb component depth */
fwrite(t_data, (size_t)1, (size_t)(3 * t_img->sizeX * t_img->sizeY), fp); fwrite(t_data, (size_t)1, (size_t)(3 * t_img->sizeX * t_img->sizeY), fp);
free(t_data); free(t_data);

View File

@ -72,33 +72,23 @@ uint8_t *zones_to_data(darray *t_zones, Image *t_img) {
Zone *current_zone; Zone *current_zone;
Segment *current_segment; Segment *current_segment;
data = (uint8_t *)malloc(sizeof(uint8_t) * t_img->sizeX * t_img->sizeY * 3); data = (uint8_t *)malloc(sizeof(uint8_t) * t_img->sizeX * t_img->sizeY * 3);
printf("data = (uint8_t *)malloc(%zu * %zu * %zu * 3); /* (%zu) */\n",
sizeof(uint8_t), t_img->sizeX, t_img->sizeY,
sizeof(uint8_t) * t_img->sizeX * t_img->sizeY * 3);
nb_zones = darraySize(t_zones); nb_zones = darraySize(t_zones);
for (zoneID = 0; zoneID < nb_zones; ++zoneID) { for (zoneID = 0; zoneID < nb_zones; ++zoneID) {
printf("Accessing t_zone[%lu]...\n", zoneID);
current_zone = darrayGet(t_zones, zoneID); current_zone = darrayGet(t_zones, zoneID);
red = current_zone->red; red = current_zone->red;
green = current_zone->green; green = current_zone->green;
blue = current_zone->blue; blue = current_zone->blue;
nb_segments = darraySize(current_zone->segments); nb_segments = darraySize(current_zone->segments);
for (segmentID = 0; segmentID < nb_segments; ++segmentID) { for (segmentID = 0; segmentID < nb_segments; ++segmentID) {
printf("\tAccessing segments[%lu]...\n", segmentID);
current_segment = darrayGet(current_zone->segments, segmentID); current_segment = darrayGet(current_zone->segments, segmentID);
left_limit = current_segment->left_limit; left_limit = current_segment->left_limit;
right_limit = current_segment->right_limit; right_limit = current_segment->right_limit;
for (k = left_limit; k < right_limit; ++k) { for (k = left_limit; k < right_limit; ++k) {
printf("\t\tAccessing data[%lu], data[%lu] and data[%lu]... ", k * 3,
k * 3 + 1, k * 3 + 2);
data[k * 3] = red; data[k * 3] = red;
data[k * 3 + 1] = green; data[k * 3 + 1] = green;
data[k * 3 + 2] = blue; data[k * 3 + 2] = blue;
puts("Done.");
} }
puts("\tDone.");
} }
puts("Done.");
} }
return data; return data;
} }
@ -123,11 +113,8 @@ void uncompress(const char *t_input_file, const char *t_output_file) {
input_file = get_file(t_input_file, "rb"); input_file = get_file(t_input_file, "rb");
read_compressed_file_meta(input_file, img); read_compressed_file_meta(input_file, img);
read_compressed_zones(input_file, zones); read_compressed_zones(input_file, zones);
puts("===== Read compressed data, now converting zones to ppm data =====");
data = zones_to_data(zones, img); data = zones_to_data(zones, img);
puts("===== Data converted, now saving the PPM file =====");
imageSavePPM(t_output_file, img, data); imageSavePPM(t_output_file, img, data);
puts("===== Saved output image, freeing up memory =====");
fclose(input_file); fclose(input_file);
/* free memory */ /* free memory */
for(i = 0; i < darraySize(zones); ++i) { for(i = 0; i < darraySize(zones); ++i) {