![]() |
|
#1
|
|||
|
|||
![]() Доброго времени суток Знатоки! Есть следующая проблема: есть у меня функция для преобразования bmp в монохромное (pf8bit), причем интересненьким методом при помощи коэффицента, реализована она на skyLine, так вот хочется переписать её на fastDib, дабы на нем весь проект держится...ничего не получается. Можете хоть подсказать в какую сторону рыть?
Код:
procedure TForm1.BtseuilClick(Sender: TObject); var rw,i,j,k,l:integer; seuil:integer; p:pbytearray; begin seuil:=TrackSeuil.Position; image1.Picture.Bitmap.Assign(bt); rw := (((bt.Width * 32) + 31) and not 31) div 8; p:=image1.Picture.Bitmap.ScanLine[bt.Height-1]; for j:=0 to bt.Height-1 do for i:=0 to bt.Width-1 do begin k:=i*4+j*rw; // passe en niveau de gris l:=(76*p[k+2]+150*p[k+1]+30*p[k+0]) div 256; //suivant le seuil choisi, c'est noir ou blanc if l<seuil then l:=0 else l:=255; // on met а jour le bitmap p[k+2]:=l; p[k+1]:=l; p[k+0]:=l; end; end; FastDib вот этот |
#2
|
|||
|
|||
![]() Переписал, оказывается не все так сложно как показалось
![]() Не уверен что код оптимизирован, однако GetTickCount возвращает "15" для bmp 640*480 24bpp, SkyLine не далеко ушел - "16", что не может не радовать. Кстати, фильтр интересный довольно-таки, что-то вроде монохромного дизеринга. Код под FastDib: Код:
procedure Mono(Bmp:TFastDIB;Split:Integer); var x,y,k: Integer; Lin1: PLine24; pc: PFColor; begin for y:=0 to Bmp.AbsHeight-1 do begin Lin1:=Bmp.Scanlines[y]; for x:=0 to Bmp.Width-1 do begin k:=(76*Lin1[x].r+150*lin1[x].g+30*lin1[x].b) div 256; if k < Split then k:=0 else k:=255; Lin1[x].r:=k; Lin1[x].g:=k; Lin1[x].b:=k; end; end; end; |