Direct2D (28) : 获取几何图形的面积、线总长度和指定位置的点坐标


uses Direct2D, D2D1;

procedure TForm1.FormPaint(Sender: TObject);
var
  cvs: TDirect2DCanvas;
  iEllipseGeometry: ID2D1EllipseGeometry;
  area,length: Single;
  rPointF1,rPointF2: TD2DPoint2f;
  ptCenter: TPoint;
begin
  ptCenter := Point(ClientWidth div 2, ClientHeight div 2);
  D2DFactory.CreateEllipseGeometry(D2D1Ellipse(ptCenter, ClientWidth/4, ClientHeight/4), iEllipseGeometry);

  {获取面积与周长}
  iEllipseGeometry.ComputeArea(TD2DMatrix3x2F.Identity, 0, area);
  iEllipseGeometry.ComputeLength(TD2DMatrix3x2F.Identity, 0, length);

  {获取图形的起始处和 1/4 处的点}
  iEllipseGeometry.ComputePointAtLength(0, TD2DMatrix3x2F.Identity, 0, @rPointF1, nil);
  iEllipseGeometry.ComputePointAtLength(length/4, TD2DMatrix3x2F.Identity, 0, @rPointF2, nil);

  cvs := TDirect2DCanvas.Create(Canvas, ClientRect);
  cvs.BeginDraw;
  cvs.RenderTarget.Clear(D2D1ColorF(clWhite));

  cvs.Font.Size := 9;
  cvs.TextOut(5, 5, Format('面积: %f; 周长: %f', [area, length]));

  cvs.DrawGeometry(iEllipseGeometry);

  cvs.MoveTo(ptCenter.X, ptCenter.Y);
  cvs.LineTo(Trunc(rPointF1.x), Trunc(rPointF1.y));
  cvs.MoveTo(ptCenter.X, ptCenter.Y);
  cvs.LineTo(Trunc(rPointF2.x), Trunc(rPointF2.y));

  cvs.EndDraw;
  cvs.Free;
end;

procedure TForm1.FormResize(Sender: TObject);
begin
  Repaint;
end;


效果图:

o_201104074.png

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值