mirror of
https://git.sr.ht/~rabbits/macintosh_cookbook
synced 2025-01-11 16:29:58 +00:00
113 lines
2.0 KiB
ObjectPascal
113 lines
2.0 KiB
ObjectPascal
|
program ExampleBezier;
|
||
|
|
||
|
type
|
||
|
mat = array[1..4, 1..4] of Real;
|
||
|
|
||
|
var
|
||
|
Px, Py, Cx, Cy: mat;
|
||
|
Tv, Mb, x, y: mat;
|
||
|
i, j, k, xx, yy: Integer;
|
||
|
window: rect;
|
||
|
t, dt: Real;
|
||
|
P: point;
|
||
|
|
||
|
procedure matmlt (var d, a, b: mat; n, m: integer);
|
||
|
var
|
||
|
i, j, k: Integer;
|
||
|
sum: Real;
|
||
|
temp: mat;
|
||
|
begin
|
||
|
for i := 1 to n do
|
||
|
begin
|
||
|
for j := 1 to m do
|
||
|
begin
|
||
|
sum := 0.0;
|
||
|
for k := 1 to 4 do
|
||
|
sum := sum + a[i, k] * b[k, j];
|
||
|
temp[i, j] := sum;
|
||
|
end;
|
||
|
end;
|
||
|
for i := 1 to n do
|
||
|
for j := 1 to m do
|
||
|
d[i, j] := temp[i, j];
|
||
|
end;
|
||
|
|
||
|
procedure getPoints;
|
||
|
var
|
||
|
i, x, y: Integer;
|
||
|
begin
|
||
|
SetRect(window, 30, 30, 400, 300);
|
||
|
setDrawingRect(window);
|
||
|
ShowDrawing;
|
||
|
penSize(2, 2);
|
||
|
Moveto(40, 20); {Print heading }
|
||
|
textSize(18);
|
||
|
textFont(2);
|
||
|
writeDraw('Bezier Parametric Cubic Curve');
|
||
|
textSize(12);
|
||
|
ForeColor(409); {Set pen to blue.}
|
||
|
for i := 1 to 4 do
|
||
|
begin
|
||
|
SetRect(window, 90, 30, 255, 50);
|
||
|
eraseRect(window);
|
||
|
Moveto(100, 45);
|
||
|
writeDraw('Please click in point', I : 3);
|
||
|
FrameRect(window);
|
||
|
repeat
|
||
|
getMouse(P)
|
||
|
until button;
|
||
|
repeat
|
||
|
until (not button);
|
||
|
Px[i, 1] := P.h;
|
||
|
Py[i, 1] := P.v;
|
||
|
SetRect(window, (P.h - 2), (P.v - 2), (P.h + 4), (P.v + 4));
|
||
|
PaintOval(window);
|
||
|
end;
|
||
|
end;
|
||
|
|
||
|
procedure set_BezMat;
|
||
|
begin
|
||
|
Mb[1, 1] := -1;
|
||
|
Mb[1, 2] := 3;
|
||
|
Mb[1, 3] := -3;
|
||
|
Mb[1, 4] := 1;
|
||
|
Mb[2, 1] := 3;
|
||
|
Mb[2, 2] := -6;
|
||
|
Mb[2, 3] := 3;
|
||
|
Mb[2, 4] := 0;
|
||
|
Mb[3, 1] := -3;
|
||
|
Mb[3, 2] := 3;
|
||
|
Mb[3, 3] := 0;
|
||
|
Mb[3, 4] := 0;
|
||
|
Mb[4, 1] := 1;
|
||
|
Mb[4, 2] := 0;
|
||
|
Mb[4, 3] := 0;
|
||
|
Mb[4, 4] := 0;
|
||
|
end;
|
||
|
|
||
|
begin
|
||
|
|
||
|
set_BezMat;
|
||
|
getPoints;
|
||
|
matmlt(Cx, Mb, Px, 4, 1);
|
||
|
matmlt(Cy, Mb, Py, 4, 1);
|
||
|
t := -0.01;
|
||
|
xx := round(Px[1, 1]);
|
||
|
yy := round(Py[1, 1]);
|
||
|
Moveto(xx, yy);
|
||
|
ForeColor(137); {Set pen to magenta.}
|
||
|
for i := 1 to 101 do
|
||
|
begin
|
||
|
t := t + 0.01;
|
||
|
Tv[1, 4] := 1;
|
||
|
Tv[1, 3] := t * Tv[1, 4];
|
||
|
Tv[1, 2] := t * Tv[1, 3];
|
||
|
Tv[1, 1] := t * Tv[1, 2];
|
||
|
matmlt(x, Tv, Cx, 1, 1);
|
||
|
matmlt(y, Tv, Cy, 1, 1);
|
||
|
xx := round(x[1, 1]);
|
||
|
yy := round(y[1, 1]);
|
||
|
Lineto(xx, yy);
|
||
|
end;
|
||
|
|
||
|
end.
|