** This is part of the CTSim program
** Copyright (c) 1983-2001 Kevin Rosenberg
**
-** $Id: dialogs.h,v 1.30 2001/02/22 15:00:20 kevin Exp $
+** $Id: dialogs.h,v 1.38 2001/09/24 11:46:17 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 "procsignal.h"
#include "filter.h"
#include "projections.h"
+#include "ctsim-map.h"
class CTSimHelpButton : public wxButton
class StringValueAndTitleListBox : public wxListBox
{
public:
- StringValueAndTitleListBox (wxDialog* pParent, int nChoices, const char* aszTitle[], const char* aszValue[]);
+ StringValueAndTitleListBox (wxDialog* pParent, int nChoices, const char* const aszTitle[], const char* const aszValue[]);
const char* getSelectionStringValue () const;
private:
- const char** m_ppszValues;
+ const char* const* m_ppszValues;
};
class StringValueAndTitleRadioBox : public wxRadioBox
{
public:
- StringValueAndTitleRadioBox (wxDialog* pParent, const wxString& strTitle, int nChoices, const char* aszTitle[], const char* aszValue[]);
+ StringValueAndTitleRadioBox (wxDialog* pParent, const wxString& strTitle, int nChoices, const char* const aszTitle[], const char* const aszValue[]);
const char* getSelectionStringValue () const;
private:
- const char** m_ppszValues;
+ const char* const* m_ppszValues;
};
StringValueAndTitleRadioBox* m_pRadioBoxPhantom;
};
+class DialogGetThetaRange : public wxDialog
+{
+ public:
+ DialogGetThetaRange (wxWindow* pParent, int iDefaultThetaRange = ParallelRaysums::THETA_RANGE_UNCONSTRAINED);
+ virtual ~DialogGetThetaRange () {}
+
+ int getThetaRange ();
+
+ private:
+ wxRadioBox* m_pRadioBoxThetaRange;
+};
+
#include <vector>
class ImageFileDocument;
{
public:
DialogGetProjectionParameters (wxWindow* pParent, int iDefaultNDet = 0,
- int iDefaultNView = 0, int iDefaultNSamples = 1, double dDefaultRotAngle = 1.,
- double dDefaultFocalLength = 1, double dDefaultViewRatio = 1.,
+ int iDefaultNView = 0, int iDefaultOffsetView = 0, int iDefaultNSamples = 1, double dDefaultRotAngle = 1.,
+ double dDefaultFocalLength = 1, double dDefaultCenterDetectorLength = 1, double dDefaultViewRatio = 1.,
double dDefaultScanRatio = 1., int iDefaultGeometry = Scanner::GEOMETRY_PARALLEL, int iDefaultTrace = Trace::TRACE_NONE);
~DialogGetProjectionParameters ();
unsigned int getNDet ();
unsigned int getNView ();
+ unsigned int getOffsetView ();
unsigned int getNSamples ();
int getTrace ();
double getViewRatio ();
double getScanRatio ();
double getFocalLengthRatio ();
+ double getCenterDetectorLengthRatio ();
const char* getGeometry();
private:
wxTextCtrl* m_pTextCtrlNDet;
wxTextCtrl* m_pTextCtrlNView;
+ wxTextCtrl* m_pTextCtrlOffsetView;
wxTextCtrl* m_pTextCtrlNSamples;
wxTextCtrl* m_pTextCtrlRotAngle;
wxTextCtrl* m_pTextCtrlFocalLength;
+ wxTextCtrl* m_pTextCtrlCenterDetectorLength;
wxTextCtrl* m_pTextCtrlViewRatio;
wxTextCtrl* m_pTextCtrlScanRatio;
StringValueAndTitleRadioBox* m_pRadioBoxGeometry;
int m_iDefaultNDet;
int m_iDefaultNView;
+ int m_iDefaultOffsetView;
int m_iDefaultNSamples;
int m_iDefaultTrace;
int m_iDefaultGeometry;
double m_dDefaultRotAngle;
double m_dDefaultFocalLength;
+ double m_dDefaultCenterDetectorLength;
double m_dDefaultViewRatio;
double m_dDefaultScanRatio;
};
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);
+ int iDefaultTrace = Trace::TRACE_NONE, ReconstructionROI* pROI = NULL);
virtual ~DialogGetReconstructionParameters ();
unsigned int getXSize();
const char* getInterpName();
unsigned int getInterpParam();
const char* getBackprojectName();
+ void getROI (ReconstructionROI* pROI);
int getTrace ();
private:
wxTextCtrl* m_pTextCtrlZeropad;
wxTextCtrl* m_pTextCtrlFilterParam;
wxTextCtrl* m_pTextCtrlInterpParam;
-
+ wxTextCtrl* m_pTextCtrlRoiXMin;
+ wxTextCtrl* m_pTextCtrlRoiXMax;
+ wxTextCtrl* m_pTextCtrlRoiYMin;
+ wxTextCtrl* m_pTextCtrlRoiYMax;
StringValueAndTitleRadioBox* m_pRadioBoxFilter;
StringValueAndTitleRadioBox* m_pRadioBoxFilterMethod;
StringValueAndTitleRadioBox* m_pRadioBoxFilterGeneration;
double m_dDefaultFilterParam;
int m_iDefaultZeropad;
int m_iDefaultInterpParam;
- int m_iDefaultTrace;
+ double m_dDefaultRoiXMin;
+ double m_dDefaultRoiXMax;
+ double m_dDefaultRoiYMin;
+ double m_dDefaultRoiYMax;
};
StringValueAndTitleRadioBox* m_pRadioBoxFormat;
};
+class DialogImportParameters : public wxDialog
+{
+ public:
+ DialogImportParameters (wxWindow* pParent, int iDefaultFormatID);
+ virtual ~DialogImportParameters () {}
+
+ const char* getFormatName();
+
+ private:
+ StringValueAndTitleRadioBox* m_pRadioBoxFormat;
+};
+
class DialogAutoScaleParameters : public wxDialog
{
public:
public:
DialogGetConvertPolarParameters (wxWindow* pParent, const char* const pszTitle, int iDefaultXSize = 0,
int iDefaultYSize = 0, int iDefaultInterpolationID = Projections::POLAR_INTERP_BILINEAR,
- int iDefaultZeropad = 1);
+ int iDefaultZeropad = 1, int iHelpID = IDH_DLG_POLAR);
virtual ~DialogGetConvertPolarParameters ();
unsigned int getXSize();