r326: FFTW additions, filter image generation
[ctsim.git] / src / dialogs.cpp
index 4a4473559838ef02954f4e1e1f48bd28578853b0..3e2d8fb06a2078d0015b0e50754e485c5ca42407 100644 (file)
@@ -9,7 +9,7 @@
 **  This is part of the CTSim program
 **  Copyright (C) 1983-2000 Kevin Rosenberg
 **
-**  $Id: dialogs.cpp,v 1.21 2000/12/27 03:16:02 kevin Exp $
+**  $Id: dialogs.cpp,v 1.22 2001/01/01 10:14:34 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
@@ -814,3 +814,132 @@ DialogGetReconstructionParameters::getFilterGenerationName (void)
 }
 
 \r
+/////////////////////////////////////////////////////////////////////\r
+// CLASS IDENTIFICATION\r
+//\r
+// DialogGetFilterParameters\r
+/////////////////////////////////////////////////////////////////////\r
+\r
+\r
+DialogGetFilterParameters::DialogGetFilterParameters (wxFrame* pParent, int iDefaultXSize, int iDefaultYSize, int iDefaultFilterID, double dDefaultFilterParam,  double dDefaultBandwidth, int iDefaultDomainID)\r
+: wxDialog (pParent, -1, "Set Filter Parameters", wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxCAPTION)\r
+{\r
+  wxBoxSizer* pTopSizer = new wxBoxSizer (wxVERTICAL);\r
+  \r
+  pTopSizer->Add (new wxStaticText (this, -1, "Set Filter Parameters"), 0, wxALIGN_CENTER | wxTOP | wxLEFT | wxRIGHT, 5);\r
+  \r
+  pTopSizer->Add (new wxStaticLine (this, -1, wxDefaultPosition, wxSize(3,3), wxHORIZONTAL), 0, wxEXPAND | wxALL, 5);\r
+  \r
+  std::ostringstream os;\r
+  os << iDefaultXSize;\r
+  m_pTextCtrlXSize = new wxTextCtrl (this, -1, os.str().c_str(), wxDefaultPosition, wxSize(100, 25), 0);\r
+  std::ostringstream osYSize;\r
+  osYSize << iDefaultYSize;\r
+  m_pTextCtrlYSize = new wxTextCtrl (this, -1, osYSize.str().c_str(), wxDefaultPosition, wxSize(100, 25), 0);\r
+  std::ostringstream osFilterParam;\r
+  osFilterParam << dDefaultFilterParam;\r
+  m_pTextCtrlFilterParam = new wxTextCtrl (this, -1, osFilterParam.str().c_str(), wxDefaultPosition, wxSize(100, 25), 0);\r
+  std::ostringstream osBandwidth;\r
+  osBandwidth << dDefaultBandwidth;\r
+  m_pTextCtrlBandwidth = new wxTextCtrl (this, -1, osBandwidth.str().c_str(), wxDefaultPosition, wxSize(100, 25), 0);\r
+  \r
+  wxFlexGridSizer* pGridSizer = new wxFlexGridSizer (2);\r
+  pGridSizer->Add (new wxStaticText (this, -1, "Filter"), 0, wxALIGN_CENTER_VERTICAL | wxALIGN_RIGHT | wxALL, 5);\r
+  m_pListBoxFilter = new StringValueAndTitleListBox (this, SignalFilter::getFilterCount(), SignalFilter::getFilterTitleArray(), SignalFilter::getFilterNameArray());\r
+  m_pListBoxFilter->SetSelection (iDefaultFilterID);\r
+  pGridSizer->Add (m_pListBoxFilter, 0, wxALL | wxALIGN_LEFT | wxEXPAND);\r
+  \r
+  m_pListBoxDomain = new StringValueAndTitleListBox (this, SignalFilter::getDomainCount(), SignalFilter::getDomainTitleArray(), SignalFilter::getDomainNameArray());\r
+  m_pListBoxDomain->SetSelection (iDefaultDomainID);\r
+  pGridSizer->Add (new wxStaticText (this, -1, "Domain"), 0, wxALIGN_CENTER_VERTICAL | wxALIGN_RIGHT | wxALL, 5);\r
+  pGridSizer->Add (m_pListBoxDomain, 0, wxALL | wxALIGN_LEFT | wxEXPAND);\r
+  \r
+  pGridSizer->Add (new wxStaticText (this, -1, "X Size"), 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);\r
+  pGridSizer->Add (m_pTextCtrlXSize, 0, wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL);\r
+  pGridSizer->Add (new wxStaticText (this, -1, "Y Size"), 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);\r
+  pGridSizer->Add (m_pTextCtrlYSize, 0, wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL);\r
+  pGridSizer->Add (new wxStaticText (this, -1, "Filter Parameter"), 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);\r
+  pGridSizer->Add (m_pTextCtrlFilterParam, 0, wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL);\r
+  pGridSizer->Add (new wxStaticText (this, -1, "Bandwidth"), 0, wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL);\r
+  pGridSizer->Add (m_pTextCtrlBandwidth, 0, wxALIGN_LEFT | wxALIGN_CENTER_VERTICAL);\r
+  \r
+  pTopSizer->Add (pGridSizer, 1, wxALL, 3);\r
+  \r
+  pTopSizer->Add (new wxStaticLine (this, -1, wxDefaultPosition, wxSize(3,3), wxHORIZONTAL), 0, wxEXPAND | wxALL, 5);\r
+  \r
+  wxBoxSizer* pButtonSizer = new wxBoxSizer (wxHORIZONTAL);\r
+  wxButton* pButtonOk = new wxButton (this, wxID_OK, "Okay");\r
+  wxButton* pButtonCancel = new wxButton (this, wxID_CANCEL, "Cancel");\r
+  pButtonSizer->Add (pButtonOk, 0, wxEXPAND | wxALL, 10);\r
+  pButtonSizer->Add (pButtonCancel, 0, wxEXPAND | wxALL, 10);\r
+  \r
+  pTopSizer->Add (pButtonSizer, 0, wxALIGN_CENTER);\r
+  \r
+  SetAutoLayout (true);\r
+  SetSizer (pTopSizer);\r
+  pTopSizer->Layout();\r
+  pTopSizer->Fit (this);\r
+  pTopSizer->SetSizeHints (this);\r
+}\r
+\r
+DialogGetFilterParameters::~DialogGetFilterParameters (void)\r
+{\r
+}\r
+\r
+\r
+unsigned int\r
+DialogGetFilterParameters::getXSize (void)\r
+{\r
+  wxString strCtrl = m_pTextCtrlXSize->GetValue();\r
+  unsigned long lValue;\r
+  if (strCtrl.ToULong (&lValue))\r
+    return lValue;\r
+  else\r
+    return (m_iDefaultXSize);\r
+}\r
+\r
+unsigned int\r
+DialogGetFilterParameters::getYSize (void)\r
+{\r
+  wxString strCtrl = m_pTextCtrlYSize->GetValue();\r
+  unsigned long lValue;\r
+  if (strCtrl.ToULong (&lValue))\r
+    return lValue;\r
+  else\r
+    return (m_iDefaultYSize);\r
+}\r
+\r
+double\r
+DialogGetFilterParameters::getBandwidth (void)\r
+{\r
+  wxString strCtrl = m_pTextCtrlBandwidth->GetValue();\r
+  double dValue;\r
+  if (strCtrl.ToDouble (&dValue))\r
+    return dValue;\r
+  else\r
+    return (m_dDefaultBandwidth);\r
+}\r
+\r
+double\r
+DialogGetFilterParameters::getFilterParam (void)\r
+{\r
+  wxString strCtrl = m_pTextCtrlFilterParam->GetValue();\r
+  double dValue;\r
+  if (strCtrl.ToDouble (&dValue))\r
+    return (dValue);\r
+  else\r
+    return (m_dDefaultFilterParam);\r
+}\r
+\r
+const char*\r
+DialogGetFilterParameters::getFilterName (void)\r
+{\r
+  return m_pListBoxFilter->getSelectionStringValue();\r
+}\r
+\r
+const char*\r
+DialogGetFilterParameters::getDomainName (void)\r
+{\r
+  return m_pListBoxDomain->getSelectionStringValue();\r
+}\r
+\r