+\r
+void \r
+MainFrame::OnCreatePhantom(wxCommandEvent& WXUNUSED(event))\r
+{\r
+ DialogGetPhantom dialogPhantom (this, m_iDefaultPhantomID);\r
+ int dialogReturn = dialogPhantom.ShowModal();\r
+ if (dialogReturn == wxID_OK) {\r
+ wxString selection (dialogPhantom.getPhantom());\r
+ *theApp->getLog() << "Selected phantom " << selection.c_str() << "\n";\r
+ wxString filename = selection + ".phm";\r
+ m_iDefaultPhantomID = Phantom::convertNameToPhantomID (selection.c_str());\r
+ theApp->getDocManager()->CreateDocument(filename, wxDOC_SILENT);\r
+ }\r
+ \r
+}\r
+\r
+void \r
+MainFrame::OnCreateFilter (wxCommandEvent& WXUNUSED(event))\r
+{\r
+ DialogGetFilterParameters dialogFilter (this, m_iDefaultFilterXSize, m_iDefaultFilterYSize, m_iDefaultFilterID, m_dDefaultFilterParam, m_dDefaultFilterBandwidth, m_iDefaultFilterDomainID, m_dDefaultFilterInputScale, m_dDefaultFilterOutputScale);\r
+ int dialogReturn = dialogFilter.ShowModal();\r
+ if (dialogReturn == wxID_OK) {\r
+ wxString strFilter (dialogFilter.getFilterName());\r
+ wxString strDomain (dialogFilter.getDomainName());\r
+ m_iDefaultFilterID = SignalFilter::convertFilterNameToID (strFilter.c_str());\r
+ m_iDefaultFilterDomainID = SignalFilter::convertDomainNameToID (strDomain.c_str());\r
+ m_iDefaultFilterXSize = dialogFilter.getXSize();\r
+ m_iDefaultFilterYSize = dialogFilter.getYSize();\r
+ m_dDefaultFilterBandwidth = dialogFilter.getBandwidth();\r
+ m_dDefaultFilterParam= dialogFilter.getFilterParam();\r
+ m_dDefaultFilterInputScale = dialogFilter.getInputScale();\r
+ m_dDefaultFilterOutputScale = dialogFilter.getOutputScale();\r
+ std::ostringstream os;\r
+ os << "Generate Filter=" << strFilter.c_str() \r
+ << ", size=(" << static_cast<int>(m_iDefaultFilterXSize) << "," << static_cast<int>(m_iDefaultFilterYSize) \r
+ << "), domain=" << strDomain.c_str() << ", filterParam=" << m_dDefaultFilterParam << ", bandwidth=" << m_dDefaultFilterBandwidth \r
+ << ", inputScale=" << m_dDefaultFilterInputScale << ", outputScale=" << m_dDefaultFilterOutputScale;\r
+ *theApp->getLog() << os.str().c_str() << "\n";\r
+ wxString filename = "untitled.if";\r
+ ImageFileDocument* pFilterDoc = dynamic_cast<ImageFileDocument*>(theApp->getDocManager()->CreateDocument ("untitled.if", wxDOC_SILENT));\r
+ if (! pFilterDoc) {\r
+ sys_error (ERR_SEVERE, "Unable to create filter image");\r
+ return;\r
+ }\r
+ ImageFile& rIF = pFilterDoc->getImageFile();\r
+ rIF.setArraySize (m_iDefaultFilterXSize, m_iDefaultFilterYSize);\r
+ rIF.filterResponse (strDomain.c_str(), m_dDefaultFilterBandwidth, strFilter.c_str(), m_dDefaultFilterParam, m_dDefaultFilterInputScale, m_dDefaultFilterOutputScale);\r
+ rIF.labelAdd (os.str().c_str());\r
+ if (theApp->getSetModifyNewDocs())\r
+ pFilterDoc->Modify (true);\r
+ pFilterDoc->UpdateAllViews();\r
+ pFilterDoc->GetFirstView()->OnUpdate (NULL, NULL);\r
+ }\r
+}\r
+\r
+void\r
+CTSimApp::getCompatibleImages (const ImageFileDocument* pIFDoc, std::vector<ImageFileDocument*>& vecIF)\r
+{\r
+ const ImageFile& rIF = pIFDoc->getImageFile();\r
+ unsigned int nx = rIF.nx();\r
+ unsigned int ny = rIF.ny();\r
+ wxList& rListDocs = m_docManager->GetDocuments();\r
+ for (wxNode* pNode = rListDocs.GetFirst(); pNode != NULL; pNode = pNode->GetNext()) {\r
+ wxDocument* pDoc = reinterpret_cast<wxDocument*>(pNode->GetData());\r
+ ImageFileDocument* pIFCompareDoc = dynamic_cast<ImageFileDocument*>(pDoc);\r
+ if (pIFCompareDoc && (pIFDoc != pIFCompareDoc)) {\r
+ const ImageFile& rCompareIF = pIFCompareDoc->getImageFile();\r
+ if (rCompareIF.nx() == nx && rCompareIF.ny() == ny)\r
+ vecIF.push_back (pIFCompareDoc);\r
+ }\r
+ }\r
+}\r
+\r