home *** CD-ROM | disk | FTP | other *** search
- (***********************************************************)
- (* *)
- (* TURBO GRAPHIX version 1.06A *)
- (* *)
- (* Bezier polynomial module *)
- (* Module version 1.06A *)
- (* *)
- (* Copyright (C) 1985 by *)
- (* BORLAND International *)
- (* *)
- (***********************************************************)
-
- procedure Bezier(A : PlotArray; MaxContrPoints : integer;
- var B : PlotArray; MaxIntPoints : integer);
- const
- MaxControlPoints = 25;
- type
- CombiArray = array[0..MaxControlPoints] of real;
- var
- N : integer;
- ContrPoint, IntPoint : integer;
- T, SumX, SumY, Prod, DeltaT, Quot : real;
- Combi : CombiArray;
-
- begin
- MaxContrPoints := MaxContrPoints - 1;
- DeltaT := 1.0 / (MaxIntPoints - 1);
- Combi[0] := 1;
- Combi[MaxContrPoints] := 1;
- for N := 0 to MaxContrPoints - 2 do
- Combi[N + 1] := Combi[N] * (MaxContrPoints - N) / (N + 1);
- for IntPoint := 1 to MaxIntPoints do
- begin
- T := (IntPoint - 1) * DeltaT;
- if T <= 0.5 then
- begin
- Prod := 1.0 - T;
- Quot := Prod;
- for N := 1 to MaxContrPoints - 1 do
- Prod := Prod * Quot;
- Quot := T / Quot;
- SumX := A[MaxContrPoints + 1, 1];
- SumY := A[MaxContrPoints + 1, 2];
- for N := MaxContrPoints downto 1 do
- begin
- SumX := Combi[N - 1] * A[N, 1] + Quot * SumX;
- SumY := Combi[N - 1] * A[N, 2] + Quot * SumY;
- end;
- end
- else
- begin
- Prod := T;
- Quot := Prod;
- for N := 1 to MaxContrPoints - 1 do
- Prod := Prod * Quot;
- Quot := (1 - T) / Quot;
- SumX := A[1, 1];
- SumY := A[1, 2];
- for N := 1 to MaxContrPoints do
- begin
- SumX := Combi[N] * A[N + 1, 1] + Quot * SumX;
- SumY := Combi[N] * A[N + 1, 2] + Quot * SumY;
- end;
- end;
- B[IntPoint, 1] := SumX * Prod;
- B[IntPoint, 2] := SumY * Prod;
- end;
- end; { Bezier }