Delphi绘图功能[3] —— 使用Polyline、Polygon绘制多边形、System.Sin、System.Cos函数画圆 — 绘制五环图标

简介: Delphi绘图功能[3] —— 使用Polyline、Polygon绘制多边形、System.Sin、System.Cos函数画圆 — 绘制五环图标

绘制多边形

在窗体上添加两个Button组件(我这里是button7,button8)

1. procedure Polyline(Points : array of TPoint)
2. {其中Points是一个TPoint型的数组}
procedure TForm1.FormCreate(Sender: TObject);
begin
  Canvas.Pen.Width := 4;
  Canvas.Pen.Color := clRed;
  Canvas.Brush.Color := clYellow;   //设置画刷颜色
end;

Polygon方法

{绘制多边形:它的参数是一个点数组,这里定义了一个常数数组}
procedure TForm1.Button7Click(Sender: TObject);
const
  pts:array[0..3] of TPoint = (
    (x:10; y:40),
    (x:46; y:120),
    (x:82; y:40),
    (x:46; y:10)
  );
begin
  Canvas.Polygon(pts);
end;

通过在画布上绘制一条从最后一个点到第一个点的直线,在画布上绘制一系列连接传入和关闭形状的点的线。


使用 Polygon 在画布上绘制一个封闭的多边形,使用 Pen 的值。在绘制完整的形状之后,使用 Brush 的值填充形状。

Polyline方法

{绘制连续的一组直线; 它的参数也是一个点数组, 我只是把上面的平移了一点}
procedure TForm1.Button8Click(Sender: TObject);
const
  pts:array[0..3] of TPoint = (
    (x:10+82; y:40),
    (x:46+82; y:120),
    (x:82+82; y:40),
    (x:46+82; y:10)
  );
begin
  Canvas.Polyline(pts);
end;

用当前钢笔在画布上绘制一系列直线,将传递给它的每个点连接起来。


使用 Polyline 连接画布上的一组点。如果只指定两个点,Polyline 将绘制一条线。


Point 参数是要连接的点的数组。

绘制五环图标

const    {把五环颜色定义为常量数组}
  Colors:array[0..4] of TColor = (clBlue,clBlack,clRed,clYellow,clGreen);
var
  ci:Integer;   {用作颜色序号}
procedure TForm1.FormCreate(Sender: TObject);
begin
  Button9.Caption := '重绘';
  Self.Color := clWhite;
  Canvas.Pen.Width:=5;
end;
procedure TForm1.FormMouseUp(Sender: TObject; Button: TMouseButton;
  Shift: TShiftState; X, Y: Integer);
const
  r = 30;  {圆半径}
var
  radian: Double; {记录弧度:Sin、Cos函数需要弧度做参数;弧度 = 角度 * Pi/180}
  i,a,b :Integer;
begin
  Canvas.MoveTo(X,Y - r);
  Canvas.Pen.Color := Colors[ci];
  for i := 1 to 360 do
  begin
    radian := i * (Pi/180);          {获取弧度}
    a := X + Round(Sin(radian) * r); {用 Sin 函数获取横坐标}
    b := Y - Round(Cos(radian) * r); {用 Cos 函数获取纵坐标}
    Canvas.LineTo(a, b);             {绘制}
    Application.ProcessMessages;     {不要影响其他操作}
    Sleep(3);                        {等 3 毫秒}
  end;
  Inc(ci);
  if ci = 5 then ci := 0;
end;
procedure TForm1.Button9Click(Sender: TObject);
begin
   ci :=0 ;
   Repaint;//重画
end;
相关文章
|
前端开发 关系型数据库 容器
利用Canvas进行绘制XY坐标系
原文:利用Canvas进行绘制XY坐标系 首先来一发图 绘制XY的坐标主要是利用Canvas setLeft和setBottom功能(Canvas内置坐标的功能) 1.首先WPF中的坐标系都是从左到右,从上到下的 即左上角位置(0,0)点,所以XY的Canvas要以(RenderTransf...
1731 0
|
3月前
使用QT绘制一个多边形
使用QT绘制一个多边形
79 0
|
6月前
|
监控 API 计算机视觉
OpenCV这么简单为啥不学——1.4、基础标识绘制(绘制线line函数、rectangle函数绘制四边形、circle函数绘制圆形、putText函数绘制文字、putText绘制中文文字)
OpenCV这么简单为啥不学——1.4、基础标识绘制(绘制线line函数、rectangle函数绘制四边形、circle函数绘制圆形、putText函数绘制文字、putText绘制中文文字)
66 0
C# GDI+绘图(二)进阶---Pen/Brush以及坐标轴平移和旋转等
上一篇C# GDI+绘图(一)GDI+介绍及基础,我们介绍了,GDI+的基础,这篇我们对其进阶内容进行学习,分别为Pen/Brush以及坐标轴操作
|
搜索推荐 Java C++
OpenglEs之三角形绘制
Opengl ES连载系列
76 0
|
前端开发
Delphi绘图功能[1] —— 入门(绘制直线和矩形)
Delphi绘图功能[1] —— 入门(绘制直线和矩形)
503 0
Delphi绘图功能[1] —— 入门(绘制直线和矩形)
|
缓存 定位技术
解决Leaflet.draw中polyline绘制无法结束的问题
通过本文,可以了解如何自定义Draw.PolyLine对象,以及在扩展时需要注意的一些坑,知道如何调试函数并定位问题,最终完成需求。
345 0
解决Leaflet.draw中polyline绘制无法结束的问题
SwiftUI—用Rectangle绘制矩形
SwiftUI—用Rectangle绘制矩形
683 0
SwiftUI—用Rectangle绘制矩形
|
机器学习/深度学习 索引
【OpenGL】十四、OpenGL 绘制三角形 ( 绘制 GL_TRIANGLE_STRIP 三角形 | GL_TRIANGLE_STRIP 三角形绘制分析 )
【OpenGL】十四、OpenGL 绘制三角形 ( 绘制 GL_TRIANGLE_STRIP 三角形 | GL_TRIANGLE_STRIP 三角形绘制分析 )
281 0
【OpenGL】十四、OpenGL 绘制三角形 ( 绘制 GL_TRIANGLE_STRIP 三角形 | GL_TRIANGLE_STRIP 三角形绘制分析 )