polar mode for var preview;

weight cloned when adding linked xform "before"
This commit is contained in:
zueuk 2009-10-08 16:29:21 +00:00
parent be4e64d14e
commit 8a7d1c1dc3

View File

@ -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