WinAPI: PolyBezier - 绘制贝塞尔线

本文介绍了一个使用PolyBezier函数绘制贝塞尔曲线的例子,并展示了如何通过指定点数组来创建平滑的曲线。通过两个实例演示了如何在Delphi中利用PolyBezier函数绘制不同形态的贝塞尔曲线。
//声明:
PolyBezier(
  DC: HDC;      {设备环境句柄}
  const Points; {点数组}
  Count: DWORD  {数组元素个数}
): BOOL;

 
 
 
 
 

 

 

  

//一条贝塞尔线最少要有 4 个点
procedure TForm1.FormPaint(Sender: TObject);
var
  ps: array[0..3] of TPoint;
begin
  ps[0].X := 10;
  ps[0].Y := 50;
  ps[1].X := 40;
  ps[1].Y := 90;
  ps[2].X := 80;
  ps[2].Y := 10;
  ps[3].X := 110;
  ps[3].Y := 50;
 
  PolyBezier(Canvas.Handle, ps, 4);

  Ellipse(Canvas.Handle, ps[0].X, ps[0].Y, ps[0].X+4, ps[0].Y+4);
  Ellipse(Canvas.Handle, ps[1].X, ps[1].Y, ps[1].X+4, ps[1].Y+4);
  Ellipse(Canvas.Handle, ps[2].X, ps[2].Y, ps[2].X+4, ps[2].Y+4);
  Ellipse(Canvas.Handle, ps[3].X, ps[3].Y, ps[3].X+4, ps[3].Y+4);
end;

 
 
 
 
 

 

 

  
 
//效果图:
26153113_LRpp.png
//连续的贝塞尔线会把前一个终止点当作起始点
procedure TForm1.FormPaint(Sender: TObject);
var
  ps: array[0..6] of TPoint;
begin
  ps[0].X := 10;
  ps[0].Y := 50;
  ps[1].X := 40;
  ps[1].Y := 90;
  ps[2].X := 80;
  ps[2].Y := 10;
  ps[3].X := 110;
  ps[3].Y := 50;
  
  ps[4].X := 140;
  ps[4].Y := 10;
  ps[5].X := 180;
  ps[5].Y := 90;
  ps[6].X := 210;
  ps[6].Y := 50;
  
  PolyBezier(Canvas.Handle, ps, 7);
end; 
//效果图:
26153113_gw1H.png

转载于:https://my.oschina.net/hermer/blog/319369

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值