** This is part of the CTSim program
** Copyright (C) 1983-2000 Kevin Rosenberg
**
-** $Id: ctsim.cpp,v 1.24 2001/01/02 05:34:57 kevin Exp $
+** $Id: ctsim.cpp,v 1.26 2001/01/06 15:33:15 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
** along with this program; if not, write to the Free Software
** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
******************************************************************************/
-\r
-\r
-// For compilers that support precompilation, includes "wx/wx.h".\r
-#include "wx/wxprec.h"\r
-\r
-#ifdef __BORLANDC__\r
-#pragma hdrstop\r
-#endif\r
-\r
-#ifndef WX_PRECOMP\r
-#include "wx/wx.h"\r
-#endif\r
-\r
-#if !wxUSE_DOC_VIEW_ARCHITECTURE\r
-#error You must set wxUSE_DOC_VIEW_ARCHITECTURE to 1 in setup.h!\r
-#endif\r
-\r
-#include "ct.h"\r
+
+
+// For compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+#pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+#include "wx/wx.h"
+#endif
+
+#if !wxUSE_DOC_VIEW_ARCHITECTURE
+#error You must set wxUSE_DOC_VIEW_ARCHITECTURE to 1 in setup.h!
+#endif
+
+#include "ct.h"
#include "ctsim.h"
#include "docs.h"
#include "views.h"
#include "dialogs.h"
-\r
+
#if defined(HAVE_CONFIG_H)
#include "config.h"
-#endif\r
-\r
+#endif
+
#if defined(HAVE_GETOPT_H) || defined(HAVE_GETOPT_LONG)
-#ifdef MSVC\r
-#define __STDC__ 1\r
-#endif\r
-#include "getopt.h"\r
-#ifdef MSVC\r
-#undef __STDC__\r
+#ifdef MSVC
+#define __STDC__ 1
#endif
+#include "getopt.h"
+#ifdef MSVC
+#undef __STDC__
#endif
-\r
-static const char* rcsindent = "$Id: ctsim.cpp,v 1.24 2001/01/02 05:34:57 kevin Exp $";
+#endif
+
+static const char* rcsindent = "$Id: ctsim.cpp,v 1.26 2001/01/06 15:33:15 kevin Exp $";
class CTSimApp* theApp = NULL;
switch (c) {
case O_VERSION:
- std::cout << rcsindent << std::endl;\r
-#ifdef CTSIMVERSION\r
- std::cout << "Version: CTSIMVERSION" << std::endl;\r
-#elif defined(VERSION)\r
- std::cout << "Version: VERSION" << std::endl;\r
+ std::cout << rcsindent << std::endl;
+#ifdef CTSIMVERSION
+ std::cout << "Version: CTSIMVERSION" << std::endl;
+#elif defined(VERSION)
+ std::cout << "Version: VERSION" << std::endl;
#endif
exit(0);
case O_HELP:
//// Create the main frame window
m_pFrame = new MainFrame(m_docManager, (wxFrame *) NULL, -1, "CTSim", wxPoint(0, 0), wxSize(500, 400), wxDEFAULT_FRAME_STYLE);
-
+
SetTopWindow (m_pFrame);
m_pFrame->Centre(wxBOTH);
// Top-level window for CTSim
+#if CTSIM_MDI
+IMPLEMENT_CLASS(MainFrame, wxMDIParentFrame)
+
+BEGIN_EVENT_TABLE(MainFrame, wxMDIParentFrame)
+#else
IMPLEMENT_CLASS(MainFrame, wxDocParentFrame)
BEGIN_EVENT_TABLE(MainFrame, wxDocParentFrame)
+#endif
+
EVT_MENU(MAINMENU_HELP_ABOUT, MainFrame::OnAbout)
EVT_MENU(MAINMENU_HELP_CONTENTS, MainFrame::OnHelpContents)
-EVT_MENU(MAINMENU_FILE_CREATE_PHANTOM, MainFrame::OnCreatePhantom)\r
-EVT_MENU(MAINMENU_FILE_CREATE_FILTER, MainFrame::OnCreateFilter)\r
+EVT_MENU(MAINMENU_FILE_CREATE_PHANTOM, MainFrame::OnCreatePhantom)
+EVT_MENU(MAINMENU_FILE_CREATE_FILTER, MainFrame::OnCreateFilter)
EVT_MENU(MAINMENU_FILE_EXIT, MainFrame::OnExit)
EVT_MENU(MAINMENU_WINDOW_BASE, MainFrame::OnWindowMenu0)
EVT_MENU(MAINMENU_WINDOW_BASE+1, MainFrame::OnWindowMenu1)
+#if CTSIM_MDI
+MainFrame::MainFrame(wxDocManager *manager, wxFrame *frame, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, const long type)
+: wxMDIParentFrame(NULL, id, title, pos, size, type), m_pLog(NULL)
+#else
MainFrame::MainFrame(wxDocManager *manager, wxFrame *frame, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, const long type)
: wxDocParentFrame(manager, frame, id, title, pos, size, type), m_pLog(NULL)
+#endif
{
m_pLog = new wxTextCtrl (this, -1, "Log Window\n", wxPoint(0, 250), wxSize(100,50), wxTE_MULTILINE | wxTE_READONLY);
wxLog::SetActiveTarget(new wxLogTextCtrl(m_pLog));
//// Make a menubar
wxMenu *file_menu = new wxMenu;
- file_menu->Append(MAINMENU_FILE_CREATE_PHANTOM, "Cr&eate Phantom...");\r
- file_menu->Append(MAINMENU_FILE_CREATE_FILTER, "Create &Filter...");\r
+ file_menu->Append(MAINMENU_FILE_CREATE_PHANTOM, "Cr&eate Phantom...");
+ file_menu->Append(MAINMENU_FILE_CREATE_FILTER, "Create &Filter...");
file_menu->Append(wxID_OPEN, "&Open...");
file_menu->AppendSeparator();
file_menu->Append(MAINMENU_FILE_EXIT, "E&xit");
// history of files visited
- m_docManager->FileHistoryUseMenu(file_menu);
+ theApp->getDocManager()->FileHistoryUseMenu(file_menu);
m_pWindowMenu = new wxMenu;
m_pWindowMenu->UpdateUI (this);
m_pWindowMenu->Append (m_apWindowMenuItems[i]);
m_pWindowMenu->Enable (MAINMENU_WINDOW_BASE+i, false);
}
- \r
- m_iDefaultPhantomID = Phantom::PHM_HERMAN;\r
- m_iDefaultFilterID = SignalFilter::FILTER_BANDLIMIT;\r
- m_iDefaultFilterDomainID = SignalFilter::DOMAIN_FREQUENCY;\r
- m_iDefaultFilterXSize = 256;\r
- m_iDefaultFilterYSize = 256;\r
- m_dDefaultFilterParam = 1.;\r
- m_dDefaultFilterBandwidth = 1.;\r
- m_dDefaultFilterInputScale = 1.;\r
- m_dDefaultFilterOutputScale = 1.;\r
- \r
+
+ m_iDefaultPhantomID = Phantom::PHM_HERMAN;
+ m_iDefaultFilterID = SignalFilter::FILTER_BANDLIMIT;
+ m_iDefaultFilterDomainID = SignalFilter::DOMAIN_FREQUENCY;
+ m_iDefaultFilterXSize = 256;
+ m_iDefaultFilterYSize = 256;
+ m_dDefaultFilterParam = 1.;
+ m_dDefaultFilterBandwidth = 1.;
+ m_dDefaultFilterInputScale = 1.;
+ m_dDefaultFilterOutputScale = 1.;
+
}
void
MainFrame::OnAbout(wxCommandEvent& WXUNUSED(event) )
-{\r
- wxString msg = "CTSim\nThe Open Source Computed Tomography Simulator\n";\r
-#ifdef CTSIMVERSION\r
- msg += "Version ";\r
- msg += CTSIMVERSION;\r
- msg += "\n\n";\r
-#elif defined(VERSION)\r
- msg << "Version: " << VERSION << "\n\n";\r
-#endif\r
- msg += "Author: Kevin Rosenberg <kevin@rosenberg.net>\nUsage: ctsim [files-to-open..] [--help]";\r
+{
+ wxString msg = "CTSim\nThe Open Source Computed Tomography Simulator\n";
+#ifdef CTSIMVERSION
+ msg += "Version ";
+ msg += CTSIMVERSION;
+ msg += "\n\n";
+#elif defined(VERSION)
+ msg << "Version: " << VERSION << "\n\n";
+#endif
+ msg += "Author: Kevin Rosenberg <kevin@rosenberg.net>\nUsage: ctsim [files-to-open..] [--help]";
wxMessageBox(msg, "About CTSim", wxOK | wxICON_INFORMATION, this);
}
-\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
+
+void
+MainFrame::OnCreatePhantom(wxCommandEvent& WXUNUSED(event))
+{
+ DialogGetPhantom dialogPhantom (this, m_iDefaultPhantomID);
+ int dialogReturn = dialogPhantom.ShowModal();
+ if (dialogReturn == wxID_OK) {
+ wxString selection (dialogPhantom.getPhantom());
+ *theApp->getLog() << "Selected phantom " << selection.c_str() << "\n";
+ wxString filename = selection + ".phm";
+ m_iDefaultPhantomID = Phantom::convertNameToPhantomID (selection.c_str());
+ theApp->getDocManager()->CreateDocument(filename, wxDOC_SILENT);
+ }
+
+}
+
+void
+MainFrame::OnCreateFilter (wxCommandEvent& WXUNUSED(event))
+{
+ DialogGetFilterParameters dialogFilter (this, m_iDefaultFilterXSize, m_iDefaultFilterYSize, m_iDefaultFilterID, m_dDefaultFilterParam, m_dDefaultFilterBandwidth, m_iDefaultFilterDomainID, m_dDefaultFilterInputScale, m_dDefaultFilterOutputScale);
+ int dialogReturn = dialogFilter.ShowModal();
+ if (dialogReturn == wxID_OK) {
+ wxString strFilter (dialogFilter.getFilterName());
+ wxString strDomain (dialogFilter.getDomainName());
+ m_iDefaultFilterID = SignalFilter::convertFilterNameToID (strFilter.c_str());
+ m_iDefaultFilterDomainID = SignalFilter::convertDomainNameToID (strDomain.c_str());
+ m_iDefaultFilterXSize = dialogFilter.getXSize();
+ m_iDefaultFilterYSize = dialogFilter.getYSize();
+ m_dDefaultFilterBandwidth = dialogFilter.getBandwidth();
+ m_dDefaultFilterParam= dialogFilter.getFilterParam();
+ m_dDefaultFilterInputScale = dialogFilter.getInputScale();
+ m_dDefaultFilterOutputScale = dialogFilter.getOutputScale();
+ std::ostringstream os;
+ os << "Generate Filter=" << strFilter.c_str()
+ << ", size=(" << static_cast<int>(m_iDefaultFilterXSize) << "," << static_cast<int>(m_iDefaultFilterYSize)
+ << "), domain=" << strDomain.c_str() << ", filterParam=" << m_dDefaultFilterParam << ", bandwidth=" << m_dDefaultFilterBandwidth
+ << ", inputScale=" << m_dDefaultFilterInputScale << ", outputScale=" << m_dDefaultFilterOutputScale;
+ *theApp->getLog() << os.str().c_str() << "\n";
+ wxString filename = "untitled.if";
+ ImageFileDocument* pFilterDoc = dynamic_cast<ImageFileDocument*>(theApp->getDocManager()->CreateDocument ("untitled.if", wxDOC_SILENT));
+ if (! pFilterDoc) {
+ sys_error (ERR_SEVERE, "Unable to create filter image");
+ return;
+ }
+ ImageFile& rIF = pFilterDoc->getImageFile();
+ rIF.setArraySize (m_iDefaultFilterXSize, m_iDefaultFilterYSize);
+ rIF.filterResponse (strDomain.c_str(), m_dDefaultFilterBandwidth, strFilter.c_str(), m_dDefaultFilterParam, m_dDefaultFilterInputScale, m_dDefaultFilterOutputScale);
+ rIF.labelAdd (os.str().c_str());
+ if (theApp->getSetModifyNewDocs())
+ pFilterDoc->Modify (true);
+ pFilterDoc->UpdateAllViews();
+ pFilterDoc->GetFirstView()->OnUpdate (NULL, NULL);
+ }
+}
+
+void
+CTSimApp::getCompatibleImages (const ImageFileDocument* pIFDoc, std::vector<ImageFileDocument*>& vecIF)
+{
+ const ImageFile& rIF = pIFDoc->getImageFile();
+ unsigned int nx = rIF.nx();
+ unsigned int ny = rIF.ny();
+ wxList& rListDocs = m_docManager->GetDocuments();
+ for (wxNode* pNode = rListDocs.GetFirst(); pNode != NULL; pNode = pNode->GetNext()) {
+ wxDocument* pDoc = reinterpret_cast<wxDocument*>(pNode->GetData());
+ ImageFileDocument* pIFCompareDoc = dynamic_cast<ImageFileDocument*>(pDoc);
+ if (pIFCompareDoc && (pIFDoc != pIFCompareDoc)) {
+ const ImageFile& rCompareIF = pIFCompareDoc->getImageFile();
+ if (rCompareIF.nx() == nx && rCompareIF.ny() == ny)
+ vecIF.push_back (pIFCompareDoc);
+ }
+ }
+}
+
void
MainFrame::OnHelpContents(wxCommandEvent& WXUNUSED(event) )
{
MainFrame::OnUpdateUI (wxUpdateUIEvent& rEvent)
{
int iPos = 0;
- wxList& rListDocs = m_docManager->GetDocuments();
+ wxList& rListDocs = theApp->getDocManager()->GetDocuments();
wxNode* pNode = rListDocs.GetFirst();
while (iPos < MAX_WINDOW_MENUITEMS && pNode != NULL) {
wxDocument* pDoc = static_cast<wxDocument*>(pNode->GetData());