** This is part of the CTSim program
** Copyright (C) 1983-2000 Kevin Rosenberg
**
-** $Id: dialogs.h,v 1.1 2000/07/18 03:14:35 kevin Exp $
+** $Id: dialogs.h,v 1.6 2000/07/22 15:45:33 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
#define __DIALOGSH__
#include "wx/wx.h"
+#include <string>
+#include "scanner.h"
+#include "phantom.h"
+#include "filter.h"
+
+// CLASS StringValueAndTitleListBox
+//
+// A superclass of wxListBox that can handle string values and titles
+// and by displaying the title in the list box and returning the string value
+
+class StringValueAndTitleListBox : public wxListBox
+{
+ public:
+ StringValueAndTitleListBox (wxDialog* pParent, int nChoices, const char* aszTitle[], const char* aszValue[]);
+
+ const char* getSelectionStringValue (void) const;
+
+ private:
+ const char** m_ppszValues;
+};
+
+
+class DialogGetPhantom : public wxDialog
+{
+ public:
+ DialogGetPhantom (wxFrame* pParent, int iDefaultPhantom = Phantom::PHM_HERMAN);
+ virtual ~DialogGetPhantom (void) {}
+
+ const char* getPhantom (void);
+
+ private:
+ StringValueAndTitleListBox* m_pListBoxPhantom;
+};
+
class ImageFile;
class DialogGetImageMinMax : public wxDialog
{
public:
DialogGetImageMinMax (wxFrame* pParent, const ImageFile& rImagefile, double dDefaultMin = 0., double dDefaultMax = 0.);
- ~DialogGetImageMinMax (void);
+ virtual ~DialogGetImageMinMax (void);
double getMinimum (void);
double getMaximum (void);
private:
- wxBoxSizer* m_pTopSizer;
wxTextCtrl* m_pTextCtrlMin;
wxTextCtrl* m_pTextCtrlMax;
- wxBoxSizer* m_pButtonSizer;
- wxButton* m_pButtonOk;
- wxButton* m_pButtonCancel;
double m_dDefaultMin;
double m_dDefaultMax;
};
+
+class DialogGetRasterParameters : public wxDialog
+{
+ public:
+ DialogGetRasterParameters (wxFrame* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0, int iDefaultNSamples = 1);
+ virtual ~DialogGetRasterParameters (void);
+
+ unsigned int getXSize (void);
+ unsigned int getYSize (void);
+ unsigned int getNSamples (void);
+
+ private:
+ wxTextCtrl* m_pTextCtrlXSize;
+ wxTextCtrl* m_pTextCtrlYSize;
+ wxTextCtrl* m_pTextCtrlNSamples;
+
+ int m_iDefaultXSize;
+ int m_iDefaultYSize;
+ int m_iDefaultNSamples;
+};
+
+
+class DialogGetProjectionParameters : public wxDialog
+{
+ public:
+ DialogGetProjectionParameters (wxFrame* pParent, int iDefaultNDet = 0, int iDefaultNView = 0, int iDefaultNSamples = 1, double dDefaultRotAngle = 1., int iDefaultGeometry = Scanner::GEOMETRY_PARALLEL);
+ ~DialogGetProjectionParameters (void);
+
+ unsigned int getNDet (void);
+ unsigned int getNView (void);
+ unsigned int getNSamples (void);
+ double getRotAngle (void);
+ const char* getGeometry(void);
+
+ private:
+ wxTextCtrl* m_pTextCtrlNDet;
+ wxTextCtrl* m_pTextCtrlNView;
+ wxTextCtrl* m_pTextCtrlNSamples;
+ wxTextCtrl* m_pTextCtrlRotAngle;
+
+ StringValueAndTitleListBox* m_pListBoxGeometry;
+
+ int m_iDefaultNDet;
+ int m_iDefaultNView;
+ int m_iDefaultNSamples;
+ double m_dDefaultRotAngle;
+};
+
+
+class DialogGetReconstructionParameters : public wxDialog
+{
+ public:
+ DialogGetReconstructionParameters (wxFrame* pParent, int iDefaultXSize = 0, int iDefaultYSize = 0, int iDefaultFilterID = SignalFilter::FILTER_ABS_BANDLIMIT, double dDefaultFilterParam = 1., int iDefaultFilterMethodID = SignalFilter::FILTER_METHOD_CONVOLUTION, int iDefaultZeropad = 3, int iDefaultInterpID = Backprojector::INTERP_LINEAR, int iDefaultInterpParam = 1, int iDefaultBackprojID = Backprojector::BPROJ_IDIFF3);
+ virtual ~DialogGetReconstructionParameters (void);
+
+ unsigned int getXSize(void);
+ unsigned int getYSize(void);
+ const char* getFilterName(void);
+ double getFilterParam(void);
+ const char* getFilterMethodName(void);
+ unsigned int getZeropad(void);
+ const char* getInterpName(void);
+ unsigned int getInterpParam(void);
+ const char* getBackprojectName(void);
+
+ private:
+ wxTextCtrl* m_pTextCtrlXSize;
+ wxTextCtrl* m_pTextCtrlYSize;
+ wxTextCtrl* m_pTextCtrlZeropad;
+ wxTextCtrl* m_pTextCtrlFilterParam;
+ wxTextCtrl* m_pTextCtrlInterpParam;
+
+ StringValueAndTitleListBox* m_pListBoxFilter;
+ StringValueAndTitleListBox* m_pListBoxFilterMethod;
+ StringValueAndTitleListBox* m_pListBoxInterp;
+ StringValueAndTitleListBox* m_pListBoxBackproject;
+
+ int m_iDefaultXSize;
+ int m_iDefaultYSize;
+ double m_dDefaultFilterParam;
+ int m_iDefaultZeropad;
+ int m_iDefaultInterpParam;
+};
+
#endif