偶然从
http://blog.csdn.net/hero82748274/archive/2010/02/10/5304386.aspx 看到了秀曲线图, 就用 GDI 模仿了一下; 如果用 GDI+ 绘制, 图形会细腻很多.
procedure TForm1.FormPaint(Sender: TObject);
var
i,j,num,X,Y: Integer;
begin
num := 60;
X := 300;
Y := 300;
ClientWidth := 2 * X;
ClientHeight := 2 * Y;
Canvas.Pen.Width := 1;
Canvas.Pen.Color := clWhite;
Canvas.Brush.Color := clNavy;
Canvas.FillRect(ClientRect);
for i := 0 to num do for j := 0 to 1 do
begin
Canvas.MoveTo(X, i*10);
if i < 30 then
if j = 0 then Canvas.LineTo(X-i*10, Y) else Canvas.LineTo(X+i*10, Y)
else
if j = 0 then Canvas.LineTo(X-(num-1-i)*10, Y) else Canvas.LineTo(X+(num-1-i)*10, Y);
end;
end;
procedure TForm1.FormPaint(Sender: TObject);
var
i,j,num,n,X,Y: Integer;
angle: Single;
pts: array of array of TPoint;
begin
num := 20;
n := 6; { 改为 n := 11 就是成了下一个图形 }
angle := -2 * PI / n;
X := 210;
Y := 210;
ClientWidth := 2*X;
ClientHeight := 2*Y;
Canvas.Pen.Width := 1;
Canvas.Pen.Color := clWhite;
Canvas.Brush.Color := clNavy;
Canvas.FillRect(ClientRect);
SetLength(pts, n+1, num);
for i := 0 to n do
begin
for j := 0 to num-1 do
begin
pts[i,j] := Point(Trunc(j*10*Cos(angle*i)+X), Trunc(j*10*Sin(angle*i)+Y));
Canvas.MoveTo(pts[i,j].X, pts[i,j].Y);
if i = 0 then
Canvas.LineTo((num-j)*10+X, Y)
else
Canvas.LineTo(pts[i-1, num-1-j].X, pts[i-1, num-1-j].Y);
end;
end;
end;