Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 495

Раздел: Delphi » Прочее
/ вопрос открыт /

Здравствуйте, уважаемые эксперты!
Как можно сделать так чтобы выбрав папку на форме появлялись все небольшого размера растровые изображения, а так же при нажатии на определенною она отурывалась в отдельном окне?
С уважением, Насыров И.Т.

Насыров И.Т. Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задал: Насыров И.Т. (статус: Посетитель)
Вопрос отправлен: 17 апреля 2007, 21:48
Состояние вопроса: открыт, ответов: 2.

Ответ #1. Отвечает эксперт: Вадим К

алгоритм работы.
с помощью FindFirst/FindNext находим список файлов.
Дальше надо решить, как отображать превью. Например можно в DrawGrid. С помощью bitbtl или Canvas.Draw можно уменьшить картинку.
Ну а отобразить - это вообще просто. Картинку знаем, делаем форму, которая будет иметь Image а двойной клик обрабатывается просто

Ответ отправил: Вадим К (статус: Академик)
Время отправки: 17 апреля 2007, 23:19

Ответ #2. Отвечает эксперт: Матвеев Игорь Владимирович

Здравствуйте, Насыров И.Т.!
Кладете на форму ListView, устанавливаете большие значки. При выборе папки сканируете директорию, отбираете файлы, для которых возможно создать эскиз и заполняете эскизами ImageList. (Создать эскизы можно либо с помощью StretchBlt - быстро но некрасиво, либо с помощью метода в приложении - тоже быстро и качественно). Потом добавляете записи в ListView, устанавливая ImageIndex'ы по-порядку указывая имена файлов в Caption.

При выборе изображения - открывете отдельную форму, на которой лежит Image и загружаете в него изображение (выбранная директория + имя файла).

Приложение:
  1. //*************************************************************
  2. // Method to create Thumbnail of the desctop image. *
  3. //*************************************************************
  4.  
  5. unit ThumbNail;
  6.  
  7. interface
  8.  
  9. uses Graphics;
  10.  
  11. type
  12. PRGB24 = ^TRGB24;
  13. TRGB24 = packed record
  14. B: Byte;
  15. G: Byte;
  16. R: Byte;
  17. end;
  18.  
  19. const
  20. FThumbSize = 150;
  21.  
  22. procedure MakeThumbNail(Source, Dest: TBitmap);
  23.  
  24. implementation
  25.  
  26. procedure MakeThumbNail(Source, Dest: TBitmap);
  27. var
  28. x, y, ix, iy : Integer;
  29. x1, x2, x3 : Integer;
  30.  
  31. xscale, yscale : Single;
  32. iRed, iGrn,
  33. iBlu, iRatio : LongWord;
  34. p, c1, c2, c3,
  35. c4, c5 : TRGB24;
  36. pt, pt1 : PRGB24;
  37. iSrc, iDst, s1 : Integer;
  38. i, j, r, g, b,
  39. tmpY : Integer;
  40.  
  41. RowDest, RowSource,
  42. RowSourceStart,
  43. w, h,
  44. dxmin, dymin,
  45. ny1, ny2, ny3,
  46. dx, dy : Integer;
  47. lutX, lutY : array of Integer;
  48. begin
  49.  
  50. if Source.PixelFormat <> pf24bit then Source.PixelFormat := pf24bit;
  51. if Dest.PixelFormat <> pf24bit then Dest.PixelFormat := pf24bit;
  52. w := Dest.Width;
  53. h := Dest.Height;
  54.  
  55. iDst := (w * 24 + 31) and not 31;
  56. iDst := iDst div 8; //BytesPerScanline
  57. iSrc := (Source.Width * 24 + 31) and not 31;
  58. iSrc := iSrc div 8;
  59.  
  60. xscale := 1 / (w / Source.Width);
  61. yscale := 1 / (h / Source.Height);
  62.  
  63. // X lookup table
  64. SetLength(lutX, w);
  65. x1 := 0;
  66. x2 := Trunc(xscale);
  67. for x := 0 to w - 1 do
  68. begin
  69. lutX[x] := x2 - x1;
  70. x1 := x2;
  71. x2 := Trunc((x + 2) * xscale);
  72. end;
  73.  
  74. // Y lookup table
  75. SetLength(lutY, h);
  76. x1 := 0;
  77. x2 := trunc(yscale);
  78. for x := 0 to h - 1 do
  79. begin
  80. lutY[x] := x2 - x1;
  81. x1 := x2;
  82. x2 := Trunc((x + 2) * yscale);
  83. end;
  84.  
  85. Dec(w);
  86. Dec(h);
  87. RowDest := Integer(Dest.Scanline[0]);
  88. RowSourceStart := Integer(Source.Scanline[0]);
  89. RowSource := RowSourceStart;
  90. for y := 0 to h do
  91. begin
  92. dy := lutY[y];
  93. x1 := 0;
  94. x3 := 0;
  95. for x := 0 to w do
  96. begin
  97. dx:= lutX[x];
  98. iRed:= 0;
  99. iGrn:= 0;
  100. iBlu:= 0;
  101. RowSource := RowSourceStart;
  102. for iy := 1 to dy do
  103. begin
  104. pt := PRGB24(RowSource + x1);
  105. for ix := 1 to dx do
  106. begin
  107. iRed := iRed + pt.R;
  108. iGrn := iGrn + pt.G;
  109. iBlu := iBlu + pt.B;
  110. inc(pt);
  111. end;
  112. RowSource := RowSource - iSrc;
  113. end;
  114. iRatio := 65535 div (dx * dy);
  115. pt1 := PRGB24(RowDest + x3);
  116. pt1.R := (iRed * iRatio) shr 16;
  117. pt1.G := (iGrn * iRatio) shr 16;
  118. pt1.B := (iBlu * iRatio) shr 16;
  119. x1 := x1 + 3 * dx;
  120. inc(x3,3);
  121. end;
  122. RowDest := RowDest - iDst;
  123. RowSourceStart := RowSource;
  124. end;
  125.  
  126. if Dest.Height < 3 then Exit;
  127.  
  128. // Sharpening...
  129. s1 := integer(dest.ScanLine[0]);
  130. iDst := integer(dest.ScanLine[1]) - s1;
  131. ny1 := Integer(s1);
  132. ny2 := ny1 + iDst;
  133. ny3 := ny2 + iDst;
  134. for y := 1 to dest.Height - 2 do
  135. begin
  136. for x := 0 to dest.Width - 3 do
  137. begin
  138. x1 := x * 3;
  139. x2 := x1 + 3;
  140. x3 := x1 + 6;
  141.  
  142. c1 := pRGB24(ny1 + x1)^;
  143. c2 := pRGB24(ny1 + x3)^;
  144. c3 := pRGB24(ny2 + x2)^;
  145. c4 := pRGB24(ny3 + x1)^;
  146. c5 := pRGB24(ny3 + x3)^;
  147.  
  148. r := (c1.R + c2.R + (c3.R * -12) + c4.R + c5.R) div -8;
  149. g := (c1.G + c2.G + (c3.G * -12) + c4.G + c5.G) div -8;
  150. b := (c1.B + c2.B + (c3.B * -12) + c4.B + c5.B) div -8;
  151.  
  152. if r < 0 then r := 0 else if r > 255 then r := 255;
  153. if g < 0 then g := 0 else if g > 255 then g := 255;
  154. if b < 0 then b := 0 else if b > 255 then b := 255;
  155.  
  156. pt1 := pRGB24(ny2 + x2);
  157. pt1.R := r;
  158. pt1.G := g;
  159. pt1.B := b;
  160. end;
  161. Inc(ny1, iDst);
  162. Inc(ny2, iDst);
  163. Inc(ny3, iDst);
  164. end;
  165. end;
  166.  
  167. end.
  168.  


Ответ отправил: Матвеев Игорь Владимирович (статус: Студент)
Время отправки: 17 апреля 2007, 23:22


Мини-форум вопроса

Мини-форум пуст.

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:54
Выполнено за 0.02 сек.