Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.07.11;
Скачать: CL | DM;

Вниз

Сжатие картинки jpeg при помещении ее в базу   Найти похожие ветки 

 
pavel_guzhanov ©   (2005-05-30 09:29) [0]

Суть вопроса в следующем. База находится на удаленном сервере, с него изображения грузятся на форму. На форме можно выбрать изображение для помещения его в отчет. Но на форму грузятся все изображения, и это иногда очень замедляет процесс загрузки формы.
В базе (не моей, я просто пишу программу для работы с уже существующей базой) кроме поля "Изображение", в котором хранится полная картинка, имеется еще поле "Эскиз", куда и помещается то же изображение, но в уменьшенном объеме, с более низким качеством картинки. Брать я из этого поля изображение могу, а вот помещать туда новые не могу, т. к. не знаю, как их сжать перед помещением в базу. Подскажите пожалуйста, как это сделать?


 
pavel_guzhanov ©   (2005-05-30 09:29) [1]

заархивировать картинку не пройдет, так как тип поля - image


 
Anatoly Podgoretsky ©   (2005-05-30 09:47) [2]

На сервере нужно сделать расширенную хранимую процедуру или добавить еще одно поле.


 
Val ©   (2005-05-30 10:03) [3]

проблема в том, как сделать картинку с более низким качеством, или как поместить картинку в базу?


 
pavel_guzhanov ©   (2005-05-30 10:08) [4]

Поместить в базу - не проблема, проблема именно в уменьшении объема...


 
Fay ©   (2005-05-30 10:08) [5]

pavel_guzhanov ©   (30.05.05 9:29) [1]
> заархивировать картинку не пройдет, так как тип поля -
> image

Можно поподорбнее ?


 
Val ©   (2005-05-30 10:19) [6]

повторяю: уменьшение объема в данном случае = сохранение в базу с более низким разрешением?


 
dmitry501 ©   (2005-05-30 10:21) [7]

pavel_guzhanov ©   (30.05.05 9:29)
const
FThumbSize = 150;

//Speed up by Renate Schaaf, Armido, Gary Williams...
procedure MakeThumbNail(src, dest: tBitmap);
type
 PRGB24 = ^TRGB24;
 TRGB24 = packed record
   B: Byte;
   G: Byte;
   R: Byte;
 end;
var
 x, y, ix, iy: integer;
 x1, x2, x3: integer;

 xscale, yscale: single;
 iRed, iGrn, iBlu, iRatio: Longword;
 p, c1, c2, c3, c4, c5: tRGB24;
 pt, pt1: pRGB24;
 iSrc, iDst, s1: integer;
 i, j, r, g, b, tmpY: integer;

 RowDest, RowSource, RowSourceStart: integer;
 w, h: integer;
 dxmin, dymin: integer;
 ny1, ny2, ny3: integer;
 dx, dy: integer;
 lutX, lutY: array of integer;

begin
 if src.PixelFormat <> pf24bit then src.PixelFormat := pf24bit;
 if dest.PixelFormat <> pf24bit then dest.PixelFormat := pf24bit;
 w := Dest.Width;
 h := Dest.Height;

 if (src.Width <= FThumbSize) and (src.Height <= FThumbSize) then
 begin
   dest.Assign(src);
   exit;
 end;

 iDst := (w * 24 + 31) and not 31;
 iDst := iDst div 8; //BytesPerScanline
 iSrc := (Src.Width * 24 + 31) and not 31;
 iSrc := iSrc div 8;

 xscale := 1 / (w / src.Width);
 yscale := 1 / (h / src.Height);

 // X lookup table
 SetLength(lutX, w);
 x1 := 0;
 x2 := trunc(xscale);
 for x := 0 to w - 1 do
 begin
   lutX[x] := x2 - x1;
   x1 := x2;
   x2 := trunc((x + 2) * xscale);
 end;

 // Y lookup table
 SetLength(lutY, h);
 x1 := 0;
 x2 := trunc(yscale);
 for x := 0 to h - 1 do
 begin
   lutY[x] := x2 - x1;
   x1 := x2;
   x2 := trunc((x + 2) * yscale);
 end;

 dec(w);
 dec(h);
 RowDest := integer(Dest.Scanline[0]);
 RowSourceStart := integer(Src.Scanline[0]);
 RowSource := RowSourceStart;
 for y := 0 to h do
 begin
   dy := lutY[y];
   x1 := 0;
   x3 := 0;
   for x := 0 to w do
   begin
     dx:= lutX[x];
     iRed:= 0;
     iGrn:= 0;
     iBlu:= 0;
     RowSource := RowSourceStart;
     for iy := 1 to dy do
     begin
       pt := PRGB24(RowSource + x1);
       for ix := 1 to dx do
       begin
         iRed := iRed + pt.R;
         iGrn := iGrn + pt.G;
         iBlu := iBlu + pt.B;
         inc(pt);
       end;
       RowSource := RowSource - iSrc;
     end;
     iRatio := 65535 div (dx * dy);
     pt1 := PRGB24(RowDest + x3);
     pt1.R := (iRed * iRatio) shr 16;
     pt1.G := (iGrn * iRatio) shr 16;
     pt1.B := (iBlu * iRatio) shr 16;
     x1 := x1 + 3 * dx;
     inc(x3,3);
   end;
   RowDest := RowDest - iDst;
   RowSourceStart := RowSource;
 end;

 if dest.Height < 3 then exit;

 // Sharpening...
 s1 := integer(dest.ScanLine[0]);
 iDst := integer(dest.ScanLine[1]) - s1;
 ny1 := Integer(s1);
 ny2 := ny1 + iDst;
 ny3 := ny2 + iDst;
 for y := 1 to dest.Height - 2 do
 begin
   for x := 0 to dest.Width - 3 do
   begin
     x1 := x * 3;
     x2 := x1 + 3;
     x3 := x1 + 6;

     c1 := pRGB24(ny1 + x1)^;
     c2 := pRGB24(ny1 + x3)^;
     c3 := pRGB24(ny2 + x2)^;
     c4 := pRGB24(ny3 + x1)^;
     c5 := pRGB24(ny3 + x3)^;

     r := (c1.R + c2.R + (c3.R * -12) + c4.R + c5.R) div -8;
     g := (c1.G + c2.G + (c3.G * -12) + c4.G + c5.G) div -8;
     b := (c1.B + c2.B + (c3.B * -12) + c4.B + c5.B) div -8;

     if r < 0 then r := 0 else if r > 255 then r := 255;
     if g < 0 then g := 0 else if g > 255 then g := 255;
     if b < 0 then b := 0 else if b > 255 then b := 255;

     pt1 := pRGB24(ny2 + x2);
     pt1.R := r;
     pt1.G := g;
     pt1.B := b;
   end;
   inc(ny1, iDst);
   inc(ny2, iDst);
   inc(ny3, iDst);
 end;
end;


Взято с сайта http://www.swissdelphicenter.ch/en/tipsindex.php


 
pavel_guzhanov ©   (2005-05-30 10:24) [8]

Fay
в MS Enterprise Manager в Design Table - Data Type - image, length - 16


 
pavel_guzhanov ©   (2005-05-30 10:32) [9]

Val [6]
Возможно и такое, хотя я предполагал, что на компьютере, откуда грузится картинка, должно создаваться изображение с меньшим объемом, а потом загружаиться в базу. А Вы предлагаете уменьшать объем в процессе загрузки в базу?


 
Val ©   (2005-05-30 10:37) [10]

Я пока что не предлагаю ничего. Я хочу узнать что для вас создает проблему, поэтому задаю контрвопросы. Мне несколько непонятна ваша задача. Что вы хотите сделать и что не получается?


 
pavel_guzhanov ©   (2005-05-30 10:47) [11]

Val [10]

Я хочу имеющийся файл перед загрузкой в базу уменьшить и загрузить в базу уменьшенный. Проблема состоит именно в уменьшении размера файла, т.к. я просто не знаю, как это сделать....


 
Val ©   (2005-05-30 10:56) [12]

Тогда просто перед сохранением в  "изображение" и "эскиз" указываете соотв. сжатие  с помощью TJPEGImage.CompressionQuality, например.


 
Anatoly Podgoretsky ©   (2005-05-30 11:04) [13]

pavel_guzhanov ©   (30.05.05 10:32) [9]
Возможно и такое, хотя я предполагал, что на компьютере, откуда грузится картинка, должно создаваться изображение с меньшим объемом, а потом загружаиться в базу. А Вы предлагаете уменьшать объем в процессе загрузки в базу?

А в чем различие?
Может ты просто своими, простыми словами объясничщь, что ты хочешь сделать. Примерно так

Имею то то.
Должно получиться то то.
Хочу сделать это таким то методом и там то.


 
pavel_guzhanov ©   (2005-05-30 11:42) [14]

Всем спасибо. Час назад скачал классный фак по Delphi, весит почти 10 мегов, и в нем нашел решение своей проблемы, причем несколько вариантов. Один из них использовал, работает:-))



Страницы: 1 вся ветка

Текущий архив: 2005.07.11;
Скачать: CL | DM;

Наверх




Память: 0.51 MB
Время: 0.03 c
1-1118815191
Roman-620
2005-06-15 09:59
2005.07.11
Как прочитать mp3-tag из mp3-файла?


8-1110488154
Okez
2005-03-10 23:55
2005.07.11
видео проигрыватель


14-1118538574
Defunct
2005-06-12 05:09
2005.07.11
Нонсенс..


1-1118494263
Pasha L
2005-06-11 16:51
2005.07.11
FILETIME


1-1118462122
!Trinix
2005-06-11 07:55
2005.07.11
Free or Destroy