Форум программистов, компьютерный форум CyberForum.ru

Я не могу преобразовать PNG (RGBA) в JPEG - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Псевдоалгоритм Хаффмана http://www.cyberforum.ru/cpp-beginners/thread368288.html
есть алгоритм n – количество символов исходного алфавита P – массив вероятностей, упорядоченных по убыванию C – матрица элементарных кодов L – массив длин кодовых слов Huffman (n,P) IF (n=2) C := 0, L := 1 C :=1, L :=1 ELSE q:= P +P
C++ Непонятный синтаксис Вот есть обявление. sp<DataSource> source; sp<DataSource> это что? Спасибо! http://www.cyberforum.ru/cpp-beginners/thread368282.html
База данных для приемной комиссии института. C++
Нужно составить простенькую программу с базой данных для приемной комиссии института. Выручайте... Она не должна быть какой - то мудреной. Это домашнее задание. Но в ней должна быть какая то графическая оболочка. Желательно описать что за что там отвечает. Просто с языком я не знаком. Базу данных я потом сам составлю. Я там должен буду вводить ФИО, телефон, курс, и группу на которую зачислен...
C++ Нужны коментарии ко коду.
Все доброго времени! Такой вопрос, есть код, работает исправно, что делает тоже ясно. Часть я уже прокоментил, но с большей частью траблы.( Прокоментируйте кажду строку что б докладно понимать какая строка что делает и зачем. Очень признателен! std::ifstream ifile("read.txt");//Считывание с файла. std::ofstream ofile("write.txt");//Запись в файл. if(ifile.is_open()){ ...
C++ Как грамотно удалить элементы в векторе? http://www.cyberforum.ru/cpp-beginners/thread368250.html
for (vector<fileResult>::iterator p = listExp.begin(); p != listExp.end();p++) { if (p->select) listExp.erase(p); } делаю так. fileResult - структура. fileResult listExp; p->select - некоторое поле в структуре ,Если оно true. То из вектора надо удалить этот элемент.
C++ не могу найти ошибку в поиске по массиву структур Здравствуйте. Дали задание: Дан массив структур. Каждая структура содержит информацию о книгах в библиотеке (придумать 5 полей структуры). Создать свои пользовательские функции. Первая из них осуществляет поиск информации по введенному запросу. Вторая - выводит результат на экран. Реализовать, используя указатели на массив структур. На этапе написания поиска информации по введёному запросу... подробнее

Показать сообщение отдельно
Solovei95
0 / 0 / 0
Регистрация: 20.06.2011
Сообщений: 14
18.10.2011, 13:58     Я не могу преобразовать PNG (RGBA) в JPEG
Проблема заключается в том, что программа сразу закрывается!
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
#include <stdio.h>
#include <stdlib.h>
extern "C" {
  #include "png.h"
  #include "jpeglib.h"
}
 
typedef struct { int w, h, d, t, ps, ts; unsigned char pl[256][3]; unsigned char tr[256]; unsigned char * p; } image_info;
 
int LoadPNG(char * szImage, image_info * pImgInfo)
{
  FILE * f;
  int res = 0;
  pImgInfo->p = 0;
 
  if ((f = fopen(szImage, "rb")) != 0)
  {
    png_structp     png_ptr;
    png_infop       info_ptr;
    png_bytepp      row_ptr = NULL;
    png_uint_32     width, height, i, rowbytes;
    int             depth, coltype, itype;
    unsigned char   sig[8];
 
    if (fread(sig, 1, 8, f) == 8 && png_sig_cmp(sig, 0, 8) == 0)
    {
      png_ptr = png_create_read_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
 
      if (png_ptr != NULL)
      {
        info_ptr = png_create_info_struct(png_ptr);
 
        if (info_ptr != NULL) 
        {
          if (setjmp(png_jmpbuf(png_ptr)) == 0)
          {
            png_init_io(png_ptr, f);
            png_set_sig_bytes(png_ptr, 8);
            png_read_info(png_ptr, info_ptr);
            png_get_IHDR(png_ptr, info_ptr, &width, &height, &depth, &coltype, &itype, NULL, NULL);
            pImgInfo->w = width;
            pImgInfo->h = height;
            pImgInfo->d = depth;
            pImgInfo->t = coltype;
 
            if (png_get_valid(png_ptr, info_ptr, PNG_INFO_PLTE))
            {
              png_colorp     palette;
 
              png_get_PLTE(png_ptr, info_ptr, &palette, &pImgInfo->ps);
              memcpy(pImgInfo->pl, palette, pImgInfo->ps * 3);
            }
            else
              pImgInfo->ps = 0;
 
            if (png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS))
            {
              png_color_16p  trans_color;
              png_bytep      trans_alpha;
 
              png_get_tRNS(png_ptr, info_ptr, &trans_alpha, &pImgInfo->ts, &trans_color);
 
              if (coltype == PNG_COLOR_TYPE_GRAY || coltype == PNG_COLOR_TYPE_RGB)
                memcpy(pImgInfo->tr, trans_color, pImgInfo->ts);
              else
                memcpy(pImgInfo->tr, trans_alpha, pImgInfo->ts);
            }
            else
              pImgInfo->ts = 0;
 
            rowbytes = png_get_rowbytes(png_ptr, info_ptr);
 
            if ((pImgInfo->p = (unsigned char *)malloc(rowbytes*height)) != NULL)
            {
              if ((row_ptr = (png_bytepp)malloc(height * sizeof(png_bytep))) != NULL)
              {
                for (i=0; i<height; i++)
                  row_ptr[i] = pImgInfo->p + i*rowbytes;
 
                png_read_image(png_ptr, row_ptr);
                free(row_ptr);
                png_read_end(png_ptr, NULL);
              }
              else
              {
                res = 7;
                free(pImgInfo->p);
              }
            }
            else
              res = 6;
          }
          else
            res = 5;
 
          png_destroy_read_struct(&png_ptr, &info_ptr, NULL);
        }
        else
        {
          png_destroy_read_struct(&png_ptr, NULL, NULL);
          res = 4;
        }
      }
      else
        res = 3;
    }
    else
      res = 2;
 
    fclose(f);
  }
  else
    res = 1;
 
  return res;
}
 
void SaveJPG(char * szImage, image_info * pImgInfo){
  int i,x,y,a;
  unsigned char * buffer = NULL;
  buffer = (unsigned char *)malloc(pImgInfo->w * pImgInfo->h * 3);
 
  for(x=0;x<pImgInfo->w;x++)
  for(y=0;y<pImgInfo->h;y++)
  {
    a = (x * pImgInfo->h + y)*3;
    buffer[a+0] = pImgInfo->p[a+0];
    buffer[a+1] = pImgInfo->p[a+1];
    buffer[a+2] = pImgInfo->p[a+2];
  }
 
  FILE * f1;
  f1 = fopen(szImage,"wb");
 
  struct jpeg_compress_struct cinfo;
  struct jpeg_error_mgr jerr;
  cinfo.err = jpeg_std_error(&jerr);
  cinfo.image_width = pImgInfo->w;
  cinfo.image_height = pImgInfo->h;
  cinfo.input_components = 3;
  cinfo.in_color_space = JCS_RGB;
  jpeg_create_compress(&cinfo);
  jpeg_stdio_dest(&cinfo, f1);
  jpeg_set_defaults(&cinfo);
  cinfo.comp_info[0].h_samp_factor = 2;
  cinfo.comp_info[0].v_samp_factor = 2;
  cinfo.comp_info[1].h_samp_factor = 1;
  cinfo.comp_info[1].v_samp_factor = 1;
  cinfo.comp_info[2].h_samp_factor = 1;
  cinfo.comp_info[2].v_samp_factor = 1;
  jpeg_set_quality(&cinfo,100,true);
  jpeg_start_compress(&cinfo, TRUE);
 
  JSAMPROW row_pointer[1];
  int row_stride;
  row_stride = pImgInfo->w * 3;
  while (cinfo.next_scanline < cinfo.image_height) {
    row_pointer[0] = & buffer[cinfo.next_scanline * row_stride];
    jpeg_write_scanlines(&cinfo, row_pointer, 1);
  }
  jpeg_finish_compress(&cinfo);
  jpeg_destroy_compress(&cinfo);
  fclose(f1);
  free(buffer);
}
 
void main (int argc, char ** argv) {
  char        * szIn;
  char        * szOut;
  int           res;
  image_info    img1;
 
  szIn  = argv[1];
  szOut = argv[2];
 
  LoadPNG(szIn,&img1);
  SaveJPG(szOut,&img1);
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 02:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru