too many chages...
This commit is contained in:
parent
5660d78da7
commit
364eceef07
@ -178,9 +178,11 @@ object AdjustForm: TAdjustForm
|
||||
Height = 129
|
||||
ActivePage = TabSheet1
|
||||
Align = alBottom
|
||||
Images = MainForm.Buttons
|
||||
TabOrder = 1
|
||||
object TabSheet1: TTabSheet
|
||||
Caption = 'Camera'
|
||||
ImageIndex = 18
|
||||
object scrollZoom: TScrollBar
|
||||
Left = 72
|
||||
Top = 7
|
||||
@ -263,6 +265,7 @@ object AdjustForm: TAdjustForm
|
||||
Height = 15
|
||||
LargeChange = 1500
|
||||
Max = 36000
|
||||
Min = -36000
|
||||
PageSize = 0
|
||||
SmallChange = 100
|
||||
TabOrder = 6
|
||||
@ -351,7 +354,7 @@ object AdjustForm: TAdjustForm
|
||||
end
|
||||
object TabSheet2: TTabSheet
|
||||
Caption = 'Rendering'
|
||||
ImageIndex = 1
|
||||
ImageIndex = 35
|
||||
object lblContrast: TLabel
|
||||
Left = 4
|
||||
Top = 80
|
||||
@ -532,7 +535,7 @@ object AdjustForm: TAdjustForm
|
||||
end
|
||||
object TabSheet3: TTabSheet
|
||||
Caption = 'Gradient'
|
||||
ImageIndex = 2
|
||||
ImageIndex = 11
|
||||
object lblVal: TLabel
|
||||
Left = 358
|
||||
Top = 55
|
||||
@ -866,7 +869,7 @@ object AdjustForm: TAdjustForm
|
||||
end
|
||||
object TabSheet4: TTabSheet
|
||||
Caption = 'Image Size'
|
||||
ImageIndex = 3
|
||||
ImageIndex = 51
|
||||
object Bevel2: TBevel
|
||||
Left = 4
|
||||
Top = 4
|
||||
@ -895,6 +898,13 @@ object AdjustForm: TAdjustForm
|
||||
Height = 13
|
||||
Caption = 'Height'
|
||||
end
|
||||
object Bevel3: TBevel
|
||||
Left = 302
|
||||
Top = 4
|
||||
Width = 73
|
||||
Height = 93
|
||||
Shape = bsFrame
|
||||
end
|
||||
object btnPreset1: TButton
|
||||
Left = 156
|
||||
Top = 12
|
||||
@ -950,9 +960,9 @@ object AdjustForm: TAdjustForm
|
||||
OnClick = btnSet3Click
|
||||
end
|
||||
object btnApplySize: TBitBtn
|
||||
Left = 302
|
||||
Top = 72
|
||||
Width = 75
|
||||
Left = 308
|
||||
Top = 64
|
||||
Width = 61
|
||||
Height = 25
|
||||
Caption = 'Apply'
|
||||
TabOrder = 6
|
||||
@ -1004,6 +1014,18 @@ object AdjustForm: TAdjustForm
|
||||
'960'
|
||||
'1024')
|
||||
end
|
||||
object chkResizeMain: TCheckBox
|
||||
Left = 308
|
||||
Top = 10
|
||||
Width = 61
|
||||
Height = 50
|
||||
Alignment = taLeftJustify
|
||||
Caption = 'Resize Main Window'
|
||||
Checked = True
|
||||
State = cbChecked
|
||||
TabOrder = 10
|
||||
WordWrap = True
|
||||
end
|
||||
end
|
||||
end
|
||||
object QualityPopup: TPopupMenu
|
||||
@ -1031,6 +1053,7 @@ object AdjustForm: TAdjustForm
|
||||
end
|
||||
object mnuInstantPreview: TMenuItem
|
||||
Caption = 'Instant Preview'
|
||||
Checked = True
|
||||
OnClick = mnuInstantPreviewClick
|
||||
end
|
||||
end
|
||||
|
@ -133,6 +133,8 @@ type
|
||||
pnlGamma: TPanel;
|
||||
pnlBrightness: TPanel;
|
||||
pnlVibrancy: TPanel;
|
||||
chkResizeMain: TCheckBox;
|
||||
Bevel3: TBevel;
|
||||
procedure FormCreate(Sender: TObject);
|
||||
procedure FormClose(Sender: TObject; var Action: TCloseAction);
|
||||
procedure FormDestroy(Sender: TObject);
|
||||
@ -362,7 +364,7 @@ begin
|
||||
scrollVibrancy.Position := trunc(cp.vibrancy * 100);
|
||||
scrollZoom.Position := trunc(cp.zoom * 1000);
|
||||
// ScrollAngle.Position := Trunc(cp.FAngle * 18000.0 / PI) mod scrollAngle.Max;
|
||||
scrollAngle.Position := Trunc((cp.FAngle + pi)* 18000.0 / PI) mod 36000;
|
||||
scrollAngle.Position := Trunc(cp.FAngle * 18000.0 / PI) mod 36000;
|
||||
|
||||
if (abs(cp.Center[0]) < 1000) and (abs(cp.Center[1]) < 1000) then begin
|
||||
scrollCenterX.Position := trunc(cp.Center[0] * 1000);
|
||||
@ -385,7 +387,7 @@ begin
|
||||
BackupPal := cp.cmap;
|
||||
|
||||
Resetting := False;
|
||||
editPPU.Text := Format('%.6g', [cp.pixels_per_unit]);
|
||||
editPPU.Text := Format('%.6g', [100*cp.pixels_per_unit/PreviewImage.Width]);
|
||||
end; //***
|
||||
DrawPreview;
|
||||
end;
|
||||
@ -394,7 +396,7 @@ procedure TAdjustForm.UpdateFlame;
|
||||
begin
|
||||
MainForm.StopThread;
|
||||
MainForm.UpdateUndo;
|
||||
MainCp.Copy(cp);
|
||||
MainCp.Copy(cp, true);
|
||||
// MainCp.cmap := cmap;
|
||||
// MainForm.zoom := zoom;
|
||||
// MainForm.Center[0] := Center[0];
|
||||
@ -488,6 +490,7 @@ begin
|
||||
Registry.WriteInteger('Top', AdjustForm.Top);
|
||||
Registry.WriteInteger('Left', AdjustForm.Left);
|
||||
Registry.WriteBool('InstantPreview', mnuInstantPreview.Checked);
|
||||
Registry.WriteBool('ResizeMain', chkResizeMain.Checked);
|
||||
end;
|
||||
finally
|
||||
Registry.Free;
|
||||
@ -521,6 +524,8 @@ begin
|
||||
AdjustForm.Top := Registry.ReadInteger('Top');
|
||||
if Registry.ValueExists('InstantPreview') then
|
||||
mnuInstantPreview.Checked := Registry.ReadBool('InstantPreview');
|
||||
if Registry.ValueExists('ResizeMain') then
|
||||
chkResizeMain.Checked := Registry.ReadBool('ResizeMain');
|
||||
Registry.CloseKey;
|
||||
end;
|
||||
|
||||
@ -871,6 +876,7 @@ procedure TAdjustForm.scrollVibrancyChange(Sender: TObject);
|
||||
begin
|
||||
cp.Vibrancy := ScrollVibrancy.Position / 100;
|
||||
txtVibrancy.text := FloatToStr(cp.Vibrancy);
|
||||
txtVibrancy.Refresh;
|
||||
DrawPreview;
|
||||
end;
|
||||
|
||||
@ -878,6 +884,7 @@ procedure TAdjustForm.scrollGammaChange(Sender: TObject);
|
||||
begin
|
||||
cp.Gamma := scrollGamma.Position / 100;
|
||||
txtGamma.text := FloatToStr(cp.Gamma);
|
||||
txtGamma.Refresh;
|
||||
DrawPreview;
|
||||
end;
|
||||
|
||||
@ -885,6 +892,7 @@ procedure TAdjustForm.scrollBrightnessChange(Sender: TObject);
|
||||
begin
|
||||
cp.Brightness := ScrollBrightness.Position / 100;
|
||||
txtBrightness.text := FloatToStr(cp.Brightness);
|
||||
txtBrightness.Refresh;
|
||||
DrawPreview;
|
||||
end;
|
||||
|
||||
@ -892,6 +900,7 @@ procedure TAdjustForm.scrollZoomChange(Sender: TObject);
|
||||
begin
|
||||
cp.zoom := scrollZoom.Position / 1000;
|
||||
txtZoom.text := FloatToStr(cp.zoom);
|
||||
txtZoom.Refresh;
|
||||
DrawPreview;
|
||||
end;
|
||||
|
||||
@ -899,13 +908,15 @@ procedure TAdjustForm.scrollCenterXChange(Sender: TObject);
|
||||
begin
|
||||
cp.center[0] := scrollCenterX.Position / 1000;
|
||||
txtCenterX.text := FloatToStr(cp.center[0]);
|
||||
txtCenterX.Refresh;
|
||||
DrawPreview;
|
||||
end;
|
||||
|
||||
procedure TAdjustForm.scrollCenterYChange(Sender: TObject);
|
||||
begin
|
||||
cp.center[1] := scrollCenterY.Position / 1000;
|
||||
txtCentery.text := FloatToStr(cp.center[1]);
|
||||
txtCenterY.text := FloatToStr(cp.center[1]);
|
||||
txtCenterY.Refresh;
|
||||
DrawPreview;
|
||||
end;
|
||||
|
||||
@ -935,8 +946,9 @@ end;
|
||||
|
||||
procedure TAdjustForm.scrollAngleChange(Sender: TObject);
|
||||
begin
|
||||
cp.FAngle := (scrollAngle.Position - 18000) * PI / 18000.0;
|
||||
cp.FAngle := scrollAngle.Position * PI / 18000.0;
|
||||
txtAngle.text := FloatToStr(cp.FAngle * 180 / PI);
|
||||
txtAngle.Refresh;
|
||||
DrawPreview;
|
||||
end;
|
||||
|
||||
@ -959,7 +971,7 @@ begin
|
||||
begin
|
||||
key := #0;
|
||||
try
|
||||
v := Trunc(StrToFloat(txtAngle.Text) * 100) mod scrollAngle.Max - 18000;
|
||||
v := Trunc(StrToFloat(txtAngle.Text) * 100) mod scrollAngle.Max;
|
||||
//if v > scrollAngle.Max then v := v - scrollAngle.Max*2
|
||||
if v < scrollAngle.Min then v := v + scrollAngle.Max;
|
||||
ScrollAngle.Position := v;
|
||||
@ -976,9 +988,9 @@ var
|
||||
begin
|
||||
if (txtAngle.Text <> EditBoxValue) then
|
||||
try
|
||||
v := Trunc(StrToFloat(txtAngle.Text) * 100) mod (scrollAngle.Max*2);
|
||||
if v > scrollAngle.Max then v := v - scrollAngle.Max*2
|
||||
else if v < scrollAngle.Min then v := v + scrollAngle.Max*2;
|
||||
v := Trunc(StrToFloat(txtAngle.Text) * 100) mod scrollAngle.Max;
|
||||
// if v > scrollAngle.Max then v := v - scrollAngle.Max*2
|
||||
// else if v < scrollAngle.Min then v := v + scrollAngle.Max*2;
|
||||
ScrollAngle.Position := v;
|
||||
UpdateFlame;
|
||||
except on EConvertError do
|
||||
@ -1687,8 +1699,10 @@ begin
|
||||
txtWidth.Text := IntToStr(ImageWidth);
|
||||
txtHeight.Text := IntToStr(ImageHeight);
|
||||
|
||||
if chkResizeMain.Checked then begin
|
||||
MainForm.Left:=Preset[n].Left;
|
||||
MainForm.Top:=Preset[n].Top;
|
||||
end;
|
||||
|
||||
SetMainWindowSize;
|
||||
end;
|
||||
@ -1739,28 +1753,36 @@ end;
|
||||
|
||||
procedure TAdjustForm.SetMainWindowSize;
|
||||
var
|
||||
xtot, ytot: integer;
|
||||
l, t, w, h: integer;
|
||||
begin
|
||||
xtot := ImageWidth + (MainForm.Width - MainForm.Image.Width);
|
||||
ytot := ImageHeight + (MainForm.Height - MainForm.Image.Height);
|
||||
if xtot > Screen.Width then
|
||||
MainCp.AdjustScale(ImageWidth, ImageHeight);
|
||||
MainForm.ResizeImage; //?
|
||||
|
||||
if chkResizeMain.Checked then begin
|
||||
l := MainForm.Left;
|
||||
t := MainForm.Top;
|
||||
w := ImageWidth + MainForm.Width - (MainForm.BackPanel.Width - 2);
|
||||
h := ImageHeight + MainForm.Height - (MainForm.BackPanel.Height - 2);
|
||||
if w > Screen.Width then
|
||||
begin
|
||||
MainForm.Left := 0;
|
||||
xtot := Screen.width;
|
||||
l := 0;
|
||||
w := Screen.width;
|
||||
end;
|
||||
if ytot > Screen.height then
|
||||
if h > Screen.height then
|
||||
begin
|
||||
MainForm.Top := 0;
|
||||
ytot := Screen.height;
|
||||
t := 0;
|
||||
h := Screen.height;
|
||||
end;
|
||||
MainForm.Width := xtot;
|
||||
MainForm.Height := ytot;
|
||||
|
||||
MainForm.SetBounds(l, t, w, h);
|
||||
end
|
||||
else MainForm.RedrawTimer.Enabled := true;
|
||||
end;
|
||||
|
||||
procedure TAdjustForm.GetMainWindowSize;
|
||||
begin
|
||||
ImageWidth := MainForm.Image.Width;
|
||||
ImageHeight := MainForm.Image.Height;
|
||||
ImageWidth := MainCP.Width; //MainForm.Image.Width;
|
||||
ImageHeight := MainCP.Height; //MainForm.Image.Height;
|
||||
txtWidth.text := IntToStr(ImageWidth);
|
||||
txtHeight.text := IntToStr(ImageHeight);
|
||||
end;
|
||||
@ -1872,7 +1894,7 @@ begin
|
||||
exit;
|
||||
end;
|
||||
MainForm.UpdateUndo;
|
||||
cp.pixels_per_unit := v;
|
||||
cp.pixels_per_unit := v/100*PreviewImage.Width;
|
||||
UpdateFlame;
|
||||
end;
|
||||
|
||||
@ -1884,7 +1906,7 @@ begin
|
||||
if Button <> mbLeft then exit;
|
||||
|
||||
if (Sender = pnlMasterScale) then
|
||||
pnlDragValue := cp.pixels_per_unit / 10
|
||||
pnlDragValue := cp.pixels_per_unit / PreviewImage.Width
|
||||
else if (Sender = pnlZoom) then
|
||||
pnlDragValue := cp.zoom
|
||||
else if (Sender = pnlXpos) then
|
||||
@ -1915,7 +1937,7 @@ end;
|
||||
procedure TAdjustForm.DragPanelMouseMove(Sender: TObject; Shift: TShiftState;
|
||||
X, Y: Integer);
|
||||
var
|
||||
v: double;
|
||||
sc, v: double;
|
||||
begin
|
||||
if pnlMM then // hack: to skip MouseMove event
|
||||
begin
|
||||
@ -1926,22 +1948,22 @@ begin
|
||||
begin
|
||||
Inc(pnlDragPos, x - pnlDragOld);
|
||||
|
||||
if GetKeyState(VK_MENU) < 0 then v := 100000
|
||||
else if GetKeyState(VK_CONTROL) < 0 then v := 10000
|
||||
else if GetKeyState(VK_SHIFT) < 0 then v := 100
|
||||
else v := 1000;
|
||||
if GetKeyState(VK_MENU) < 0 then sc := 100000
|
||||
else if GetKeyState(VK_CONTROL) < 0 then sc := 10000
|
||||
else if GetKeyState(VK_SHIFT) < 0 then sc := 100
|
||||
else sc := 1000;
|
||||
|
||||
v := Round6(pnlDragValue + pnlDragPos / v);
|
||||
v := Round6(pnlDragValue + pnlDragPos / sc);
|
||||
|
||||
SetCursorPos(MousePos.x, MousePos.y); // hmmm
|
||||
pnlMM:=true;
|
||||
|
||||
if (Sender = pnlMasterScale) then
|
||||
begin
|
||||
v := v * 10;
|
||||
if v <= 0.1 then v := 0.1;
|
||||
cp.pixels_per_unit := v;
|
||||
editPPU.Text := FloatToStr(v);
|
||||
v := Round6(pnlDragValue * power(2, pnlDragPos / sc / 2));
|
||||
if v <= 0.0001 then v := 0.0001;
|
||||
cp.pixels_per_unit := v*PreviewImage.Width;
|
||||
editPPU.Text := FloatToStr(v*100);
|
||||
end
|
||||
else if (Sender = pnlZoom) then
|
||||
begin
|
||||
@ -1957,7 +1979,7 @@ begin
|
||||
end
|
||||
else if (Sender = pnlAngle) then
|
||||
begin
|
||||
scrollAngle.Position := Trunc((v + pi)* 18000.0 / PI) mod 36000;
|
||||
scrollAngle.Position := Trunc(v * 18000.0 / PI) mod 36000;
|
||||
end
|
||||
else if (Sender = pnlGamma) then
|
||||
begin
|
||||
@ -2005,9 +2027,9 @@ begin
|
||||
if (Sender = pnlMasterScale) then
|
||||
begin
|
||||
pValue := @cp.pixels_per_unit;
|
||||
if pValue^ = 32 then exit;
|
||||
pValue^ := 32;
|
||||
editPPU.Text := FloatToStr(pValue^);
|
||||
if pValue^ = PreviewImage.Width/4 then exit;
|
||||
pValue^ := PreviewImage.Width/4;
|
||||
editPPU.Text := FloatToStr(100*pValue^/PreviewImage.Width);
|
||||
end
|
||||
else if (Sender = pnlZoom) then
|
||||
begin
|
||||
@ -2023,7 +2045,7 @@ begin
|
||||
end
|
||||
else if (Sender = pnlAngle) then
|
||||
begin
|
||||
scrollAngle.Position := 18000;
|
||||
scrollAngle.Position := 0;
|
||||
end
|
||||
else if (Sender = pnlGamma) then
|
||||
begin
|
||||
|
@ -34,8 +34,6 @@ const
|
||||
BRIGHT_ADJUST = 2.3;
|
||||
FUSE = 15;
|
||||
|
||||
// ---- MyTypes ----
|
||||
|
||||
type
|
||||
TCoefsArray= array[0..2, 0..1] of double;
|
||||
pCoefsArray= ^TCoefsArray;
|
||||
@ -67,8 +65,6 @@ type
|
||||
TPreviewPixArray = array[0..159, 0..119, 0..3] of integer;
|
||||
TFileType = (ftIfs, ftFla, ftXML);
|
||||
|
||||
// -----
|
||||
|
||||
type //?
|
||||
PLongintArray = ^TLongintArray;
|
||||
TLongintArray = array[0..8192] of Longint;
|
||||
@ -164,15 +160,19 @@ type
|
||||
// procedure Testiterate(NrPoints: integer; var Points: TPointsArray);
|
||||
|
||||
function Clone: TControlPoint;
|
||||
procedure Copy(cp1: TControlPoint);
|
||||
procedure Copy(cp1: TControlPoint; KeepSizes: boolean = false);
|
||||
|
||||
function HasNewVariants: boolean;
|
||||
// function HasNewVariants: boolean;
|
||||
function HasFinalXForm: boolean;
|
||||
|
||||
// CP-specific functions moved from unit Main
|
||||
function NumXForms: integer;
|
||||
function TrianglesFromCP(var Triangles: TTriangles): integer;
|
||||
procedure GetFromTriangles(const Triangles: TTriangles; const t: integer);
|
||||
|
||||
procedure GetPostTriangle(var Triangles: TTriangles; const n: integer);
|
||||
procedure SetPostTriangle(const Triangles: TTriangles; const n: integer);
|
||||
|
||||
procedure EqualizeWeights;
|
||||
procedure NormalizeWeights;
|
||||
procedure RandomizeWeights;
|
||||
@ -913,6 +913,7 @@ var
|
||||
deltay, miny, maxy: double;
|
||||
cntminy, cntmaxy: integer;
|
||||
LimitOutSidePoints: integer;
|
||||
px, py, sina, cosa: double;
|
||||
begin
|
||||
{$IFDEF TESTVARIANT}
|
||||
center[0] := 0;
|
||||
@ -929,6 +930,9 @@ begin
|
||||
1: iterateXYC(SUB_BATCH_SIZE, points);
|
||||
end;
|
||||
}
|
||||
cosa := cos(FAngle);
|
||||
sina := sin(FAngle);
|
||||
|
||||
Prepare;
|
||||
|
||||
IterateXY(SUB_BATCH_SIZE, points);
|
||||
@ -960,6 +964,8 @@ begin
|
||||
cntminy := 0;
|
||||
cntmaxy := 0;
|
||||
for i := 0 to SUB_BATCH_SIZE - 1 do begin
|
||||
px := points[i].x * cosa + points[i].y * sina;
|
||||
py := points[i].y * cosa - points[i].x * sina;
|
||||
if (Points[i].x < minx) then Inc(cntminx);
|
||||
if (Points[i].x > maxx) then Inc(cntmaxx);
|
||||
if (Points[i].y < miny) then Inc(cntminy);
|
||||
@ -1490,11 +1496,15 @@ begin
|
||||
sl.Free;
|
||||
end;
|
||||
|
||||
procedure TControlPoint.Copy(cp1: TControlPoint);
|
||||
procedure TControlPoint.Copy(cp1: TControlPoint; KeepSizes: boolean = false);
|
||||
var
|
||||
i: integer;
|
||||
sl: TStringList;
|
||||
w, h: integer;
|
||||
begin
|
||||
w := Width;
|
||||
h := Height;
|
||||
|
||||
Clear;
|
||||
sl := TStringList.Create;
|
||||
|
||||
@ -1503,11 +1513,17 @@ begin
|
||||
ParseStringlist(sl);
|
||||
|
||||
Fangle := cp1.FAngle;
|
||||
center[0]:= cp1.center[0];
|
||||
center[1]:= cp1.center[1];
|
||||
pixels_per_unit := cp1.pixels_per_unit;
|
||||
cmap := cp1.cmap;
|
||||
name := cp1.name;
|
||||
nick := cp1.nick;
|
||||
url := cp1.url;
|
||||
|
||||
if KeepSizes then
|
||||
AdjustScale(w, h);
|
||||
|
||||
for i := 0 to NXFORMS do // was: NXFORMS-1
|
||||
xform[i].assign(cp1.xform[i]);
|
||||
finalXformEnabled := cp1.finalXformEnabled;
|
||||
@ -1649,6 +1665,7 @@ begin
|
||||
end;
|
||||
end;
|
||||
|
||||
(*
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
function TControlPoint.HasNewVariants: boolean;
|
||||
var
|
||||
@ -1668,47 +1685,40 @@ begin
|
||||
end;
|
||||
}
|
||||
end;
|
||||
*)
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
procedure TControlPoint.ZoomtoRect(R: TRect);
|
||||
var
|
||||
scale: double;
|
||||
ppux, ppuy: double;
|
||||
scale, ppu: double;
|
||||
dx,dy: double;
|
||||
begin
|
||||
scale := power(2, zoom);
|
||||
ppux := pixels_per_unit * scale;
|
||||
ppuy := pixels_per_unit * scale;
|
||||
ppu := pixels_per_unit * scale;
|
||||
|
||||
dx := ((r.Left + r.Right)/2 - Width/2)/ppux ;
|
||||
dy := ((r.Top + r.Bottom)/2 - Height/2)/ppuy;
|
||||
dx := ((r.Left + r.Right)/2 - Width/2) / ppu;
|
||||
dy := ((r.Top + r.Bottom)/2 - Height/2) / ppu;
|
||||
|
||||
center[0] := center[0] + cos(FAngle) * dx - sin(FAngle) * dy;
|
||||
center[1] := center[1] + sin(FAngle) * dx + cos(FAngle) * dy ;
|
||||
center[1] := center[1] + sin(FAngle) * dx + cos(FAngle) * dy;
|
||||
|
||||
Scale := Scale * Min( Width/(abs(r.Right - r.Left) + 1), Height/(abs(r.Bottom - r.Top) + 1)) ;
|
||||
Zoom := Log2(Scale);
|
||||
zoom := Log2(scale * ( Width/(abs(r.Right - r.Left) + 1)));
|
||||
end;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
procedure TControlPoint.ZoomOuttoRect(R: TRect);
|
||||
var
|
||||
scale: double;
|
||||
ppux, ppuy: double;
|
||||
dx,dy: double;
|
||||
ppu: double;
|
||||
dx, dy: double;
|
||||
begin
|
||||
scale := power(2, zoom);
|
||||
ppux := pixels_per_unit * scale;
|
||||
ppuy := pixels_per_unit * scale;
|
||||
zoom := Log2(power(2, zoom) / ( Width/(abs(r.Right - r.Left) + 1)));
|
||||
ppu := pixels_per_unit * power(2, zoom);
|
||||
|
||||
dx := ((r.Left + r.Right)/2 - Width/2)/ppux ;
|
||||
dy := ((r.Top + r.Bottom)/2 - Height/2)/ppuy;
|
||||
dx := ((r.Left + r.Right)/2 - Width/2) / ppu;
|
||||
dy := ((r.Top + r.Bottom)/2 - Height/2) / ppu;
|
||||
|
||||
center[0] := center[0] + cos(FAngle) * dx - sin(FAngle) * dy;
|
||||
center[1] := center[1] + sin(FAngle) * dx + cos(FAngle) * dy ;
|
||||
|
||||
Scale := Scale / Min( Width/(abs(r.Right - r.Left) + 1), Height/(abs(r.Bottom - r.Top) + 1)) ;
|
||||
Zoom := Log2(Scale);
|
||||
center[0] := center[0] - cos(FAngle) * dx + sin(FAngle) * dy;
|
||||
center[1] := center[1] - sin(FAngle) * dx - cos(FAngle) * dy;
|
||||
end;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
@ -1960,6 +1970,33 @@ begin
|
||||
FinalXformEnabled := EnableFinalXform;
|
||||
end;
|
||||
|
||||
|
||||
procedure TControlPoint.GetPostTriangle(var Triangles: TTriangles; const n: integer);
|
||||
var
|
||||
i, j: integer;
|
||||
begin
|
||||
for i := 0 to 2 do
|
||||
with xform[n] do begin
|
||||
Triangles[n].x[i] := Triangles[-1].x[i] * p[0][0] + Triangles[-1].y[i] * p[1][0] + p[2][0];
|
||||
Triangles[n].y[i] := Triangles[-1].x[i] * p[0][1] + Triangles[-1].y[i] * p[1][1] + p[2][1];
|
||||
end;
|
||||
//for i := 0 to 2 do Triangles[n].y[i] := -Triangles[n].y[i];
|
||||
end;
|
||||
|
||||
procedure TControlPoint.SetPostTriangle(const Triangles: TTriangles; const n: integer);
|
||||
begin
|
||||
solve3(Triangles[-1].x[0], -Triangles[-1].y[0], Triangles[n].x[0],
|
||||
Triangles[-1].x[1], -Triangles[-1].y[1], Triangles[n].x[1],
|
||||
Triangles[-1].x[2], -Triangles[-1].y[2], Triangles[n].x[2],
|
||||
xform[n].p[0][0], xform[n].p[1][0], xform[n].p[2][0]);
|
||||
|
||||
solve3(Triangles[-1].x[0], -Triangles[-1].y[0], -Triangles[n].y[0],
|
||||
Triangles[-1].x[1], -Triangles[-1].y[1], -Triangles[n].y[1],
|
||||
Triangles[-1].x[2], -Triangles[-1].y[2], -Triangles[n].y[2],
|
||||
xform[n].p[0][1], xform[n].p[1][1], xform[n].p[2][1]);
|
||||
end;
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
procedure TControlPoint.AdjustScale(w, h: integer);
|
||||
begin
|
||||
// if width >= height then
|
||||
|
@ -412,8 +412,9 @@ object EditForm: TEditForm
|
||||
Top = 1
|
||||
Width = 170
|
||||
Height = 130
|
||||
IncrementalDisplay = True
|
||||
Center = True
|
||||
PopupMenu = QualityPopup
|
||||
Proportional = True
|
||||
end
|
||||
end
|
||||
object ControlPanel: TPanel
|
||||
@ -1193,7 +1194,7 @@ object EditForm: TEditForm
|
||||
ShowHint = True
|
||||
OnClick = btnResetPostXFormClick
|
||||
end
|
||||
object btnSwapXforms: TSpeedButton
|
||||
object btnPostTriangle: TSpeedButton
|
||||
Left = 8
|
||||
Top = 260
|
||||
Width = 145
|
||||
@ -1209,7 +1210,7 @@ object EditForm: TEditForm
|
||||
ParentFont = False
|
||||
ParentShowHint = False
|
||||
ShowHint = True
|
||||
OnClick = btnSwapXformsClick
|
||||
OnClick = btnPostTriangleClick
|
||||
end
|
||||
object pnlWeight: TPanel
|
||||
Left = 8
|
||||
@ -1695,8 +1696,7 @@ object EditForm: TEditForm
|
||||
Caption = '-'
|
||||
end
|
||||
object mnuResetLoc: TMenuItem
|
||||
Caption = 'Reset Location'
|
||||
Checked = True
|
||||
Caption = 'Auto reset location'
|
||||
OnClick = mnuResetLocClick
|
||||
end
|
||||
end
|
||||
|
@ -28,12 +28,6 @@ uses
|
||||
ControlPoint, XForm, cmap, CustomDrawControl,
|
||||
Render;
|
||||
|
||||
const
|
||||
crEditArrow = 20;
|
||||
crEditMove = 21;
|
||||
crEditRotate = 22;
|
||||
crEditScale = 23;
|
||||
|
||||
type
|
||||
TEditForm = class(TForm)
|
||||
GrphPnl: TPanel;
|
||||
@ -145,7 +139,7 @@ type
|
||||
txtPost20: TEdit;
|
||||
txtPost21: TEdit;
|
||||
btnResetPostXForm: TSpeedButton;
|
||||
btnSwapXforms: TSpeedButton;
|
||||
btnPostTriangle: TSpeedButton;
|
||||
GroupBox3: TGroupBox;
|
||||
editPivotY: TEdit;
|
||||
editPivotX: TEdit;
|
||||
@ -274,9 +268,6 @@ type
|
||||
Shift: TShiftState; X, Y: Integer);
|
||||
procedure VEVarsDblClick(Sender: TObject);
|
||||
|
||||
// procedure vleVariablesGetPickList(Sender: TObject; const KeyName: String; Values: TStrings);
|
||||
// procedure vleVariablesStringsChange(Sender: TObject);
|
||||
|
||||
procedure cbTransformsDrawItem(Control: TWinControl; Index: Integer;
|
||||
Rect: TRect; State: TOwnerDrawState);
|
||||
|
||||
@ -302,7 +293,7 @@ type
|
||||
procedure PostCoefValidate(Sender: TObject);
|
||||
procedure PostCoefKeypress(Sender: TObject; var Key: Char);
|
||||
procedure btnResetPostXFormClick(Sender: TObject);
|
||||
procedure btnSwapXformsClick(Sender: TObject);
|
||||
procedure btnPostTriangleClick(Sender: TObject);
|
||||
procedure btnPivotModeClick(Sender: TObject);
|
||||
procedure PivotValidate(Sender: TObject);
|
||||
procedure PivotKeyPress(Sender: TObject; var Key: Char);
|
||||
@ -353,7 +344,6 @@ type
|
||||
SelectMode, ExtendedEdit, AxisLock: boolean;
|
||||
showVarPreview: boolean;
|
||||
|
||||
// --Z-- variables moved from outside
|
||||
GraphZoom: double;
|
||||
TriangleCaught, CornerCaught, EdgeCaught: boolean;
|
||||
LocalAxisLocked: boolean;
|
||||
@ -371,12 +361,6 @@ type
|
||||
pnlDragPos, pnlDragOld: integer;
|
||||
pnlDragValue: double;
|
||||
|
||||
(*
|
||||
{ Options }
|
||||
UseFlameBackground, UseTransformColors: boolean;
|
||||
BackGroundColor, ReferenceTrianglecolor: integer;
|
||||
GridColor1, GridColor2, HelpersColor: integer;
|
||||
*)
|
||||
procedure UpdateFlameX;
|
||||
procedure UpdateFlame(DrawMain: boolean);
|
||||
procedure UpdateWidgets;
|
||||
@ -384,15 +368,13 @@ type
|
||||
|
||||
function GetPivot: TSPoint; overload;
|
||||
function GetPivot(n: integer): TSPoint; overload;
|
||||
//moved to public: function GetTriangleColor(n: integer): TColor;
|
||||
|
||||
// --Z-- functions moved from outside (?)
|
||||
procedure ShowSelectedInfo;
|
||||
procedure Scale(var fx, fy: double; x, y: integer);
|
||||
// procedure ReadjustWeights(var cp: TControlPoint);
|
||||
|
||||
procedure TriangleViewPaint(Sender: TObject);
|
||||
procedure AutoZoom;
|
||||
|
||||
public
|
||||
cp: TControlPoint;
|
||||
Render: TRenderer;
|
||||
@ -414,7 +396,6 @@ const
|
||||
|
||||
var
|
||||
EditForm: TEditForm;
|
||||
// pcenterx, pcentery, pscale: double;
|
||||
|
||||
function ColorValToColor(c: TColorMap; index: double): TColor;
|
||||
function FlipTriangleVertical(t: TTriangle): TTriangle;
|
||||
@ -428,7 +409,6 @@ function Centroid(t: TTriangle): TSPoint;
|
||||
function OffsetTriangleRandom(t: TTriangle): TTriangle;
|
||||
function ScaleTriangleCenter(t: TTriangle; scale: double): TTriangle;
|
||||
function ScaleTrianglePoint(t: TTriangle; x, y, scale: double): TTriangle;
|
||||
//procedure ScaleAll;
|
||||
|
||||
implementation
|
||||
|
||||
@ -580,29 +560,30 @@ function ColorValToColor(c: TColorMap; index: double): TColor;
|
||||
var
|
||||
i: integer;
|
||||
begin
|
||||
i := Trunc(Index * 255); //!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! >>TODO: check<<
|
||||
i := Trunc(Index * 255);
|
||||
assert(i >= 0);
|
||||
assert(i < 256);
|
||||
result := c[i][2] shl 16 + c[i][1] shl 8 + c[i][0];
|
||||
end;
|
||||
|
||||
procedure TEditForm.UpdatePreview;
|
||||
var
|
||||
pw, ph: integer;
|
||||
r: double;
|
||||
begin
|
||||
pw := PrevPnl.Width - 2;
|
||||
ph := PrevPnl.Height - 2;
|
||||
if (cp.width / cp.height) > (PrevPnl.Width / PrevPnl.Height) then
|
||||
if (cp.width / cp.height) > (pw / ph) then
|
||||
begin
|
||||
PreviewImage.Width := pw;
|
||||
r := cp.width / PreviewImage.Width;
|
||||
PreviewImage.height := round(cp.height / r);
|
||||
assert(pw <> 0);
|
||||
PreviewImage.Height := round(cp.height / cp.Width * pw);
|
||||
PreviewImage.Left := 1;
|
||||
PreviewImage.Top := (ph - PreviewImage.Height) div 2;
|
||||
end
|
||||
else begin
|
||||
PreviewImage.Height := ph;
|
||||
r := cp.height / PreviewImage.height;
|
||||
PreviewImage.Width := round(cp.Width / r);
|
||||
assert(ph <> 0);
|
||||
PreviewImage.Width := round(cp.Width / cp.Height * ph);
|
||||
PreviewImage.Top := 1;
|
||||
PreviewImage.Left := (pw - PreviewImage.Width) div 2;
|
||||
end;
|
||||
@ -613,7 +594,6 @@ end;
|
||||
procedure TEditForm.UpdateDisplay(PreviewOnly: boolean = false);
|
||||
var
|
||||
i: integer;
|
||||
// pw, ph: integer;
|
||||
begin
|
||||
// currently EditForm does not really know if we select another
|
||||
// flame in the Main Window - which is not good...
|
||||
@ -651,7 +631,7 @@ begin
|
||||
TriangleCaught := false;
|
||||
|
||||
ShowSelectedInfo;
|
||||
if MainForm.UndoIndex = 0 then AutoZoom // auto-zoom only on 'new' flame - hmm...?
|
||||
if MainForm.UndoIndex = 0 then AutoZoom // auto-zoom only on 'new' flame
|
||||
else TriangleView.Invalidate;
|
||||
end;
|
||||
|
||||
@ -665,15 +645,16 @@ begin
|
||||
begin
|
||||
cp.zoom := 0;
|
||||
cp.CalcBoundbox;
|
||||
end
|
||||
{ end
|
||||
else
|
||||
begin
|
||||
cp.zoom := MainCp.zoom;
|
||||
cp.center[0] := MainCp.Center[0];
|
||||
cp.center[1] := MainCp.Center[1];
|
||||
}
|
||||
end;
|
||||
|
||||
cp.cmap := MainCp.cmap;
|
||||
// Render.Compatibility := compatibility;
|
||||
Render.SetCP(cp);
|
||||
Render.Render;
|
||||
PreviewImage.Picture.Bitmap.Assign(Render.GetImage);
|
||||
@ -830,6 +811,7 @@ end;
|
||||
procedure TEditForm.UpdateFlameX;
|
||||
begin
|
||||
cp.GetFromTriangles(MainTriangles, Transforms);
|
||||
|
||||
if not chkPreserve.checked then cp.ComputeWeights(MainTriangles, Transforms);
|
||||
DrawPreview;
|
||||
ShowSelectedInfo;
|
||||
@ -838,23 +820,26 @@ end;
|
||||
|
||||
procedure TEditForm.UpdateFlame(DrawMain: boolean);
|
||||
begin
|
||||
//; MainForm.StopThread;
|
||||
StatusBar.Panels[2].Text := Format('Zoom: %f', [GraphZoom]);
|
||||
|
||||
cp.GetFromTriangles(MainTriangles, LastTriangle);
|
||||
|
||||
// if not chkPreserve.Checked then ComputeWeights(cp, MainTriangles, transforms);
|
||||
DrawPreview;
|
||||
ShowSelectedInfo;
|
||||
TriangleView.Refresh;
|
||||
if DrawMain then begin
|
||||
MainForm.StopThread;
|
||||
MainCp.Copy(cp);
|
||||
|
||||
MainCp.Copy(cp, true);
|
||||
|
||||
MainCp.cmap := cmap;
|
||||
if mnuResetLoc.checked then begin
|
||||
MainCp.zoom := 0;
|
||||
MainForm.center[0] := cp.center[0];
|
||||
MainForm.center[1] := cp.center[1];
|
||||
end;
|
||||
// if AdjustForm.Visible then AdjustForm.UpdateDisplay;
|
||||
if AdjustForm.Visible then AdjustForm.UpdateDisplay;
|
||||
if MutateForm.Visible then MutateForm.UpdateDisplay;
|
||||
MainForm.RedrawTimer.enabled := true;
|
||||
end;
|
||||
@ -1051,7 +1036,10 @@ var
|
||||
tps: TPenStyle;
|
||||
label DrawCorner;
|
||||
begin
|
||||
assert(SelectedTriangle >= 0);
|
||||
if (SelectedTriangle < 0) then begin
|
||||
assert(false, 'Selected triangle < 0');
|
||||
SelectedTriangle := 0;
|
||||
end;
|
||||
assert(TCustomDrawControl(Sender) = TriangleView);
|
||||
if SelectedTriangle > LastTriangle then SelectedTriangle := LastTriangle;
|
||||
|
||||
@ -1133,11 +1121,11 @@ begin
|
||||
begin
|
||||
if i <> SelectedTriangle then Pen.Style := psDot;
|
||||
|
||||
// this is still a hack --------------------------------------------------------
|
||||
with cp.xform[i] do
|
||||
if (p[0,0]<>1) or (p[0,1]<>0) or(p[1,0]<>0) or (p[1,1]<>1) or (p[2,0]<>0) or (p[2,1]<>0) then
|
||||
begin
|
||||
Pen.Color := GetTriangleColor(i) shr 1 and $7f7f7f;
|
||||
//Pen.Mode := pmMerge;
|
||||
a:=toscreen(p[0,0] - p[1,0] + p[2,0], -p[0,1] + p[1,1] - p[2,1]);
|
||||
moveto(a.x, a.y);
|
||||
b:=toscreen(p[0,0] + p[1,0] + p[2,0], -p[0,1] - p[1,1] - p[2,1]);
|
||||
@ -1268,7 +1256,6 @@ end;
|
||||
end;
|
||||
end;
|
||||
|
||||
//i := min( min(Width, Height), integer(round(dmax * sc)));
|
||||
i := integer(round(d * sc));
|
||||
if i > 4 then
|
||||
begin
|
||||
@ -1469,11 +1456,6 @@ procedure TEditForm.FormCreate(Sender: TObject);
|
||||
var
|
||||
i: integer;
|
||||
begin
|
||||
Screen.Cursors[crEditArrow] := LoadCursor(HInstance, 'ARROW_WHITE');
|
||||
Screen.Cursors[crEditMove] := LoadCursor(HInstance, 'MOVE_WB');
|
||||
Screen.Cursors[crEditRotate] := LoadCursor(HInstance, 'ROTATE_WB');
|
||||
Screen.Cursors[crEditScale] := LoadCursor(HInstance, 'SCALE_WB');
|
||||
|
||||
// Custom control setup
|
||||
TriangleView := TCustomDrawControl.Create(self);
|
||||
TriangleView.TabStop := True;
|
||||
@ -1499,21 +1481,10 @@ begin
|
||||
for i:= 0 to NRVAR - 1 do begin
|
||||
VEVars.InsertRow(Varnames(i), '0', True);
|
||||
end;
|
||||
|
||||
for i:= 0 to GetNrVariableNames - 1 do begin
|
||||
vleVariables.InsertRow(GetVariableNameAt(i), '0', True);
|
||||
end;
|
||||
|
||||
{
|
||||
with vleVariables.ItemProps['blur2_type'] do begin // temporary hack?
|
||||
ReadOnly := true;
|
||||
PickList.Add('gaussian');
|
||||
PickList.Add('zoom');
|
||||
PickList.Add('radial');
|
||||
PickList.Add('defocus');
|
||||
end;
|
||||
}
|
||||
|
||||
GraphZoom := 1;
|
||||
|
||||
case EditPrevQual of
|
||||
@ -1559,8 +1530,6 @@ procedure TEditForm.FormDestroy(Sender: TObject);
|
||||
begin
|
||||
cp.free;
|
||||
Render.free;
|
||||
|
||||
// vleVariables.ItemProps['blur2_type'].Destroy; // :-/
|
||||
end;
|
||||
|
||||
procedure TEditForm.TriangleViewMouseMove(Sender: TObject; Shift: TShiftState;
|
||||
@ -2178,6 +2147,7 @@ begin
|
||||
EditPopup.Popup(mousepos.x, mousepos.y)
|
||||
else begin
|
||||
SelectedTriangle := mouseOverTriangle;
|
||||
cbTransforms.ItemIndex := SelectedTriangle;
|
||||
TriangleView.Refresh;
|
||||
TrianglePopup.Popup(mousepos.x, mousepos.y)
|
||||
end;
|
||||
@ -2789,7 +2759,9 @@ begin
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
|
||||
cp.TrianglesFromCP(MainTriangles);
|
||||
|
||||
ShowSelectedInfo;
|
||||
UpdateFlame(true);
|
||||
end;
|
||||
@ -3043,8 +3015,6 @@ begin
|
||||
|
||||
TValueListEditor(Sender).Row := cell.Y;
|
||||
|
||||
// if ((Sender = vleVariables) and vleVariables.ItemProps[varDragIndex].ReadOnly) then exit;
|
||||
|
||||
Screen.Cursor := crHSplit;
|
||||
|
||||
GetCursorPos(mousepos); // hmmm
|
||||
@ -3134,26 +3104,31 @@ end;
|
||||
procedure TEditForm.VEVarsDblClick(Sender: TObject);
|
||||
var
|
||||
n: integer;
|
||||
v, v1: double;
|
||||
changed: boolean;
|
||||
begin
|
||||
n := TValueListEditor(Sender).Row - 1;
|
||||
assert(n >= 0);
|
||||
assert(n < TValueListEditor(Sender).rowCount);
|
||||
|
||||
if {(varDragOld >= TValueListEditor(Sender).ColWidths[0]) or}
|
||||
(TValueListEditor(Sender).Values[VarNames(n)] = '0') then exit;
|
||||
changed := false;
|
||||
|
||||
MainForm.UpdateUndo;
|
||||
if Sender = VEVars then
|
||||
begin
|
||||
cp.xform[SelectedTriangle].vars[n] := 0;
|
||||
VEVars.Values[VarNames(n)] := '0';
|
||||
v := cp.xform[SelectedTriangle].vars[n];
|
||||
cp.xform[SelectedTriangle].vars[n] := IfThen(DoubleClickSetVars and (v = 0), 1, 0);
|
||||
//VEVars.Values[VarNames(n)] := '0';
|
||||
changed := (cp.xform[SelectedTriangle].vars[n] <> v);
|
||||
end
|
||||
else begin
|
||||
//v := 0; // hmm
|
||||
cp.xform[SelectedTriangle].GetVariable(vleVariables.Keys[n + 1], v);
|
||||
cp.xform[SelectedTriangle].ResetVariable(vleVariables.Keys[n + 1]);
|
||||
//vleVariables.Values[vleVariables.Keys[varDragIndex+1]] := '0';
|
||||
cp.xform[SelectedTriangle].GetVariable(vleVariables.Keys[n + 1], v1);
|
||||
changed := (v1 <> v);
|
||||
end;
|
||||
|
||||
if changed then MainForm.UpdateUndo;
|
||||
UpdateFlame(true);
|
||||
end;
|
||||
|
||||
@ -3747,6 +3722,11 @@ begin
|
||||
cp.xform[1].color := 1;
|
||||
cp.xform[2].symmetry := 1;
|
||||
|
||||
cp.center[0] := 0;
|
||||
cp.center[1] := 0;
|
||||
cp.zoom := 0;
|
||||
cp.pixels_per_unit := PreviewImage.Width/4;
|
||||
|
||||
Transforms := 2;
|
||||
SelectedTriangle := 1;
|
||||
MainTriangles[0] := MainTriangles[-1];
|
||||
@ -3760,6 +3740,7 @@ begin
|
||||
cbTransforms.Items.Add('1');
|
||||
cbTransforms.Items.Add('2');
|
||||
AutoZoom;
|
||||
|
||||
UpdateFlame(True);
|
||||
end;
|
||||
|
||||
@ -3787,6 +3768,7 @@ begin
|
||||
MainForm.UpdateUndo;
|
||||
cp.xform[SelectedTriangle].c[1][0] := 0;
|
||||
cp.xform[SelectedTriangle].c[1][1] := 1;
|
||||
|
||||
cp.TrianglesFromCP(MainTriangles);
|
||||
UpdateFlame(True);
|
||||
end;
|
||||
@ -3799,6 +3781,7 @@ begin
|
||||
MainForm.UpdateUndo;
|
||||
cp.xform[SelectedTriangle].c[2][0] := 0;
|
||||
cp.xform[SelectedTriangle].c[2][1] := 0;
|
||||
|
||||
cp.TrianglesFromCP(MainTriangles);
|
||||
UpdateFlame(True);
|
||||
end;
|
||||
@ -4062,7 +4045,7 @@ begin
|
||||
end;
|
||||
|
||||
// this function is temporary...................................................
|
||||
procedure TEditForm.btnSwapXformsClick(Sender: TObject);
|
||||
procedure TEditForm.btnPostTriangleClick(Sender: TObject);
|
||||
var
|
||||
i, j: integer;
|
||||
t: double;
|
||||
|
@ -3,7 +3,7 @@ object RenderForm: TRenderForm
|
||||
Top = 336
|
||||
BorderIcons = [biSystemMenu, biMinimize]
|
||||
BorderStyle = bsSingle
|
||||
Caption = 'RenderForm'
|
||||
Caption = 'Render to Disk'
|
||||
ClientHeight = 449
|
||||
ClientWidth = 434
|
||||
Color = clBtnFace
|
||||
@ -133,7 +133,7 @@ object RenderForm: TRenderForm
|
||||
Width = 137
|
||||
Height = 17
|
||||
Alignment = taLeftJustify
|
||||
Caption = 'Save incomplete render'
|
||||
Caption = 'Save incomplete renders'
|
||||
TabOrder = 8
|
||||
OnClick = chkSaveIncompleteRendersClick
|
||||
end
|
||||
@ -143,9 +143,11 @@ object RenderForm: TRenderForm
|
||||
Width = 433
|
||||
Height = 353
|
||||
ActivePage = TabSettings
|
||||
Images = MainForm.Buttons
|
||||
TabOrder = 9
|
||||
object TabSettings: TTabSheet
|
||||
Caption = 'Settings'
|
||||
ImageIndex = 18
|
||||
object GroupBox5: TGroupBox
|
||||
Left = 8
|
||||
Top = 8
|
||||
@ -542,7 +544,7 @@ object RenderForm: TRenderForm
|
||||
end
|
||||
object TabOutput: TTabSheet
|
||||
Caption = 'Output'
|
||||
ImageIndex = 1
|
||||
ImageIndex = 38
|
||||
object Output: TMemo
|
||||
Left = 8
|
||||
Top = 8
|
||||
|
@ -101,7 +101,6 @@ type
|
||||
oldProg: double;
|
||||
|
||||
ApproxSamples: int64;
|
||||
SaveIncompleteRenders: boolean;
|
||||
|
||||
procedure DoPostProcess;
|
||||
|
||||
@ -129,9 +128,6 @@ type
|
||||
procedure ResetControls;
|
||||
end;
|
||||
|
||||
const
|
||||
ShowRenderStats = true;
|
||||
|
||||
var
|
||||
RenderForm: TRenderForm;
|
||||
Ratio: double;
|
||||
@ -139,7 +135,8 @@ var
|
||||
implementation
|
||||
|
||||
uses
|
||||
Main, Global, SavePreset, formPostProcess, pngimage;
|
||||
Main, Global, SavePreset, formPostProcess, PngImage, ImageMaker,
|
||||
Tracer;
|
||||
|
||||
{$R *.DFM}
|
||||
|
||||
@ -191,39 +188,26 @@ begin
|
||||
)]);
|
||||
end;
|
||||
|
||||
function TimeToString(t: TDateTime): string;
|
||||
var
|
||||
n: integer;
|
||||
procedure Trace2(const str: string);
|
||||
begin
|
||||
n := Trunc(t);
|
||||
Result := '';
|
||||
if n>0 then begin
|
||||
Result := Result + Format(' %d day', [n]);
|
||||
if (n mod 10) <> 1 then Result := Result + 's';
|
||||
end;
|
||||
t := t * 24;
|
||||
n := Trunc(t) mod 24;
|
||||
if n>0 then begin
|
||||
Result := Result + Format(' %d hour', [n]);
|
||||
if (n mod 10) <> 1 then Result := Result + 's';
|
||||
end;
|
||||
t := t * 60;
|
||||
n := Trunc(t) mod 60;
|
||||
if n>0 then begin
|
||||
Result := Result + Format(' %d minute', [n]);
|
||||
if (n mod 10) <> 1 then Result := Result + 's';
|
||||
end;
|
||||
t := t * 60;
|
||||
t := t - (Trunc(t) div 60) * 60;
|
||||
Result := Result + Format(' %.2f seconds', [t]);
|
||||
if TraceLevel >= 2 then
|
||||
RenderForm.Output.Lines.Add('. . ' + str);
|
||||
end;
|
||||
|
||||
procedure TRenderForm.HandleThreadCompletion(var Message: TMessage);
|
||||
var
|
||||
Stats: TBucketStats;
|
||||
begin
|
||||
Trace2(MsgComplete + IntToStr(message.LParam));
|
||||
if not assigned(Renderer) then begin
|
||||
Trace2(MsgNotAssigned);
|
||||
exit;
|
||||
end;
|
||||
if Renderer.ThreadID <> message.LParam then begin
|
||||
Trace2(MsgAnotherRunning);
|
||||
exit;
|
||||
end;
|
||||
|
||||
EndTime := Now;
|
||||
// Output.Lines.Add(TimeToStr(EndTime) + ' : Saving image');
|
||||
|
||||
try
|
||||
Renderer.SaveImage(FileName);
|
||||
except
|
||||
@ -236,26 +220,13 @@ begin
|
||||
else
|
||||
sndPlaySound(pchar(SND_ALIAS_SYSTEMASTERISK), SND_ALIAS_ID or SND_NOSTOP or SND_ASYNC);
|
||||
|
||||
if ShowRenderStats then with Stats do
|
||||
with Output.Lines do
|
||||
begin
|
||||
Add('');
|
||||
Add('Render Statistics:');
|
||||
Add(Format(' Max possible bits: %2.3f', [8 + log2(ApproxSamples)]));
|
||||
Renderer.GetBucketStats(Stats);
|
||||
Add(Format(' Max Red: %2.3f bits (%u)', [log2(MaxR), MaxR]));
|
||||
Add(Format(' Max Green: %2.3f bits (%u)', [log2(MaxG), MaxG]));
|
||||
Add(Format(' Max Blue: %2.3f bits (%u)', [log2(MaxB), MaxB]));
|
||||
Add(Format(' Max Count: %2.3f bits (%u)', [log2(MaxA), MaxA]));
|
||||
Add(Format(' Point hit ratio: %2.2f%%', [100.0*(TotalA/TotalSamples)]));
|
||||
if RenderTime > 0 then // hmm
|
||||
Add(Format(' Average speed: %n points per second', [TotalSamples / (RenderTime * 24 * 60 * 60)]));
|
||||
Add(' Rendering time:' + TimeToString(RenderTime));
|
||||
Add(' Total time:' + TimeToString(EndTime - StartTime));
|
||||
end;
|
||||
|
||||
Output.Lines.Add('');
|
||||
PageCtrl.TabIndex := 1;
|
||||
if ShowRenderStats then
|
||||
Renderer.ShowBigStats
|
||||
else
|
||||
Renderer.ShowSmallStats;
|
||||
Output.Lines.Add(' Total time:' + TimeToString(EndTime - StartTime));
|
||||
Output.Lines.Add('');
|
||||
|
||||
if not chkLimitMem.Checked and cbPostProcess.checked then
|
||||
DoPostProcess;
|
||||
@ -269,8 +240,16 @@ end;
|
||||
|
||||
procedure TRenderForm.HandleThreadTermination(var Message: TMessage);
|
||||
begin
|
||||
if Assigned(Renderer) then
|
||||
begin
|
||||
Trace2(MsgTerminated + IntToStr(message.LParam));
|
||||
if not assigned(Renderer) then begin
|
||||
Trace2(MsgNotAssigned);
|
||||
exit;
|
||||
end;
|
||||
if Renderer.ThreadID <> message.LParam then begin
|
||||
Trace2(MsgAnotherRunning);
|
||||
exit;
|
||||
end;
|
||||
|
||||
Output.Lines.Add(TimeToStr(Now) + ' : Rendering terminated!');
|
||||
sndPlaySound(pchar(SND_ALIAS_SYSTEMEXCLAMATION), SND_ALIAS_ID or SND_NOSTOP or SND_ASYNC);
|
||||
(*
|
||||
@ -278,12 +257,12 @@ begin
|
||||
Output.Lines.Add('Saving incomplete image...');
|
||||
Renderer.SaveImage(FileName);
|
||||
end;
|
||||
Output.Lines.Add('');
|
||||
*)
|
||||
Output.Lines.Add('');
|
||||
|
||||
Renderer.Free;
|
||||
Renderer := nil;
|
||||
ResetControls;
|
||||
end;
|
||||
end;
|
||||
|
||||
procedure TRenderForm.OnProgress(prog: double);
|
||||
@ -317,9 +296,6 @@ begin
|
||||
edt := edt + dt;
|
||||
if (edt > 1/24/60/60/2) and (prog > 0) then
|
||||
begin
|
||||
// Remainder := Min(Remainder, Elapsed * (power(1 / prog, 1.2) - 1)); // --Z-- this power() is weird
|
||||
// Remaining := Elapsed/prog - Elapsed; // --Z-- should've been like this maybe? ;) too easy anyway...
|
||||
|
||||
Remaining := (1 - prog) * edt / (prog - oldProg);
|
||||
edt := 0;
|
||||
oldProg := prog;
|
||||
@ -330,7 +306,6 @@ begin
|
||||
Trunc(Remaining * 24 * 60 * 60) mod 60,
|
||||
Trunc(Remaining * 24 * 60 * 60 * 100) mod 100]);
|
||||
end;
|
||||
|
||||
StatusBar.Panels[2].text := 'Slice ' + IntToStr(Renderer.Slice + 1) + ' of ' + IntToStr(Renderer.nrSlices);
|
||||
end;
|
||||
|
||||
@ -364,8 +339,12 @@ begin
|
||||
|
||||
if (not chkLimitMem.checked) and (ApproxMemory > PhysicalMemory) then
|
||||
begin
|
||||
Application.MessageBox('You do not have enough memory for this render. Please use memory limiting.', 'Apophysis', 48);
|
||||
exit;
|
||||
//Application.MessageBox('You do not have enough memory for this render. Please use memory limiting.', 'Apophysis', 48);
|
||||
if Application.MessageBox('There is not enough memory for this render. ' +
|
||||
'You can use memory limiting, or if you are sure that your system has this much RAM, ' +
|
||||
'you can try to allocate memory anyway. ' +
|
||||
'Dou you want to try? (USE ON YOUR OWN RISK!!!)', 'Apophysis',
|
||||
MB_YESNO) <> IDYES then exit;
|
||||
end;
|
||||
if chkLimitMem.checked and (PhysicalMemory < StrToInt(cbMaxMemory.text)) and (Approxmemory > PhysicalMemory) then begin
|
||||
Application.MessageBox('You do not have enough memory for this render. Please use a lower Maximum memory setting.', 'Apophysis', 48);
|
||||
@ -414,10 +393,8 @@ begin
|
||||
end;
|
||||
if chkLimitMem.checked then
|
||||
begin
|
||||
try
|
||||
MaxMemory := StrToInt(cbMaxMemory.text);
|
||||
if MaxMemory <= 0 then raise Exception.Create('');
|
||||
except
|
||||
MaxMemory := StrToIntDef(cbMaxMemory.text, 0);
|
||||
if MaxMemory * 1024*1024 < ImageWidth * (int64(ImageHeight) * 4 + oversample) then begin
|
||||
Application.MessageBox('Invalid maximum memory value', 'Apophysis', 16);
|
||||
exit;
|
||||
end;
|
||||
@ -442,10 +419,10 @@ begin
|
||||
btnPause.enabled := true;
|
||||
btnCancel.Caption := 'Stop';
|
||||
StartTime := Now;
|
||||
// Remaining := 365;
|
||||
|
||||
PageCtrl.TabIndex := 1;
|
||||
|
||||
if Output.Lines.Count >= 1000 then Output.Lines.Clear;
|
||||
Output.Lines.Add('--- Rendering "' + ExtractFileName(FileName) + '" ---');
|
||||
Output.Lines.Add(Format(' Size: %dx%d', [ImageWidth, ImageHeight]));
|
||||
Output.Lines.Add(Format(' Quality: %g', [sample_density]));
|
||||
@ -462,7 +439,7 @@ begin
|
||||
end;
|
||||
|
||||
if Assigned(Renderer) then begin
|
||||
Output.Lines.Add(TimeToStr(Now) + 'Shutting down previous render...'); // hmm
|
||||
Output.Lines.Add(TimeToStr(Now) + 'Shutting down previous render'); // hmm...?
|
||||
Renderer.Terminate;
|
||||
Renderer.WaitFor;
|
||||
Renderer.Free;
|
||||
@ -517,7 +494,7 @@ procedure TRenderForm.FormShow(Sender: TObject);
|
||||
var
|
||||
Registry: TRegistry;
|
||||
begin
|
||||
{ Read posution from registry }
|
||||
{ Read position from registry }
|
||||
Registry := TRegistry.Create;
|
||||
try
|
||||
Registry.RootKey := HKEY_CURRENT_USER;
|
||||
@ -532,6 +509,7 @@ begin
|
||||
finally
|
||||
Registry.Free;
|
||||
end;
|
||||
|
||||
SaveDialog.FileName := Filename;
|
||||
case renderFileFormat of
|
||||
1: txtFilename.Text := ChangeFileExt(SaveDialog.Filename, '.bmp');
|
||||
@ -540,8 +518,8 @@ begin
|
||||
end;
|
||||
txtOversample.Text := IntToStr(renderOversample);
|
||||
txtFilterRadius.Text := FloatToStr(renderFilterRadius);
|
||||
cbWidth.Text := IntToStr(MainForm.Image.Width);
|
||||
cbHeight.Text := IntToStr(MainForm.Image.Height);
|
||||
cbWidth.Text := IntToStr(cp.Width);
|
||||
cbHeight.Text := IntToStr(cp.Height);
|
||||
ImageWidth := StrToInt(cbWidth.Text);
|
||||
ImageHeight := StrToInt(cbHeight.Text);
|
||||
sample_density := renderDensity;
|
||||
@ -550,6 +528,7 @@ begin
|
||||
cbBitsPerSample.ItemIndex := BitsPerSample;
|
||||
ShowMemoryStatus;
|
||||
Ratio := ImageWidth / ImageHeight;
|
||||
chkSaveIncompleteRenders.Checked := SaveIncompleteRenders;
|
||||
end;
|
||||
|
||||
procedure TRenderForm.txtWidthChange(Sender: TObject);
|
||||
@ -625,7 +604,7 @@ begin
|
||||
end;
|
||||
|
||||
if SaveIncompleteRenders and not ChkLimitMem.Checked then begin
|
||||
Renderer.Break;
|
||||
Renderer.BreakRender;
|
||||
Renderer.WaitFor; //?
|
||||
end
|
||||
else begin
|
||||
@ -639,12 +618,12 @@ begin
|
||||
end;
|
||||
|
||||
procedure TRenderForm.txtDensityChange(Sender: TObject);
|
||||
var
|
||||
t: double;
|
||||
begin
|
||||
try
|
||||
Sample_Density := StrToFloat(txtDensity.Text);
|
||||
except
|
||||
end;
|
||||
ShowMemoryStatus;
|
||||
if TryStrToFloat(txtDensity.Text, t) then
|
||||
Sample_Density := t;
|
||||
if Sample_Density > 0 then ShowMemoryStatus;
|
||||
end;
|
||||
|
||||
procedure TRenderForm.txtFilterRadiusChange(Sender: TObject);
|
||||
@ -785,6 +764,7 @@ var
|
||||
i, p: integer;
|
||||
Title: string;
|
||||
FStrings: TStringList;
|
||||
f: textfile;
|
||||
begin
|
||||
FStrings := TStringList.Create;
|
||||
try
|
||||
|
@ -43,10 +43,6 @@ type
|
||||
|
||||
procedure CreateFilter;
|
||||
procedure NormalizeFilter;
|
||||
procedure SetOnProgress(const Value: TOnProgress);
|
||||
|
||||
procedure Progress(value: double);
|
||||
|
||||
|
||||
public
|
||||
constructor Create;
|
||||
@ -68,7 +64,7 @@ type
|
||||
|
||||
property OnProgress: TOnProgress
|
||||
read FOnProgress
|
||||
write SetOnProgress;
|
||||
write FOnProgress;
|
||||
end;
|
||||
|
||||
implementation
|
||||
@ -234,12 +230,6 @@ begin
|
||||
Fcp := CP;
|
||||
end;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
procedure TImageMaker.SetOnProgress(const Value: TOnProgress);
|
||||
begin
|
||||
FOnProgress := Value;
|
||||
end;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
procedure TImageMaker.CreateImage(YOffset: integer);
|
||||
var
|
||||
@ -313,7 +303,9 @@ begin
|
||||
by := 0;
|
||||
for i := 0 to fcp.Height - 1 do begin
|
||||
bx := 0;
|
||||
Progress(i / fcp.Height);
|
||||
|
||||
if (i and $7 = 0) and assigned(FOnProgress) then FOnProgress(i / fcp.Height);
|
||||
|
||||
AlphaRow := PByteArray(FAlphaBitmap.scanline[YOffset + i]);
|
||||
Row := PRGBArray(FBitmap.scanline[YOffset + i]);
|
||||
for j := 0 to fcp.Width - 1 do begin
|
||||
@ -451,7 +443,7 @@ zero_alpha:
|
||||
|
||||
FBitmap.PixelFormat := pf24bit;
|
||||
|
||||
Progress(1);
|
||||
if assigned(FOnProgress) then FOnProgress(1);
|
||||
end;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
@ -520,13 +512,6 @@ BMPHack:
|
||||
end;
|
||||
end;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
procedure TImageMaker.Progress(value: double);
|
||||
begin
|
||||
if assigned(FOnprogress) then
|
||||
FOnprogress(Value);
|
||||
end;
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
function TImageMaker.GetTransparentImage: TPngObject;
|
||||
var
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,5 +1,6 @@
|
||||
{
|
||||
Apophysis Copyright (C) 2001-2004 Mark Townsend
|
||||
Apophysis Copyright (C) 2005-2006 Ronald Hordijk, Piotr Borys, Peter Sdobnov
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
|
Loading…
Reference in New Issue
Block a user