Advertisement
Janilabo

Untitled

Oct 25th, 2013
66
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Pascal 6.00 KB | None | 0 0
  1. var
  2.   bmp := BitmapFromString(496, 76, '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');
  3.  
  4. type
  5.   TThreshMethod = (TM_Mean, TM_MinMax);
  6.   T2DByteArray = array of TByteArray;
  7.  
  8. function ColorToGrayL(Color:Integer): Byte;
  9. begin
  10.   Result := Trunc((0.2126 * (Color and $FF)) +
  11.                   (0.7152 * ((Color shr 8) and $FF)) +
  12.                   (0.0722 * ((Color shr 16) and $FF)));
  13. end;
  14.  
  15. function ImThresholdAdaptive(const ImgArr:T2DIntArray; Alpha, Beta: Byte; Method:TThreshMethod; C:Integer): T2DIntegerArray;
  16. var
  17.   W,H,x,y,i:Integer;
  18.   Color,IMin,IMax: Byte;
  19.   Threshold,Counter: Integer;
  20.   Temp: T2DByteArray;
  21.   Tab: Array [0..256] of Byte;
  22. begin
  23.   if Alpha >= Beta then Exit;
  24.   if Alpha > Beta then begin
  25.     X := Beta;
  26.     Beta := Alpha;
  27.     Alpha := X;
  28.   end;
  29.   W := Length(ImgArr[0]);
  30.   H := Length(ImgArr);
  31.   SetLength(Result, H,W);
  32.   SetLength(Temp, H+2,W+2);
  33.   Dec(W); Dec(H);
  34.  
  35.   //Finding the threshold - While at it convert image to grayscale.
  36.   Threshold := 0;
  37.   Case Method of
  38.     //Find the Arithmetic Mean / Average.
  39.     TM_Mean:
  40.     begin
  41.       for y:=0 to H do
  42.       begin
  43.         Counter := 0;
  44.         for x:=0 to W do
  45.         begin
  46.           Color := ColorToGrayL(ImgArr[y][x]);
  47.           Temp[y+1][x+1] := Color;
  48.           Counter := Counter + Color;
  49.         end;
  50.         Threshold := Threshold + (Counter div W);
  51.       end;
  52.       if (C < 0) then Threshold := (Threshold div H) - Abs(C)
  53.       else Threshold := (Threshold div H) + C;
  54.     end;
  55.     //Mean of Min and Max values
  56.     TM_MinMax:
  57.     begin
  58.       IMin := ColorToGrayL(ImgArr[0][0]);
  59.       IMax := IMin;
  60.       for y:=0 to H do
  61.         for x:=0 to W do
  62.         begin
  63.           Color := ColorToGrayL(ImgArr[y][x]);
  64.           Temp[y+1][x+1] := Color;
  65.           if Color < IMin then
  66.             IMin := Color
  67.           else if Color > IMax then
  68.             IMax := Color;
  69.         end;
  70.       if (C < 0) then Threshold := ((IMax+IMin) div 2) - Abs(C)
  71.       else Threshold := ((IMax+IMin) div 2) + C;
  72.     end;
  73.   end;
  74.   Threshold := Max(0, Min(Threshold, 255)); //In range 0..255.
  75.  
  76.   for i:=0 to (Threshold-1) do Tab[i] := Alpha;
  77.   for i:=Threshold to 255 do Tab[i] := Beta;
  78.  
  79.   for x:=1 to W do
  80.     for y:=1 to H do
  81.       Result[y-1][x-1] := Tab[Temp[y][x]];
  82.   SetLength(Temp, 0);
  83. end;
  84.  
  85. procedure DrawMatrixBitmap(bitmap: Integer; matrix: T2DIntegerArray);
  86. var
  87.   x, y, w, h: Integer;
  88. begin
  89.   h := High(matrix);
  90.   for x := 0 to h do
  91.   begin
  92.     w := High(matrix[y]);
  93.     for y := 0 to w do
  94.       FastSetPixel(bitmap, x, y, matrix[x][y]);
  95.   end;
  96. end;
  97.  
  98. var
  99.   matrix, res: T2DIntegerArray;
  100.   w, h: integer;
  101.  
  102. begin
  103.   getBitmapSize(bmp, w, h);
  104.  
  105.   matrix := getMufasaBitmap(bmp).GetAreaColors(0, 0, w-1, h-1);
  106.  
  107.   res := ImThresholdAdaptive(matrix, 0, 255, TM_Mean, 50);
  108.  
  109.   drawMatrixBitmap(bmp, res);
  110.  
  111.   displayDebugImgWindow(496, 76);
  112.   drawBitmapDebugImg(bmp);
  113.  
  114.   freeBitmap(bmp);
  115. end.
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement