284 lines
9.2 KiB
ObjectPascal
284 lines
9.2 KiB
ObjectPascal
{
|
|
Apophysis Copyright (C) 2001-2004 Mark Townsend
|
|
Apophysis Copyright (C) 2005-2006 Ronald Hordijk, Piotr Borys, Peter Sdobnov
|
|
Apophysis Copyright (C) 2007-2008 Piotr Borys, Peter Sdobnov
|
|
|
|
Apophysis "3D hack" Copyright (C) 2007-2008 Peter Sdobnov
|
|
Apophysis "7X" Copyright (C) 2009-2010 Georg Kiehne
|
|
Apophysis AV "Phoenix Edition" Copyright (C) 2021-2022 Alice V. Koryagina
|
|
|
|
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
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
}
|
|
unit FormExport;
|
|
|
|
interface
|
|
|
|
uses
|
|
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
|
|
StdCtrls, Buttons, ComCtrls, ExtCtrls;
|
|
|
|
type
|
|
TExportDialog = class(TForm)
|
|
btnOK: TButton;
|
|
btnCancel: TButton;
|
|
GroupBox1: TGroupBox;
|
|
btnBrowse: TSpeedButton;
|
|
txtFilename: TEdit;
|
|
SaveDialog: TSaveDialog;
|
|
GroupBox3: TGroupBox;
|
|
txtOversample: TEdit;
|
|
txtFilterRadius: TEdit;
|
|
txtDensity: TEdit;
|
|
udOversample: TUpDown;
|
|
GroupBox2: TGroupBox;
|
|
chkMaintain: TCheckBox;
|
|
cbWidth: TComboBox;
|
|
cbHeight: TComboBox;
|
|
GroupBox4: TGroupBox;
|
|
cmbDepth: TComboBox;
|
|
chkRender: TCheckBox;
|
|
txtStrips: TEdit;
|
|
udStrips: TUpDown;
|
|
txtEstimator: TEdit;
|
|
txtEstimatorMin: TEdit;
|
|
txtEstimatorCurve: TEdit;
|
|
txtGammaTreshold: TEdit;
|
|
Panel1: TPanel;
|
|
Label6: TLabel;
|
|
Label15: TLabel;
|
|
Label4: TPanel;
|
|
Label5: TPanel;
|
|
Label3: TPanel;
|
|
Label1: TPanel;
|
|
Label2: TPanel;
|
|
Label7: TPanel;
|
|
Label8: TPanel;
|
|
Label9: TPanel;
|
|
Label14: TPanel;
|
|
Label12: TPanel;
|
|
Label11: TPanel;
|
|
Label10: TPanel;
|
|
lblFlam3Link: TLabel;
|
|
procedure Panel1Resize(Sender: TObject);
|
|
procedure FormCreate(Sender: TObject);
|
|
procedure btnBrowseClick(Sender: TObject);
|
|
procedure FormShow(Sender: TObject);
|
|
procedure btnOKClick(Sender: TObject);
|
|
procedure txtWidthChange(Sender: TObject);
|
|
procedure chkMaintainClick(Sender: TObject);
|
|
procedure txtHeightChange(Sender: TObject);
|
|
procedure txtDensityChange(Sender: TObject);
|
|
procedure txtFilterRadiusChange(Sender: TObject);
|
|
procedure txtOversampleChange(Sender: TObject);
|
|
procedure txtEstimatorChange(Sender: TObject);
|
|
procedure txtEstimatorMinChange(Sender: TObject);
|
|
procedure txtEstimatorCurveChange(Sender: TObject);
|
|
procedure txtGammaTresholdChange(Sender: TObject);
|
|
procedure lblFlam3LinkClick(Sender: TObject);
|
|
private
|
|
FloatFormatSettings: TFormatSettings;
|
|
public
|
|
Filename: string;
|
|
ImageWidth, ImageHeight, Oversample: Integer;
|
|
Sample_Density, Filter_Radius: double;
|
|
Estimator, EstimatorMin, EstimatorCurve: double;
|
|
GammaTreshold: double;
|
|
// Batches, Jitters: Integer;
|
|
end;
|
|
|
|
var
|
|
ExportDialog: TExportDialog;
|
|
Ratio: double;
|
|
|
|
implementation
|
|
|
|
uses Global, Main, ShellAPI, Translation;
|
|
|
|
{$R *.DFM}
|
|
|
|
procedure TExportDialog.btnBrowseClick(Sender: TObject);
|
|
begin
|
|
SaveDialog.InitialDir := ExtractFileDir(txtFilename.text);
|
|
SaveDialog.Filename := txtFilename.Text;
|
|
case ExportFileFormat of // AV: fixed
|
|
1: SaveDialog.DefaultExt := 'jpg';
|
|
2: SaveDialog.DefaultExt := 'ppm';
|
|
3: SaveDialog.DefaultExt := 'png';
|
|
end;
|
|
SaveDialog.FilterIndex := ExportFileFormat;
|
|
if SaveDialog.Execute then
|
|
begin
|
|
case SaveDialog.FilterIndex of
|
|
1: txtFilename.Text := ChangeFileExt(SaveDialog.Filename, '.jpg');
|
|
2: txtFilename.Text := ChangeFileExt(SaveDialog.Filename, '.ppm');
|
|
3: txtFilename.Text := ChangeFileExt(SaveDialog.Filename, '.png');
|
|
end;
|
|
ExportFileFormat := SaveDialog.FilterIndex;
|
|
renderPath := ExtractFilePath(SaveDialog.Filename);
|
|
end;
|
|
|
|
end;
|
|
|
|
procedure TExportDialog.FormShow(Sender: TObject);
|
|
begin
|
|
txtFilename.Text := Filename;
|
|
cbWidth.Text := IntToStr(MainCp.Width);
|
|
cbHeight.Text := IntToStr(MainCp.Height);
|
|
ImageWidth := MainCp.Width;
|
|
ImageHeight := MainCp.Height;
|
|
txtDensity.text := FloatToStr(Sample_density);
|
|
txtFilterRadius.text := FloatToStr(Filter_Radius);
|
|
txtOversample.text := IntToSTr(Oversample);
|
|
udOversample.Position := Oversample;
|
|
Ratio := ImageWidth / ImageHeight;
|
|
//Batches := 1;
|
|
//Jitters := 1;
|
|
Estimator := 9.0;
|
|
EstimatorMin := 0.0;
|
|
EstimatorCurve := 0.4;
|
|
GammaTreshold := MainCP.gamma_threshold; //0.01;
|
|
GetLocaleFormatSettings(LOCALE_SYSTEM_DEFAULT, FloatFormatSettings);
|
|
txtEstimator.Text := FloatToStr(Estimator, FloatFormatSettings);
|
|
txtEstimatorMin.Text := FloatToStr(EstimatorMin, FloatFormatSettings);
|
|
txtEstimatorCurve.Text := FloatToStr(EstimatorCurve, FloatFormatSettings);
|
|
txtGammaTreshold.Text := FloatToStr(GammaTreshold, FloatFormatSettings);
|
|
end;
|
|
|
|
procedure TExportDialog.btnOKClick(Sender: TObject);
|
|
begin
|
|
Filename := txtFilename.text;
|
|
ImageWidth := StrToInt(cbWidth.Text);
|
|
ImageHeight := StrToInt(cbHeight.Text);
|
|
end;
|
|
|
|
procedure TExportDialog.txtWidthChange(Sender: TObject);
|
|
begin
|
|
try
|
|
ImageWidth := StrToInt(cbWidth.Text);
|
|
if chkMaintain.checked and cbWidth.Focused then
|
|
begin
|
|
ImageHeight := Round(ImageWidth / ratio);
|
|
cbHeight.Text := IntToStr(ImageHeight)
|
|
end;
|
|
except
|
|
end;
|
|
end;
|
|
|
|
procedure TExportDialog.chkMaintainClick(Sender: TObject);
|
|
begin
|
|
Ratio := ImageWidth / ImageHeight;
|
|
end;
|
|
|
|
procedure TExportDialog.txtHeightChange(Sender: TObject);
|
|
begin
|
|
try
|
|
ImageHeight := StrToInt(cbHeight.Text);
|
|
if chkMaintain.checked and cbHeight.Focused then
|
|
begin
|
|
ImageWidth := Round(ImageHeight * ratio);
|
|
cbWidth.Text := IntToStr(ImageWidth)
|
|
end;
|
|
except
|
|
end;
|
|
end;
|
|
|
|
procedure TExportDialog.txtDensityChange(Sender: TObject);
|
|
begin
|
|
Sample_Density := StrToFloatDef(txtDensity.Text, 200);
|
|
end;
|
|
|
|
procedure TExportDialog.txtFilterRadiusChange(Sender: TObject);
|
|
begin
|
|
Filter_Radius := StrToFloatDef(txtFilterRadius.Text, 0.04);
|
|
end;
|
|
|
|
procedure TExportDialog.txtOversampleChange(Sender: TObject);
|
|
begin
|
|
if StrToInt(txtOversample.Text) > udOversample.Max then
|
|
txtOversample.Text := IntToStr(udOversample.Max);
|
|
if StrToInt(txtOversample.Text) < udOversample.Min then
|
|
txtOversample.Text := IntToStr(udOversample.Min);
|
|
|
|
Oversample := StrToIntDef(txtOversample.Text, 2);
|
|
end;
|
|
|
|
procedure TExportDialog.txtEstimatorChange(Sender: TObject);
|
|
begin
|
|
Estimator := 0;
|
|
Estimator := StrToFloatDef(txtEstimator.Text, 0, FloatFormatSettings);
|
|
end;
|
|
|
|
procedure TExportDialog.txtEstimatorMinChange(Sender: TObject);
|
|
begin
|
|
EstimatorMin := 0;
|
|
EstimatorMin := StrToFloatDef(txtEstimatorMin.Text, 0, FloatFormatSettings);
|
|
end;
|
|
|
|
procedure TExportDialog.txtEstimatorCurveChange(Sender: TObject);
|
|
begin
|
|
EstimatorCurve := 0;
|
|
EstimatorCurve := StrToFloatDef(txtEstimatorCurve.Text, 0, FloatFormatSettings);
|
|
end;
|
|
|
|
procedure TExportDialog.txtGammaTresholdChange(Sender: TObject);
|
|
begin
|
|
GammaTreshold := StrToFloatDef(txtGammaTreshold.Text, 0.01, FloatFormatSettings);
|
|
end;
|
|
|
|
procedure TExportDialog.lblFlam3LinkClick(Sender: TObject);
|
|
begin
|
|
ShellExecute(ValidParentForm(Self).Handle, 'open', PChar(TLabel(Sender).Hint),
|
|
nil, nil, SW_SHOWNORMAL);
|
|
end;
|
|
|
|
procedure TExportDialog.FormCreate(Sender: TObject);
|
|
begin
|
|
btnOK.Caption := TextByKey('common-ok');
|
|
btnCancel.Caption := TextByKey('common-cancel');
|
|
Label1.Caption := TextByKey('common-width');
|
|
Label2.Caption := TextByKey('common-height');
|
|
GroupBox2.Caption := TextByKey('common-size');
|
|
chkMaintain.Caption := TextByKey('common-keepaspect');
|
|
GroupBox1.Caption := TextByKey('common-destination');
|
|
Label10.Caption := TextByKey('common-filename');
|
|
btnBrowse.Hint := TextByKey('common-browse');
|
|
GroupBox3.Caption := TextByKey('common-quality');
|
|
Label5.Caption := TextByKey('common-filterradius');
|
|
Label4.Caption := TextByKey('common-density');
|
|
Label3.Caption := TextByKey('common-oversample');
|
|
Label14.Caption := TextByKey('common-gammathreshold');
|
|
self.Caption := TextByKey('main-menu-file-exportflame');
|
|
GroupBox4.Caption := TextByKey('export-paramoptions-title');
|
|
Label7.Caption := TextByKey('export-paramoptions-bufferdepth');
|
|
Label8.Caption := TextByKey('export-paramoptions-strips');
|
|
Label9.Caption := TextByKey('export-paramoptions-estimatorradius');
|
|
Label12.Caption := TextByKey('export-paramoptions-estimatorcurve');
|
|
Label11.Caption := TextByKey('export-paramoptions-estimatormin');
|
|
chkRender.Caption := TextByKey('export-paramoptions-dorender');
|
|
Label6.Caption := TextByKey('export-paramoptions-warningtitle');
|
|
Label15.Caption := TextByKey('export-paramoptions-warningtext');
|
|
// AV: fixed the order and moved here here since the filter never changes
|
|
SaveDialog.Filter := Format('%s|*.jpg;*.jpeg|Portable Pixmap (*.ppm)|*.ppm|%s|*.png',
|
|
[TextByKey('common-filter-jpeg'), TextByKey('common-filter-png')]);
|
|
end;
|
|
|
|
procedure TExportDialog.Panel1Resize(Sender: TObject);
|
|
begin
|
|
Label15.Top := (Panel1.Height - 30) div 2 - Label15.Height div 2 + 25;
|
|
end;
|
|
|
|
end.
|
|
|