程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> Delphi >> 再學GDI+[50]: 路徑 - GetPathPoints、GetPathTypes、TPathData(2)

再學GDI+[50]: 路徑 - GetPathPoints、GetPathTypes、TPathData(2)

編輯:Delphi

這個例子有點麻煩, 如果使用 TPathData 類會簡單許多, 下面是用 TPathData 實現的代碼, 運行效果相同; 不過這樣獲取的點數組必須是小數數組. 代碼如下:unit Unit1;
interface
uses
 Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
 Dialogs, StdCtrls, Grids;
type
 TForm1 = class(TForm)
  StringGrid1: TStringGrid;
  procedure FormCreate(Sender: TObject);
  procedure FormPaint(Sender: TObject);
  procedure StringGrid1SelectCell(Sender: TObject; ACol, ARow: Integer;
   var CanSelect: Boolean);
 end;
var
 Form1: TForm1;
implementation
{$R *.dfm}
uses GDIPOBJ, GDIPAPI;
procedure TForm1.FormCreate(Sender: TObject);
begin
 StringGrid1.Align := alRight;
 StringGrid1.FixedCols := 0;
 StringGrid1.ColCount := 3;
 StringGrid1.ColWidths[0] := 25;
 StringGrid1.ColWidths[1] := 25;
 StringGrid1.ColWidths[2] := 80;
 StringGrid1.DefaultRowHeight := 20;
 StringGrid1.Cells[0,0] := 'X';
 StringGrid1.Cells[1,0] := 'Y';
 StringGrid1.Cells[2,0] := '點類型';
end;
procedure TForm1.FormPaint(Sender: TObject);
var
 g: TGPGraphics;
 p: TGPPen;
 path: TGPGraphicsPath;
 PathData: TPathData;
 Points: PGPPointF;
 Types: PByte;
 TypeStr: string;
 i: Integer;
begin
 g := TGPGraphics.Create(Canvas.Handle);
 p := TGPPen.Create(aclRed);
 path := TGPGraphicsPath.Create;
 path.StartFigure;
 path.AddRectangle(MakeRect(30,20,90,40));
 path.AddEllipse(MakeRect(30,80,90,180));
 path.CloseFigure;
 g.DrawPath(p, path);
 PathData := TPathData.Create;
 path.GetPathData(PathData);
 Points := PathData.Points;
 Types := PathData.Types;
 StringGrid1.RowCount := PathData.Count + 1;
 for i := 0 to PathData.Count - 1 do
 begin
  case Types^ of
   $00 : TypeStr := '路徑起始點';
   $01 : TypeStr := '直線點';
   $03 : TypeStr := '貝塞爾線點';
   $07 : TypeStr := '遮蓋點';
   $10 : TypeStr := '虛線點';
   $20 : TypeStr := '路徑標記';
   $80 : TypeStr := '子路徑結束點';
  end;
  StringGrid1.Cells[0, i+1] := IntToStr(Trunc(Points.X));
  StringGrid1.Cells[1, i+1] := IntToStr(Trunc(Points.Y));
  StringGrid1.Cells[2, i+1] := TypeStr;
  Inc(Points);
  Inc(Types);
 end;
 PathData.Free;
 path.Free;
 p.Free;
 g.Free;
end;
procedure TForm1.StringGrid1SelectCell(Sender: TObject; ACol, ARow: Integer;
 var CanSelect: Boolean);
var
 x,y: Integer;
begin
 x := StrToIntDef(StringGrid1.Cells[0,ARow], 0);
 y := StrToIntDef(StringGrid1.Cells[1,ARow], 0);
 Repaint;
 Canvas.Brush.Color := clBlue;
 Canvas.FillRect(Bounds(x-3,y-3,6,6));
 Text := Format('%d,%d',[x,y]);
end;
end.

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved