Delphi二值图像膨胀算法


本文整理自网络,侵删。

 procedure BitmapDilate(Bitmap: TBitmap);
//传入的Bitmap为二值位图
var
   X, Y: integer;
   O, P, Q, R: pByteArray;
   newbmp: TBitmap;
begin
   newbmp := TBitmap.Create;
   newbmp.Assign(bitmap);
   for Y := 1 to newbmp.Height - 2 do
   begin
      O := bitmap.ScanLine[Y];
      P := newbmp.ScanLine[Y - 1];
      Q := newbmp.ScanLine[Y];
      R := newbmp.ScanLine[Y + 1];
      for X := 1 to newbmp.Width - 2 do
      begin
         if ((O[3 * X] = 255) and (O[3 * X + 1] = 255) and (O[3 * X + 2] = 255)) then
         begin
            if (((Q[3 * (X - 1)] = 0) and (Q[3 * (X - 1) + 1] = 0) and (Q[3 * (X - 1) + 2] = 0))
                or ((Q[3 * (X + 1)] = 0) and (Q[3 * (X + 1) + 1] = 0) and (Q[3 * (X + 1) + 2] = 0))
                or ((P[3 * X] = 0) and (P[3 * X + 1] = 0) and (P[3 * X + 2] = 0))
               or ((R[3 * X] = 0) and (R[3 * X + 1] = 0) and (R[3 * X + 2] = 0))) then
            begin
               O[3 * X] := 0;
               O[3 * X + 1] := 0;
               O[3 * X + 2] := 0;
            end;
         end;
      end;
   end;
end;

过程调用示例:

uses Math;

//打开图片
procedure TForm1.Button1Click(Sender: TObject);
begin
  if OpenPictureDialog1.Execute then
    Image1.Picture.LoadFromFile(OpenPictureDialog1.FileName);
end;

//图像二值化处理
procedure TForm1.Button2Click(Sender: TObject);
var
    p: PByteArray;
    Gray, x, y: Integer;
    Bmp: TBitmap;
begin
    Bmp := TBitmap.Create;
    Bmp.Assign(Image1.Picture.Bitmap);
    //设置为24位真彩色
    Bmp.PixelFormat := pf24Bit;
    randomize;
    for y := 0 to Bmp.Height - 1 do
    begin
        p := Bmp.scanline[y];
        for x := 0 to Bmp.Width - 1 do
        begin
            //一个象素点三个字节
            Gray := Round(p[x * 3 + 2] * 0.3 + p[x * 3 + 1] * 0.59 + p[x * 3] * 0.11);
            if gray > 128 then //全局阀值128
            begin
                p[x * 3] := 255;
                p[x * 3 + 1] := 255;
                p[x * 3 + 2] := 255;
            end else begin
                p[x * 3] := 0;
                p[x * 3 + 1] := 0;
                p[x * 3 + 2] := 0;
            end;
        end;
    end;
    Image2.Picture.Bitmap.Assign(Bmp);
    Bmp.Free;
end;

//图像膨胀处理
procedure TForm1.Button3Click(Sender: TObject);
begin
  BitmapDilate(Image2.Picture.Bitmap);
  Image2.Repaint; //更新显示
end;

相关阅读 >>

Delphi 使用firedac tfdibbackup和tfdibrestore备份和还原firebird

Delphi中messagebox用法

Delphi 删除文件函数支持撤销删除

Delphi comparestr 这个函数可以模糊匹配,且不区分大小写

Delphi 生成随机字符串

Delphi2010获取鼠标指向窗口的位置及鼠标在窗口内的相对位置坐标

Delphi 关闭自己,重新运行

Delphi结构体的方法

Delphi 通过u盘方式加密

Delphi 根据进程pid获取程序所在路径的函数

更多相关阅读请进入《Delphi》频道 >>



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...