** Date Started: July 2000
**
** This is part of the CTSim program
-** Copyright (C) 1983-2000 Kevin Rosenberg
+** Copyright (c) 1983-2001 Kevin Rosenberg
**
-** $Id: dialogs.h,v 1.18 2001/01/02 05:34:57 kevin Exp $
+** $Id: dialogs.h,v 1.29 2001/02/22 00:56:50 kevin Exp $
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License (version 2) as
#include "scanner.h"
#include "phantom.h"
#include "procsignal.h"
-#include "filter.h"\r
+#include "filter.h"
+#include "projections.h"
+
+
+class CTSimHelpButton : public wxButton
+{
+public:
+ CTSimHelpButton (wxWindow* parent, int id)
+ : wxButton (parent, id, "Help")
+ {}
+};
// CLASS StringValueAndTitleListBox
};
+class StringValueAndTitleRadioBox : public wxRadioBox
+{
+ public:
+ StringValueAndTitleRadioBox (wxDialog* pParent, const wxString& strTitle, int nChoices, const char* aszTitle[], const char* aszValue[]);
+
+ const char* getSelectionStringValue () const;
+
+ private:
+ const char** m_ppszValues;
+};
+
+
class DialogGetPhantom : public wxDialog
{
public:
- DialogGetPhantom (wxFrame* pParent, int iDefaultPhantom = Phantom::PHM_HERMAN);
+ DialogGetPhantom (wxWindow* pParent, int iDefaultPhantom = Phantom::PHM_HERMAN);
virtual ~DialogGetPhantom () {}
const char* getPhantom ();
private:
- StringValueAndTitleListBox* m_pListBoxPhantom;
+ StringValueAndTitleRadioBox* m_pRadioBoxPhantom;
+};
+
+
+#include <vector>
+class ImageFileDocument;
+class DialogGetComparisonImage : public wxDialog
+{
+ public:
+ DialogGetComparisonImage (wxWindow* pParent, const char* const pszTitle, const std::vector<ImageFileDocument*>& rVecIF, bool bShowMakeDifference);
+ virtual ~DialogGetComparisonImage () {}
+
+ ImageFileDocument* getImageFileDocument ();
+
+ bool getMakeDifferenceImage();
+
+ private:
+ wxListBox* m_pListBoxImageChoices;
+ wxCheckBox* m_pMakeDifferenceImage;
+ const std::vector<ImageFileDocument*>& m_rVecIF;
+};
+
+
+class DialogPreferences : public wxDialog
+{
+ public:
+ DialogPreferences (wxWindow* pParent, const char* const pszTitle, bool bAdvanced, bool bAskNewDocs,
+ bool bVerboseLogging, bool bStartupTips);
+ virtual ~DialogPreferences ();
+
+ bool getAdvancedOptions ();
+ bool getAskDeleteNewDocs ();
+ bool getVerboseLogging ();
+ bool getStartupTips ();
+
+ private:
+ wxCheckBox* m_pCBAdvancedOptions;
+ wxCheckBox* m_pCBAskDeleteNewDocs;
+ wxCheckBox* m_pCBVerboseLogging;
+ wxCheckBox* m_pCBStartupTips;
};
-\r
-\r
-#include <vector>\r
-class ImageFileDocument;\r
-class DialogGetComparisonImage : public wxDialog\r
-{\r
- public:\r
- DialogGetComparisonImage (wxFrame* pParent, const char* const pszTitle, const std::vector<ImageFileDocument*>& rVecIF, bool bShowMakeDifference);\r
- virtual ~DialogGetComparisonImage () {}\r
-\r
- ImageFileDocument* getImageFileDocument ();\r
-\r
- bool getMakeDifferenceImage();\r
-\r
- private:\r
- wxListBox* m_pListBoxImageChoices;\r
- wxCheckBox* m_pMakeDifferenceImage;\r
- const std::vector<ImageFileDocument*>& m_rVecIF;\r
-};\r
-\r
+
class ImageFile;
class DialogGetMinMax : public wxDialog
{
public:
- DialogGetMinMax (wxFrame* pParent, const char* const pszTitle, double dDefaultMin = 0., double dDefaultMax = 0.);
+ DialogGetMinMax (wxWindow* pParent, const char* const pszTitle, double dDefaultMin = 0., double dDefaultMax = 0.);
virtual ~DialogGetMinMax ();
double getMinimum ();
class DialogGetRasterParameters : public wxDialog
{
public:
- DialogGetRasterParameters (wxFrame* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0, int iDefaultNSamples = 1);
+ DialogGetRasterParameters (wxWindow* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0,
+ int iDefaultNSamples = 1, double dDefaultViewRatio = 1);
virtual ~DialogGetRasterParameters ();
unsigned int getXSize ();
unsigned int getYSize ();
unsigned int getNSamples ();
+ double getViewRatio();
private:
wxTextCtrl* m_pTextCtrlXSize;
wxTextCtrl* m_pTextCtrlYSize;
wxTextCtrl* m_pTextCtrlNSamples;
+ wxTextCtrl* m_pTextCtrlViewRatio;
int m_iDefaultXSize;
int m_iDefaultYSize;
int m_iDefaultNSamples;
+ double m_dDefaultViewRatio;
};
class DialogGetProjectionParameters : public wxDialog
{
public:
- DialogGetProjectionParameters (wxFrame* pParent, int iDefaultNDet = 0, int iDefaultNView = 0, int iDefaultNSamples = 1, double dDefaultRotAngle = 1., double dDefaultFocalLength = 1, double dDefaultFieldOfView = 1., int iDefaultGeometry = Scanner::GEOMETRY_PARALLEL, int iDefaultTrace = Trace::TRACE_NONE);
+ DialogGetProjectionParameters (wxWindow* pParent, int iDefaultNDet = 0,
+ int iDefaultNView = 0, int iDefaultNSamples = 1, double dDefaultRotAngle = 1.,
+ double dDefaultFocalLength = 1, double dDefaultViewRatio = 1.,
+ double dDefaultScanRatio = 1., int iDefaultGeometry = Scanner::GEOMETRY_PARALLEL, int iDefaultTrace = Trace::TRACE_NONE);
~DialogGetProjectionParameters ();
unsigned int getNDet ();
int getTrace ();
double getRotAngle ();
- double getFieldOfViewRatio ();
+ double getViewRatio ();
+ double getScanRatio ();
double getFocalLengthRatio ();
const char* getGeometry();
wxTextCtrl* m_pTextCtrlNSamples;
wxTextCtrl* m_pTextCtrlRotAngle;
wxTextCtrl* m_pTextCtrlFocalLength;
- wxTextCtrl* m_pTextCtrlFieldOfView;
-
- StringValueAndTitleListBox* m_pListBoxGeometry;
- StringValueAndTitleListBox* m_pListBoxTrace;
+ wxTextCtrl* m_pTextCtrlViewRatio;
+ wxTextCtrl* m_pTextCtrlScanRatio;
+ StringValueAndTitleRadioBox* m_pRadioBoxGeometry;
+ StringValueAndTitleRadioBox* m_pRadioBoxTrace;
int m_iDefaultNDet;
int m_iDefaultNView;
int m_iDefaultGeometry;
double m_dDefaultRotAngle;
double m_dDefaultFocalLength;
- double m_dDefaultFieldOfView;
+ double m_dDefaultViewRatio;
+ double m_dDefaultScanRatio;
};
#include "backprojectors.h"
-class DialogGetReconstructionParameters : public wxDialog\r
-{\r
- public:\r
- DialogGetReconstructionParameters (wxFrame* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0, int iDefaultFilterID = SignalFilter::FILTER_ABS_BANDLIMIT, double dDefaultFilterParam = 1., int iDefaultFilterMethodID = ProcessSignal::FILTER_METHOD_CONVOLUTION, int iDefaultFilterGeneration = ProcessSignal::FILTER_GENERATION_INVALID, int iDefaultZeropad = 3, int iDefaultInterpID = Backprojector::INTERP_LINEAR, int iDefaultInterpParam = 1, int iDefaultBackprojectID = Backprojector::BPROJ_IDIFF3, int iDefaultTrace = Trace::TRACE_NONE);\r
- virtual ~DialogGetReconstructionParameters ();\r
-\r
- unsigned int getXSize();\r
- unsigned int getYSize();\r
- const char* getFilterName();\r
- double getFilterParam();\r
- const char* getFilterMethodName();\r
- unsigned int getZeropad();\r
- const char* getFilterGenerationName();\r
- const char* getInterpName();\r
- unsigned int getInterpParam();\r
- const char* getBackprojectName();\r
- int getTrace ();\r
-\r
- private:\r
- wxTextCtrl* m_pTextCtrlXSize;\r
- wxTextCtrl* m_pTextCtrlYSize;\r
- wxTextCtrl* m_pTextCtrlZeropad;\r
- wxTextCtrl* m_pTextCtrlFilterParam;\r
- wxTextCtrl* m_pTextCtrlInterpParam;\r
-\r
- StringValueAndTitleListBox* m_pListBoxFilter;\r
- StringValueAndTitleListBox* m_pListBoxFilterMethod;\r
- StringValueAndTitleListBox* m_pListBoxFilterGeneration;\r
- StringValueAndTitleListBox* m_pListBoxInterp;\r
- StringValueAndTitleListBox* m_pListBoxBackproject;\r
- StringValueAndTitleListBox* m_pListBoxTrace;\r
-\r
- int m_iDefaultXSize;\r
- int m_iDefaultYSize;\r
- double m_dDefaultFilterParam;\r
- int m_iDefaultZeropad;\r
- int m_iDefaultInterpParam;\r
- int m_iDefaultTrace;\r
-};\r
-\r
-
-class DialogGetFilterParameters : public wxDialog\r
-{\r
- public:\r
- DialogGetFilterParameters (wxFrame* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0, int iDefaultFilterID = SignalFilter::FILTER_BANDLIMIT, double dDefaultFilterParam = 1., double dDefaultBandwidth = 1., int iDefaultDomain = SignalFilter::DOMAIN_SPATIAL, double dDefaultInputScale = 1., double dDefaultOutputScale = 1.);\r
- virtual ~DialogGetFilterParameters ();\r
-\r
- unsigned int getXSize();\r
- unsigned int getYSize();\r
- const char* getFilterName();\r
- const char* getDomainName();\r
- double getFilterParam();\r
- double getInputScale();\r
- double getOutputScale();\r
- double getBandwidth();\r
-\r
- private:\r
- wxTextCtrl* m_pTextCtrlXSize;\r
- wxTextCtrl* m_pTextCtrlYSize;\r
- wxTextCtrl* m_pTextCtrlFilterParam;\r
- wxTextCtrl* m_pTextCtrlOutputScale;\r
- wxTextCtrl* m_pTextCtrlInputScale;\r
- wxTextCtrl* m_pTextCtrlBandwidth;\r
-\r
- StringValueAndTitleListBox* m_pListBoxFilter;\r
- StringValueAndTitleListBox* m_pListBoxDomain;\r
-\r
- int m_iDefaultXSize;\r
- int m_iDefaultYSize;\r
- double m_dDefaultFilterParam;\r
- double m_dDefaultBandwidth;\r
- double m_dDefaultOutputScale;\r
- double m_dDefaultInputScale;\r
- int m_iDefaultDomain;\r
-};\r
-\r
-class DialogExportParameters : public wxDialog\r
-{\r
- public:\r
- DialogExportParameters (wxFrame* pParent, int iDefaultFormatID);\r
- virtual ~DialogExportParameters () {}\r
-\r
- const char* getFormatName();\r
-\r
- private:\r
- StringValueAndTitleListBox* m_pListBoxFormat;\r
-};\r
-\r
+class DialogGetReconstructionParameters : public wxDialog
+{
+ public:
+ DialogGetReconstructionParameters (wxWindow* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0,
+ int iDefaultFilterID = SignalFilter::FILTER_ABS_BANDLIMIT, double dDefaultFilterParam = 1.,
+ int iDefaultFilterMethodID = ProcessSignal::FILTER_METHOD_CONVOLUTION,
+ int iDefaultFilterGeneration = ProcessSignal::FILTER_GENERATION_DIRECT,
+ int iDefaultZeropad = 3, int iDefaultInterpID = Backprojector::INTERP_LINEAR,
+ int iDefaultInterpParam = 1, int iDefaultBackprojectID = Backprojector::BPROJ_IDIFF,
+ int iDefaultTrace = Trace::TRACE_NONE);
+ virtual ~DialogGetReconstructionParameters ();
+
+ unsigned int getXSize();
+ unsigned int getYSize();
+ const char* getFilterName();
+ double getFilterParam();
+ const char* getFilterMethodName();
+ unsigned int getZeropad();
+ const char* getFilterGenerationName();
+ const char* getInterpName();
+ unsigned int getInterpParam();
+ const char* getBackprojectName();
+ int getTrace ();
+
+ private:
+ wxTextCtrl* m_pTextCtrlXSize;
+ wxTextCtrl* m_pTextCtrlYSize;
+ wxTextCtrl* m_pTextCtrlZeropad;
+ wxTextCtrl* m_pTextCtrlFilterParam;
+ wxTextCtrl* m_pTextCtrlInterpParam;
+
+ StringValueAndTitleRadioBox* m_pRadioBoxFilter;
+ StringValueAndTitleRadioBox* m_pRadioBoxFilterMethod;
+ StringValueAndTitleRadioBox* m_pRadioBoxFilterGeneration;
+ StringValueAndTitleRadioBox* m_pRadioBoxInterp;
+ StringValueAndTitleRadioBox* m_pRadioBoxBackproject;
+ StringValueAndTitleRadioBox* m_pRadioBoxTrace;
+
+ int m_iDefaultXSize;
+ int m_iDefaultYSize;
+ double m_dDefaultFilterParam;
+ int m_iDefaultZeropad;
+ int m_iDefaultInterpParam;
+ int m_iDefaultTrace;
+};
+
+
+class DialogGetFilterParameters : public wxDialog
+{
+ public:
+ DialogGetFilterParameters (wxWindow* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0, int iDefaultFilterID = SignalFilter::FILTER_BANDLIMIT, double dDefaultFilterParam = 1., double dDefaultBandwidth = 1., int iDefaultDomain = SignalFilter::DOMAIN_SPATIAL, double dDefaultInputScale = 1., double dDefaultOutputScale = 1.);
+ virtual ~DialogGetFilterParameters ();
+
+ unsigned int getXSize();
+ unsigned int getYSize();
+ const char* getFilterName();
+ const char* getDomainName();
+ double getFilterParam();
+ double getInputScale();
+ double getOutputScale();
+ double getBandwidth();
+
+ private:
+ wxTextCtrl* m_pTextCtrlXSize;
+ wxTextCtrl* m_pTextCtrlYSize;
+ wxTextCtrl* m_pTextCtrlFilterParam;
+ wxTextCtrl* m_pTextCtrlOutputScale;
+ wxTextCtrl* m_pTextCtrlInputScale;
+ wxTextCtrl* m_pTextCtrlBandwidth;
+
+ StringValueAndTitleRadioBox* m_pRadioBoxFilter;
+ StringValueAndTitleRadioBox* m_pRadioBoxDomain;
+
+ int m_iDefaultXSize;
+ int m_iDefaultYSize;
+ double m_dDefaultFilterParam;
+ double m_dDefaultBandwidth;
+ double m_dDefaultOutputScale;
+ double m_dDefaultInputScale;
+ int m_iDefaultDomain;
+};
+
+class DialogExportParameters : public wxDialog
+{
+ public:
+ DialogExportParameters (wxWindow* pParent, int iDefaultFormatID);
+ virtual ~DialogExportParameters () {}
+
+ const char* getFormatName();
+
+ private:
+ StringValueAndTitleRadioBox* m_pRadioBoxFormat;
+};
+
class DialogAutoScaleParameters : public wxDialog
{
public:
- DialogAutoScaleParameters (wxFrame* pParent, double mean, double mode, double median, double stddev, double dDefaultScaleFactor = 1.);
+ DialogAutoScaleParameters (wxWindow* pParent, double mean, double mode, double median, double stddev, double dDefaultScaleFactor = 1.);
virtual ~DialogAutoScaleParameters() {}
bool getMinMax (double* pMin, double* pMax);
double getAutoScaleFactor ();
private:
- const double m_dMean;\r
+ const double m_dMean;
const double m_dMode;
- const double m_dMedian;\r
- const double m_dStdDev;\r
+ const double m_dMedian;
+ const double m_dStdDev;
wxTextCtrl* m_pTextCtrlStdDevFactor;
- wxListBox* m_pListBoxCenter;
+ wxRadioBox* m_pRadioBoxCenter;
+};
+
+class DialogGetXYSize : public wxDialog
+{
+ public:
+ DialogGetXYSize (wxWindow* pParent, const char* const pszTitle, int iDefaultXSize = 1, int iDefaultYSize = 1);
+ virtual ~DialogGetXYSize ();
+
+ unsigned int getXSize ();
+ unsigned int getYSize ();
+
+ private:
+ wxTextCtrl* m_pTextCtrlXSize;
+ wxTextCtrl* m_pTextCtrlYSize;
+
+ unsigned int m_iDefaultXSize;
+ unsigned int m_iDefaultYSize;
};
-\r
-class DialogGetXYSize : public wxDialog\r
-{\r
- public:\r
- DialogGetXYSize (wxFrame* pParent, const char* const pszTitle, int iDefaultXSize = 1, int iDefaultYSize = 1);\r
- virtual ~DialogGetXYSize ();\r
-\r
- unsigned int getXSize ();\r
- unsigned int getYSize ();\r
-\r
- private:\r
- wxTextCtrl* m_pTextCtrlXSize;\r
- wxTextCtrl* m_pTextCtrlYSize;\r
-\r
- unsigned int m_iDefaultXSize;\r
- unsigned int m_iDefaultYSize;\r
-};\r
-\r
+
+
+class DialogGetConvertPolarParameters : public wxDialog
+{
+ public:
+ DialogGetConvertPolarParameters (wxWindow* pParent, const char* const pszTitle, int iDefaultXSize = 0,
+ int iDefaultYSize = 0, int iDefaultInterpolationID = Projections::POLAR_INTERP_BILINEAR,
+ int iDefaultZeropad = 1);
+ virtual ~DialogGetConvertPolarParameters ();
+
+ unsigned int getXSize();
+ unsigned int getYSize();
+ const char* getInterpolationName();
+ unsigned int getZeropad();
+
+ private:
+ wxTextCtrl* m_pTextCtrlXSize;
+ wxTextCtrl* m_pTextCtrlYSize;
+ wxTextCtrl* m_pTextCtrlZeropad;
+
+ StringValueAndTitleRadioBox* m_pRadioBoxInterpolation;
+
+ int m_iDefaultXSize;
+ int m_iDefaultYSize;
+ int m_iDefaultZeropad;
+};
+
#endif