C++ Builder
| Главная | Уроки | Статьи | FAQ | Форум | Downloads | Литература | Ссылки | RXLib | Диски |

 
Печать
Mikhail
Отправлено: 04.06.2003, 17:59


Не зарегистрирован







Кто подскажет как программно распечатать картинку, нарисованную в Timage, или как распечатать графический файл.
Anry
Отправлено: 07.06.2003, 11:47


Дежурный стрелочник

Группа: Участник
Сообщений: 56



TPrinter *Prntr = Printer();
Prntr->BeginDoc();
Prntr->Canvas->Draw(50, 50, Image1);
Prntr->EndDoc();

Отредактировано Anry — 7 Jun 2003, 11:48
pasha
Отправлено: 11.06.2003, 17:40


Дежурный стрелочник

Группа: Участник
Сообщений: 62



Пример взят отсюда.

CODE


Печать TImage.
Компилятор: C++ Builder

Самый простой способ напечатать TImage, это воспользоваться методом print в TForm, которая содержит только битмап. Этот способ работает, однако такая картинка напечатается либо очень маленькой, либо вообще не напечатается. Следующий код позволяет напечатать TImage на всю страницу. Так же Вы можете изменить масштаб и напечатать картинку любого размера.


Замечание: картинка должна содержать Bitmap.


/*-----------------------------------------------------------------------
Эта функция является обработчиком события OnClick для TButton, которая
находится на TForm. На TForm также присутствует TImage с именем image.
------------------------------------------------------------------------*/
void __fastcall Tmain_form::print_image_btnClick(TObject *Sender)
{
   TPrinter *p = Printer();

   // создаём в памяти dc для картинки
   HDC h_dc = image->Picture->Bitmap->Canvas->Handle;
   int bmp_w = image->Picture->Bitmap->Width,
   bmp_h = image->Picture->Bitmap->Height;
   HDC h_mem_dc = ::CreateCompatibleDC (h_dc);
   HBITMAP h_mem_bmp = ::CreateCompatibleBitmap (h_dc, bmp_w, bmp_h);
   HBITMAP h_old_bmp = ::SelectObject (h_mem_dc, h_mem_bmp);

   // фиксируем ошибки видео драйверов
   bool is_pal_dev = false;
   LOGPALETTE *pal;
   HPALETTE h_pal, h_old_pal;

   if (::GetDeviceCaps (image->Canvas->Handle, RASTERCAPS) & RC_PALETTE)
   {
       pal = static_cast(malloc (sizeof (LOGPALETTE) +
                                       (sizeof (PALETTEENTRY) * 256)));
       memset (pal, 0, sizeof (LOGPALETTE) + (sizeof (PALETTEENTRY) * 256));
       pal->palVersion = 0x300;
       pal->palNumEntries = ::GetSystemPaletteEntries(image->Canvas->Handle, 0,
                                                        256, pal->palPalEntry);
       if (pal->palNumEntries != 0)
       {
           h_pal = ::CreatePalette (pal);
           h_old_pal = ::SelectPalette (h_mem_dc, h_pal, false);
           is_pal_dev = true;
       }
       else
       {
           free (pal);
       }
   }

   // копируем картинку на dc в памяти
   ::BitBlt (h_mem_dc, 0, 0, bmp_w, bmp_h, h_dc, 0, 0, SRCCOPY);

   if (is_pal_dev)
   {
       ::SelectPalette (h_mem_dc, h_old_pal, false);
       ::DeleteObject (h_pal);
   }

   // удаляем dc в памяти
   ::SelectObject (h_mem_dc, h_old_bmp);
   ::DeleteDC (h_mem_dc);

   // выделяем память для структуры BITMAPIFO
   HANDLE h_bmp_info = ::GlobalAlloc (GHND,
                           sizeof (BITMAPINFO) + (sizeof (RGBQUAD) * 256));
   BITMAPINFO* bmp_info = static_cast(::GlobalLock (h_bmp_info));
   //Заполняем структуру
   memset (bmp_info, NULL, sizeof (BITMAPINFO) + (sizeof (RGBQUAD) * 255));
   bmp_info->bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
   bmp_info->bmiHeader.biPlanes = 1;
   bmp_info->bmiHeader.biBitCount = 8;
   bmp_info->bmiHeader.biWidth = bmp_w;
   bmp_info->bmiHeader.biHeight = bmp_h;
   bmp_info->bmiHeader.biCompression = BI_RGB;

   // определяем размер памяти для битов
   ::GetDIBits (h_dc, h_mem_bmp, 0, bmp_h, NULL, bmp_info, DIB_RGB_COLORS);

   // Выделяем память для битов
   HANDLE h_bits = GlobalAlloc (GHND, bmp_info->bmiHeader.biSizeImage);
   void *bits = ::GlobalLock (h_bits);

   // получаем биты
   ::GetDIBits (h_dc, h_mem_bmp, 0, bmp_h, bits, bmp_info, DIB_RGB_COLORS);

   // фиксируем ошибки видео драйверов
   if (is_pal_dev)
   {
       for (int i = 0; i palNumEntries; i++)
       {
           bmp_info->bmiColors[i].rgbRed = pal->palPalEntry[i].peRed;
           bmp_info->bmiColors[i].rgbGreen = pal->palPalEntry[i].peGreen;
           bmp_info->bmiColors[i].rgbBlue = pal->palPalEntry[i].peBlue;
       }
       free (pal);
   }

   // начинаем печать
   p->BeginDoc ();

   // масштабируем размер печати
   int scale_x, scale_y;
   if (p->PageWidth PageHeight)
   {
       scale_x = p->PageWidth;
       scale_y = image->Picture->Height * (p->PageWidth / bmp_w);
   }
   else
   {
       scale_x = image->Picture->Width * (p->PageHeight / bmp_h);
       scale_y = p->PageHeight;
   }

   // устанавливаем палитру печати
   is_pal_dev = false;
   if (::GetDeviceCaps (h_dc, RASTERCAPS) & RC_PALETTE)
   {
       pal = static_cast(malloc (sizeof (LOGPALETTE) +
                                         (sizeof (PALETTEENTRY) * 256)));
       memset (pal, 0, sizeof (LOGPALETTE) + (sizeof (PALETTEENTRY) * 256));
       pal->palVersion = 0x300;
       pal->palNumEntries = 256;
       for (int i = 0; pal->palNumEntries; i++)
       {
           pal->palPalEntry[i].peRed = bmp_info->bmiColors[i].rgbRed;
           pal->palPalEntry[i].peGreen = bmp_info->bmiColors[i].rgbGreen;
           pal->palPalEntry[i].peBlue = bmp_info->bmiColors[i].rgbBlue;
       }
       h_pal = CreatePalette(pal);
       free (pal);
       h_old_pal = SelectPalette(p->Canvas->Handle, h_pal, false);
       is_pal_dev = true;
   }

   // посылаем биты на принтер
   StretchDIBits(p->Canvas->Handle, 0, 0, scale_x, scale_y,
 0, 0, bmp_w, bmp_h, bits,bmp_info, DIB_RGB_COLORS, SRCCOPY);

   // конец печати
   p->EndDoc ();

   // освобождаем ресурсы
   ::DeleteObject (h_mem_bmp);
   if (is_pal_dev)
   {
       ::SelectObject (p->Canvas->Handle, h_old_pal);
       ::DeleteObject (h_pal);
   }
   ::GlobalUnlock (bits);
   ::GlobalFree (h_bits);
   ::GlobalUnlock (bmp_info);
   ::GlobalFree (h_bmp_info);
}


Вернуться в Работа с базами данных в C++Builder