polar mode for var preview;
weight cloned when adding linked xform "before"
This commit is contained in:
parent
be4e64d14e
commit
8a7d1c1dc3
@ -379,17 +379,17 @@ type
|
|||||||
PreviewDensity: double;
|
PreviewDensity: double;
|
||||||
|
|
||||||
viewDragMode, viewDragged: boolean;
|
viewDragMode, viewDragged: boolean;
|
||||||
editMode, oldMode, widgetMode: (modeNone, modeMove, modeRotate, modeScale, modePick);
|
editMode, oldMode, bracketMode: (modeNone, modeMove, modeRotate, modeScale, modePick);
|
||||||
modeHack: boolean; // for mouseOverEdge...
|
modeHack: boolean; // for mouseOverEdge...
|
||||||
modeKey: word;
|
modeKey: word;
|
||||||
key_handled: boolean;
|
key_handled: boolean;
|
||||||
updating: boolean;
|
updating: boolean;
|
||||||
|
|
||||||
MousePos: TPoint; // in screen coordinates
|
MousePos: TPoint; // in screen coordinates
|
||||||
mouseOverTriangle, mouseOverEdge, mouseOverCorner, mouseOverWidget: integer;
|
mouseOverTriangle, mouseOverEdge, mouseOverCorner, mouseOverBracket: integer;
|
||||||
mouseOverPos: TSPoint;
|
mouseOverPos: TSPoint;
|
||||||
|
|
||||||
Widgets: array[0..3] of array [0..2] of TSPoint;
|
Brackets: array[0..3] of array [0..2] of TSPoint;
|
||||||
xx, xy, yx, yy: double;
|
xx, xy, yx, yy: double;
|
||||||
|
|
||||||
varDragMode: boolean;
|
varDragMode: boolean;
|
||||||
@ -439,7 +439,7 @@ type
|
|||||||
|
|
||||||
procedure UpdateFlameX;
|
procedure UpdateFlameX;
|
||||||
procedure UpdateFlame(DrawMain: boolean);
|
procedure UpdateFlame(DrawMain: boolean);
|
||||||
procedure UpdateWidgets;
|
procedure UpdateBrackets;
|
||||||
procedure UpdateXformsList;
|
procedure UpdateXformsList;
|
||||||
|
|
||||||
procedure DeleteTriangle(t: integer);
|
procedure DeleteTriangle(t: integer);
|
||||||
@ -1097,7 +1097,7 @@ begin
|
|||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TEditForm.UpdateWidgets;
|
procedure TEditForm.UpdateBrackets;
|
||||||
function Point(x, y: double): TSPoint;
|
function Point(x, y: double): TSPoint;
|
||||||
begin
|
begin
|
||||||
Result.x := x;
|
Result.x := x;
|
||||||
@ -1110,21 +1110,21 @@ begin
|
|||||||
xy := y[0] - y[1];
|
xy := y[0] - y[1];
|
||||||
yx := x[2] - x[1];
|
yx := x[2] - x[1];
|
||||||
yy := y[2] - y[1];
|
yy := y[2] - y[1];
|
||||||
Widgets[0][0] := Point(x[1] + 0.8*xx + yx, y[1] + 0.8*xy + yy);
|
Brackets[0][0] := Point(x[1] + 0.8*xx + yx, y[1] + 0.8*xy + yy);
|
||||||
Widgets[0][1] := Point(x[1] + xx + yx, y[1] + xy + yy);
|
Brackets[0][1] := Point(x[1] + xx + yx, y[1] + xy + yy);
|
||||||
Widgets[0][2] := Point(x[1] + xx + 0.8*yx, y[1] + xy + 0.8*yy);
|
Brackets[0][2] := Point(x[1] + xx + 0.8*yx, y[1] + xy + 0.8*yy);
|
||||||
|
|
||||||
Widgets[1][0] := Point(x[1] - 0.8*xx + yx, y[1] - 0.8*xy + yy);
|
Brackets[1][0] := Point(x[1] - 0.8*xx + yx, y[1] - 0.8*xy + yy);
|
||||||
Widgets[1][1] := Point(x[1] - xx + yx, y[1] - xy + yy);
|
Brackets[1][1] := Point(x[1] - xx + yx, y[1] - xy + yy);
|
||||||
Widgets[1][2] := Point(x[1] - xx + 0.8*yx, y[1] - xy + 0.8*yy);
|
Brackets[1][2] := Point(x[1] - xx + 0.8*yx, y[1] - xy + 0.8*yy);
|
||||||
|
|
||||||
Widgets[2][0] := Point(x[1] - 0.8*xx - yx, y[1] - 0.8*xy - yy);
|
Brackets[2][0] := Point(x[1] - 0.8*xx - yx, y[1] - 0.8*xy - yy);
|
||||||
Widgets[2][1] := Point(x[1] - xx - yx, y[1] - xy - yy);
|
Brackets[2][1] := Point(x[1] - xx - yx, y[1] - xy - yy);
|
||||||
Widgets[2][2] := Point(x[1] - xx - 0.8*yx, y[1] - xy - 0.8*yy);
|
Brackets[2][2] := Point(x[1] - xx - 0.8*yx, y[1] - xy - 0.8*yy);
|
||||||
|
|
||||||
Widgets[3][0] := Point(x[1] + 0.8*xx - yx, y[1] + 0.8*xy - yy);
|
Brackets[3][0] := Point(x[1] + 0.8*xx - yx, y[1] + 0.8*xy - yy);
|
||||||
Widgets[3][1] := Point(x[1] + xx - yx, y[1] + xy - yy);
|
Brackets[3][1] := Point(x[1] + xx - yx, y[1] + xy - yy);
|
||||||
Widgets[3][2] := Point(x[1] + xx - 0.8*yx, y[1] + xy - 0.8*yy);
|
Brackets[3][2] := Point(x[1] + xx - 0.8*yx, y[1] + xy - 0.8*yy);
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
@ -1302,7 +1302,7 @@ var
|
|||||||
a, b, c: TPoint;
|
a, b, c: TPoint;
|
||||||
e, f: TPoint;
|
e, f: TPoint;
|
||||||
|
|
||||||
procedure DrawWidgets;
|
procedure DrawBrackets;
|
||||||
var
|
var
|
||||||
i: integer;
|
i: integer;
|
||||||
begin
|
begin
|
||||||
@ -1311,9 +1311,9 @@ var
|
|||||||
begin
|
begin
|
||||||
for i := 0 to 3 do
|
for i := 0 to 3 do
|
||||||
begin
|
begin
|
||||||
a:=toscreen(Widgets[i][0].x, Widgets[i][0].y);
|
a:=toscreen(Brackets[i][0].x, Brackets[i][0].y);
|
||||||
b:=toscreen(Widgets[i][1].x, Widgets[i][1].y);
|
b:=toscreen(Brackets[i][1].x, Brackets[i][1].y);
|
||||||
c:=toscreen(Widgets[i][2].x, Widgets[i][2].y);
|
c:=toscreen(Brackets[i][2].x, Brackets[i][2].y);
|
||||||
moveto(a.x, a.y);
|
moveto(a.x, a.y);
|
||||||
lineto(b.x, b.y);
|
lineto(b.x, b.y);
|
||||||
lineto(c.x, c.y);
|
lineto(c.x, c.y);
|
||||||
@ -1324,9 +1324,9 @@ var
|
|||||||
var
|
var
|
||||||
i, n, tc, tn: integer;
|
i, n, tc, tn: integer;
|
||||||
d, d1: double;
|
d, d1: double;
|
||||||
tx, ty: double;
|
|
||||||
|
|
||||||
ax, ay: integer;
|
ax, ay: integer;
|
||||||
|
tx, ty, tr, ta: double;
|
||||||
|
|
||||||
gridX1, gridX2, gridY1, gridY2, gi, gstep: double;
|
gridX1, gridX2, gridY1, gridY2, gi, gstep: double;
|
||||||
gp: TRoundToRange;
|
gp: TRoundToRange;
|
||||||
@ -1495,19 +1495,19 @@ begin
|
|||||||
TextOut(b.x+2, b.y+1, 'O');
|
TextOut(b.x+2, b.y+1, 'O');
|
||||||
end;
|
end;
|
||||||
|
|
||||||
UpdateWidgets;
|
UpdateBrackets;
|
||||||
if ExtendedEdit then begin
|
if ExtendedEdit then begin
|
||||||
n := GetTriangleColor(SelectedTriangle);// shr 1 and $7f7f7f;
|
n := GetTriangleColor(SelectedTriangle);// shr 1 and $7f7f7f;
|
||||||
if mouseOverTriangle <> SelectedTriangle then n := n shr 1 and $7f7f7f;
|
if mouseOverTriangle <> SelectedTriangle then n := n shr 1 and $7f7f7f;
|
||||||
Pen.Color := n;
|
Pen.Color := n;
|
||||||
Pen.Mode := pmMerge;
|
Pen.Mode := pmMerge;
|
||||||
DrawWidgets;
|
DrawBrackets;
|
||||||
|
|
||||||
if mouseOverWidget >= 0 then
|
if mouseOverBracket >= 0 then
|
||||||
begin
|
begin
|
||||||
pen.Color := pen.Color shr 1 and $7f7f7f;
|
pen.Color := pen.Color shr 1 and $7f7f7f;
|
||||||
pen.Width := 4;
|
pen.Width := 4;
|
||||||
DrawWidgets;
|
DrawBrackets;
|
||||||
pen.Width := 1;
|
pen.Width := 1;
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
@ -1517,8 +1517,40 @@ begin
|
|||||||
assert(trkVarPreviewRange.position > 0);
|
assert(trkVarPreviewRange.position > 0);
|
||||||
assert(trkVarPreviewDensity.position > 0);
|
assert(trkVarPreviewDensity.position > 0);
|
||||||
|
|
||||||
|
try
|
||||||
cp.xform[SelectedTriangle].Prepare;
|
cp.xform[SelectedTriangle].Prepare;
|
||||||
|
except
|
||||||
|
end;
|
||||||
|
|
||||||
|
if btnCoefsPolar.Down then begin
|
||||||
|
n := trkVarPreviewRange.position * trkVarPreviewDensity.position * 5;
|
||||||
|
d1 := trkVarPreviewDensity.position * 5;
|
||||||
|
tc := GetTriangleColor(SelectedTriangle);
|
||||||
|
|
||||||
|
try
|
||||||
|
tx := 0;
|
||||||
|
ty := 0;
|
||||||
|
for i := trkVarPreviewDepth.position downto 1 do
|
||||||
|
cp.xform[SelectedTriangle].NextPointXY(tx, ty);
|
||||||
|
a := ToScreen(tx, -ty);
|
||||||
|
Pixels[a.x, a.y] := tc;
|
||||||
|
except
|
||||||
|
end;
|
||||||
|
for ax := -2*n to 2*n do
|
||||||
|
for ay := 1 to n do
|
||||||
|
try
|
||||||
|
tr := ay/d1;
|
||||||
|
ta := ax * PI/2/n;
|
||||||
|
tx := tr * cos(ta);
|
||||||
|
ty := tr * sin(ta);
|
||||||
|
for i := trkVarPreviewDepth.position downto 1 do
|
||||||
|
cp.xform[SelectedTriangle].NextPointXY(tx, ty);
|
||||||
|
a := ToScreen(tx, -ty);
|
||||||
|
Pixels[a.x, a.y] := tc;
|
||||||
|
except
|
||||||
|
end;
|
||||||
|
end
|
||||||
|
else begin
|
||||||
n := trkVarPreviewRange.position * trkVarPreviewDensity.position * 5;
|
n := trkVarPreviewRange.position * trkVarPreviewDensity.position * 5;
|
||||||
d1 := trkVarPreviewDensity.position * 5;
|
d1 := trkVarPreviewDensity.position * 5;
|
||||||
tc := GetTriangleColor(SelectedTriangle);
|
tc := GetTriangleColor(SelectedTriangle);
|
||||||
@ -1529,11 +1561,12 @@ begin
|
|||||||
ty := ay / d1;
|
ty := ay / d1;
|
||||||
for i := trkVarPreviewDepth.position downto 1 do
|
for i := trkVarPreviewDepth.position downto 1 do
|
||||||
cp.xform[SelectedTriangle].NextPointXY(tx, ty);
|
cp.xform[SelectedTriangle].NextPointXY(tx, ty);
|
||||||
a := toscreen(tx, -ty);
|
a := ToScreen(tx, -ty);
|
||||||
Pixels[a.x, a.y] := tc;
|
Pixels[a.x, a.y] := tc;
|
||||||
except
|
except
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
if (TriangleCaught or CornerCaught) then // if dragging, draw pivot axis
|
if (TriangleCaught or CornerCaught) then // if dragging, draw pivot axis
|
||||||
begin
|
begin
|
||||||
@ -1856,7 +1889,7 @@ begin
|
|||||||
AxisLock := TransformAxisLock;
|
AxisLock := TransformAxisLock;
|
||||||
tbAxisLock.Down := AxisLock;
|
tbAxisLock.Down := AxisLock;
|
||||||
ExtendedEdit := ExtEditEnabled;
|
ExtendedEdit := ExtEditEnabled;
|
||||||
widgetMode := modeRotate;
|
bracketMode := modeRotate;
|
||||||
|
|
||||||
EdgeCaught := false;
|
EdgeCaught := false;
|
||||||
CornerCaught := false;
|
CornerCaught := false;
|
||||||
@ -1864,7 +1897,7 @@ begin
|
|||||||
mouseOverTriangle := -1;
|
mouseOverTriangle := -1;
|
||||||
mouseOverCorner := -1;
|
mouseOverCorner := -1;
|
||||||
mouseOverEdge := -1;
|
mouseOverEdge := -1;
|
||||||
mouseOverWidget := -1;
|
mouseOverBracket := -1;
|
||||||
oldSelected := -1;
|
oldSelected := -1;
|
||||||
|
|
||||||
MemTriangle.x[0] := 1;
|
MemTriangle.x[0] := 1;
|
||||||
@ -1937,7 +1970,7 @@ begin
|
|||||||
|
|
||||||
if not (CornerCaught or TriangleCaught) then // look for a point under cursor
|
if not (CornerCaught or TriangleCaught) then // look for a point under cursor
|
||||||
begin
|
begin
|
||||||
mouseOverWidget := -1;
|
mouseOverBracket := -1;
|
||||||
mouseOverEdge := -1;
|
mouseOverEdge := -1;
|
||||||
mouseOverCorner:= -1;
|
mouseOverCorner:= -1;
|
||||||
mouseOverPos.x := fx;
|
mouseOverPos.x := fx;
|
||||||
@ -1999,14 +2032,14 @@ begin
|
|||||||
|
|
||||||
if ExtendedEdit then //and (oldMode = modeNone) then
|
if ExtendedEdit then //and (oldMode = modeNone) then
|
||||||
begin
|
begin
|
||||||
for i := 0 to 3 do // -- detect 'widget' hit
|
for i := 0 to 3 do // -- detect bracket hit
|
||||||
for j := 0 to 1 do begin
|
for j := 0 to 1 do begin
|
||||||
if abs(line_dist(fx, fy, Widgets[i][j].x, Widgets[i][j].y,
|
if abs(line_dist(fx, fy, Brackets[i][j].x, Brackets[i][j].y,
|
||||||
Widgets[i][j+1].x, Widgets[i][j+1].y)
|
Brackets[i][j+1].x, Brackets[i][j+1].y)
|
||||||
) * GraphZoom * 50 < 3 then
|
) * GraphZoom * 50 < 3 then
|
||||||
begin
|
begin
|
||||||
mouseOverTriangle := SelectedTriangle;
|
mouseOverTriangle := SelectedTriangle;
|
||||||
mouseOverWidget := i;
|
mouseOverBracket := i;
|
||||||
// mouseOverEdge := -1;
|
// mouseOverEdge := -1;
|
||||||
// mouseOverCorner:= -1;
|
// mouseOverCorner:= -1;
|
||||||
mouseOverPos.x := fx;
|
mouseOverPos.x := fx;
|
||||||
@ -2045,7 +2078,7 @@ FoundCorner:
|
|||||||
|
|
||||||
if (mouseOverTriangle >= 0) or (SelectMode = false) or (oldMode <> modeNone) then
|
if (mouseOverTriangle >= 0) or (SelectMode = false) or (oldMode <> modeNone) then
|
||||||
begin
|
begin
|
||||||
if (mouseOverWidget >= 0) and (oldMode = modeNone) then
|
if (mouseOverBracket >= 0) and (oldMode = modeNone) then
|
||||||
TriangleView.Cursor := crEditRotate
|
TriangleView.Cursor := crEditRotate
|
||||||
else
|
else
|
||||||
if (mouseOverEdge >= 0) and (oldMode = modeNone) then begin // kinda hack, not good...
|
if (mouseOverEdge >= 0) and (oldMode = modeNone) then begin // kinda hack, not good...
|
||||||
@ -2382,11 +2415,11 @@ begin
|
|||||||
|
|
||||||
if ExtendedEdit then //and (oldMode = modeNone) then
|
if ExtendedEdit then //and (oldMode = modeNone) then
|
||||||
begin
|
begin
|
||||||
for i := 0 to 3 do // -- detect 'widget' hit
|
for i := 0 to 3 do // -- detect bracket hit
|
||||||
for j := 0 to 1 do
|
for j := 0 to 1 do
|
||||||
begin
|
begin
|
||||||
if abs(line_dist(fx, fy, Widgets[i][j].x, Widgets[i][j].y,
|
if abs(line_dist(fx, fy, Brackets[i][j].x, Brackets[i][j].y,
|
||||||
Widgets[i][j+1].x, Widgets[i][j+1].y)
|
Brackets[i][j+1].x, Brackets[i][j+1].y)
|
||||||
) * GraphZoom * 50 < 3 then
|
) * GraphZoom * 50 < 3 then
|
||||||
begin
|
begin
|
||||||
// modeHack := true;
|
// modeHack := true;
|
||||||
@ -3923,7 +3956,7 @@ begin
|
|||||||
2: mnuResetTrgScaleClick(Sender);
|
2: mnuResetTrgScaleClick(Sender);
|
||||||
end;
|
end;
|
||||||
end
|
end
|
||||||
else if mouseOverWidget >= 0 then begin
|
else if mouseOverBracket >= 0 then begin
|
||||||
case editMode of
|
case editMode of
|
||||||
modeScale: mnuResetTrgScaleClick(Sender);
|
modeScale: mnuResetTrgScaleClick(Sender);
|
||||||
else mnuResetTrgRotationClick(Sender);
|
else mnuResetTrgRotationClick(Sender);
|
||||||
@ -4198,6 +4231,7 @@ end;
|
|||||||
procedure TEditForm.btnCoefsModeClick(Sender: TObject);
|
procedure TEditForm.btnCoefsModeClick(Sender: TObject);
|
||||||
begin
|
begin
|
||||||
ShowSelectedInfo;
|
ShowSelectedInfo;
|
||||||
|
TriangleView.Invalidate;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TEditForm.tbVarPreviewClick(Sender: TObject);
|
procedure TEditForm.tbVarPreviewClick(Sender: TObject);
|
||||||
@ -5167,7 +5201,7 @@ begin
|
|||||||
|
|
||||||
MainTriangles[Transforms] := MainTriangles[-1];
|
MainTriangles[Transforms] := MainTriangles[-1];
|
||||||
cp.xform[Transforms].Clear;
|
cp.xform[Transforms].Clear;
|
||||||
cp.xform[Transforms].weight := 0.5;
|
cp.xform[Transforms].weight := cp.xform[SelectedTriangle].weight;
|
||||||
cp.xform[Transforms].vars[0] := 1;
|
cp.xform[Transforms].vars[0] := 1;
|
||||||
|
|
||||||
for i := 0 to Transforms-1 do begin
|
for i := 0 to Transforms-1 do begin
|
||||||
|
Loading…
Reference in New Issue
Block a user