-void \r
-MainFrame::OnCreatePhantom(wxCommandEvent& WXUNUSED(event))\r
-{\r
- DialogGetPhantom dialogPhantom (this, Phantom::PHM_HERMAN);\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
- theApp->getDocManager()->CreateDocument(filename, wxDOC_SILENT);\r
- }\r
- \r
-}\r
-\r
-void \r
-MainFrame::OnCreateFilter (wxCommandEvent& WXUNUSED(event))\r
-{\r
- DialogGetFilterParameters dialogFilter (this, 256, 256, SignalFilter::FILTER_BANDLIMIT, 1., 10., SignalFilter::DOMAIN_SPATIAL);\r
- int dialogReturn = dialogFilter.ShowModal();\r
- if (dialogReturn == wxID_OK) {\r
- wxString strFilter (dialogFilter.getFilterName());\r
- wxString strDomain (dialogFilter.getDomainName());\r
- unsigned int nx = dialogFilter.getXSize();\r
- unsigned int ny = dialogFilter.getYSize();\r
- double dBandwidth = dialogFilter.getBandwidth();\r
- double dFilterParam= dialogFilter.getFilterParam();\r
- *theApp->getLog() << "Selected filter " << strFilter.c_str() << ", domain " << strDomain.c_str() << ", filterParam " << dFilterParam << ", bandwidth " << dBandwidth << "\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 (nx, ny);\r
- rIF.filterResponse (strDomain.c_str(), dBandwidth, strFilter.c_str(), dFilterParam);\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