** This is part of the CTSim program
** Copyright (C) 1983-2000 Kevin Rosenberg
**
-** $Id: ctsim.cpp,v 1.21 2000/12/27 03:16:02 kevin Exp $
+** $Id: ctsim.cpp,v 1.23 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
#endif
#endif
\r
-static const char* rcsindent = "$Id: ctsim.cpp,v 1.21 2000/12/27 03:16:02 kevin Exp $";
+static const char* rcsindent = "$Id: ctsim.cpp,v 1.23 2001/01/01 10:14:34 kevin Exp $";
class CTSimApp* theApp = NULL;
BEGIN_EVENT_TABLE(MainFrame, wxDocParentFrame)
EVT_MENU(MAINMENU_HELP_ABOUT, MainFrame::OnAbout)
EVT_MENU(MAINMENU_HELP_CONTENTS, MainFrame::OnHelpContents)
- EVT_MENU(MAINMENU_FILE_CREATE_PHANTOM, MainFrame::OnCreatePhantom)
+ EVT_MENU(MAINMENU_FILE_CREATE_PHANTOM, MainFrame::OnCreatePhantom)\r
+ EVT_MENU(MAINMENU_FILE_CREATE_FILTER, MainFrame::OnCreateFilter)\r
EVT_MENU(MAINMENU_FILE_EXIT, MainFrame::OnExit)
EVT_MENU(MAINMENU_WINDOW_BASE, MainFrame::OnWindowMenu0)
EVT_MENU(MAINMENU_WINDOW_BASE+1, MainFrame::OnWindowMenu1)
//// Make a menubar
wxMenu *file_menu = new wxMenu;
- file_menu->Append(MAINMENU_FILE_CREATE_PHANTOM, "Cr&eate Phantom...");
+ file_menu->Append(MAINMENU_FILE_CREATE_PHANTOM, "Cr&eate Phantom...");\r
+ file_menu->Append(MAINMENU_FILE_CREATE_FILTER, "Create &Filter...");\r
file_menu->Append(wxID_OPEN, "&Open...");
file_menu->AppendSeparator();
wxMessageBox(msg, "About CTSim", wxOK | wxICON_INFORMATION, this);
}
-void
-MainFrame::OnCreatePhantom(wxCommandEvent& WXUNUSED(event))
-{
- DialogGetPhantom dialogPhantom (this, Phantom::PHM_HERMAN);
- int dialogReturn = dialogPhantom.ShowModal();
- if (dialogReturn == wxID_OK) {
- wxString selection (dialogPhantom.getPhantom());
- *theApp->getLog() << "Selected phantom " << selection.c_str() << "\n";
- wxString filename = selection + ".phm";
- theApp->getDocManager()->CreateDocument(filename, wxDOC_SILENT);
- }
-
-}
-
+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
- int nx = rIF.nx();\r
- int ny = rIF.ny();\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