Как сделать черно-белое изображение файла ppm в C? - PullRequest
2 голосов
/ 28 апреля 2019

эй, мне нужна небольшая помощь с моим кодом, я читаю ppm-файл, меняю цвет на черно-белый и хочу сохранить его в новом файле. Я мог бы прочитать заголовок моего файла и записать его в новый файл, но я борюсь с изменением цветов. Я знаю, что могу получить значение серого по формуле: 0,299 * красный компонент + 0,587 * зеленый компонент + 0,114 * синий компонент. Кто-нибудь знает, как я могу написать это как код?

int main(int argc, char **argv)
{   

    FILE *oldFile, *newFile;
    int width, height, max_colour;
    oldFile = fopen("oldpic.ppm","rb"); 
    newFile = fopen("newpic.ppm","wb");

    fscanf (oldFile, "P6\n %d %d %d", &width, &height, &max_colour);

    unsigned char *data = malloc(width*height);
    fread(data,1,width*height,oldFile);


   fprintf(newFile, "P6\n%d %d\n%d\n", width, height, max_colour);

  for (int j = 0; j < width; ++j)
  {
    for (int i = 0; i < height; ++i)
    {

       unsigned char color[3];
      color[0] = 0.299 * ? + 0.587 * ? + 0.114 * ?; /* red */
      color[1] = 0.299 * ? + 0.587 * ? + 0.114 * ?;  /* green */
      color[2] = 0.299 * ? + 0.587 * ? + 0.114 * ?;  /* blue */
      (void) fwrite(color, 1, 3, newFile);
    }
  }
  (void) fclose(newFile);
   return 0;
} 

1 Ответ

2 голосов
/ 28 апреля 2019

Возможно, вам нужна масштабированная двоичная арифметика.

Кроме того, даже несмотря на то, что вы можете считывать входные данные в большой массив, вам может быть проще читать их и обрабатывать каждый пиксель за раз.

Вот ваш код, переработанный для этого:

int
main(int argc, char **argv)
{

    FILE *oldFile;
    FILE *newFile;
    int width;
    int height;
    int max_colour;

    oldFile = fopen("oldpic.ppm", "rb");
    newFile = fopen("newpic.ppm", "wb");

    fscanf(oldFile, "P6\n %d %d %d", &width, &height, &max_colour);

#if 0
    unsigned char *data = malloc(width * height);
    fread(data, 1, width * height, oldFile);
#endif

    fprintf(newFile, "P6\n%d %d\n%d\n", width, height, max_colour);

    for (int j = 0; j < width; ++j) {
        for (int i = 0; i < height; ++i) {
            unsigned char color[3];
            unsigned int grey;

            fread(color, 1, 3, oldFile);

            grey = 0;
            grey += 299u * color[0];  // red
            grey += 586u * color[1];  // green
            grey += 114u * color[2];  // blue
            grey /= 1000;

            color[0] = grey;
            color[1] = grey;
            color[2] = grey;

            fwrite(color, 1, 3, newFile);
        }
    }

    fclose(oldFile);
    fclose(newFile);

    return 0;
}
...