** This is part of the CTSim program
** Copyright (C) 1983-2000 Kevin Rosenberg
**
-** $Id: ctsim.cpp,v 1.44 2001/01/26 21:22:37 kevin Exp $
+** $Id: ctsim.cpp,v 1.54 2001/01/28 19:10:18 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
-static const char* rcsindent = "$Id: ctsim.cpp,v 1.44 2001/01/26 21:22:37 kevin Exp $";
+static const char* rcsindent = "$Id: ctsim.cpp,v 1.54 2001/01/28 19:10:18 kevin Exp $";
struct option CTSimApp::ctsimOptions[] =
{
// Create the main frame window
int xDisplay, yDisplay;
::wxDisplaySize (&xDisplay, &yDisplay);
- m_pFrame = new MainFrame(m_docManager, (wxFrame *) NULL, -1, "CTSim", wxPoint(0, 0), wxSize(xDisplay * .75, yDisplay * .755), wxDEFAULT_FRAME_STYLE);
+ m_pFrame = new MainFrame(m_docManager, (wxFrame *) NULL, -1, "CTSim", wxPoint(0, 0),
+ wxSize(nearest<int>(xDisplay * .75), nearest<int>(yDisplay * .755)), wxDEFAULT_FRAME_STYLE);
setIconForFrame (m_pFrame);
m_pFrame->Centre(wxBOTH);
if (m_pConfig)
m_docManager->FileHistoryLoad(*m_pConfig);
-#ifdef CTSIM_WINHELP
- if (! m_pFrame->getWinHelpController().Initialize("ctsim"))
- ::wxMessageBox ("Cannot initialize the help system", "Error");
-#endif
- if (! m_pFrame->getHtmlHelpController().Initialize(::wxGetCwd() + "/ctsim"))
- ::wxMessageBox ("Cannot initialize the help system", "Error");
-
#ifdef CTSIM_MDI
TextFileDocument* pLogDoc = newTextDoc();
if (pLogDoc) {
m_pFrame->GetClientSize(&xSize, &ySize);
int yLogSize = ySize / 3;
pLogDoc->getView()->getFrame()->SetSize (0, ySize - yLogSize, xSize, yLogSize);
+ pLogDoc->getView()->getFrame()->Show (true);
} else
#else
m_pLog = new wxTextCtrl (m_pFrame, -1, "Log Window\n", wxPoint(0, 0), wxSize(0,0), wxTE_MULTILINE | wxTE_READONLY);
#endif
wxLog::SetActiveTarget (new wxLogTextCtrl(m_pLog));
+#ifdef CTSIM_WINHELP
+ if (! m_pFrame->getWinHelpController().Initialize("ctsim"))
+ *m_pLog << "Cannot initialize the Windows Help system" << "\n";
+#endif
+ if (! m_pFrame->getHtmlHelpController().Initialize(::wxGetCwd() + "/ctsim"))
+ *m_pLog << "Cannot initialize the HTML Help system" << "\n";
+
return true;
}
int
CTSimApp::OnExit()
{
- if (theApp->getConfig())
- theApp->getDocManager()->FileHistorySave (*theApp->getConfig());
- delete theApp->getDocManager();
-// m_docManager = NULL;
-
#ifdef HAVE_DMALLOC
dmalloc_shutdown();
#endif
MainFrame::~MainFrame()
{
+ if (theApp->getConfig())
+ theApp->getDocManager()->FileHistorySave (*theApp->getConfig());
+ delete theApp->getDocManager();
+
}
void
MainFrame::OnSize (wxSizeEvent& event)
{
+#ifdef CTSIM_MDI
+ int xSize, ySize;
+ wxMDIParentFrame::GetClientSize(&xSize, &ySize);
+ wxSize sizeClient (xSize, ySize);
+#else
wxSize sizeClient = GetClientSize();
+#endif
wxSize sizeLog = sizeClient;
if (sizeClient.y < 100) {
sizeLog.y = 0;
<< ", 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));
+ ImageFileDocument* pFilterDoc = theApp->newImageDoc();
if (! pFilterDoc) {
sys_error (ERR_SEVERE, "Unable to create filter image");
return;
pFilterDoc->Modify (true);
pFilterDoc->UpdateAllViews();
pFilterDoc->GetFirstView()->OnUpdate (NULL, NULL);
+ pFilterDoc->getView()->getFrame()->SetClientSize(m_iDefaultFilterXSize, m_iDefaultFilterYSize);
+ pFilterDoc->getView()->getFrame()->Show(true);
}
}
ProjectionFileDocument*
CTSimApp::newProjectionDoc()
{
- wxString strFilename (getUntitledFilename());
- strFilename += ".pj";
-
- ProjectionFileDocument* newDoc = dynamic_cast<ProjectionFileDocument*>(m_pDocTemplProjection->CreateDocument (strFilename));
+ ProjectionFileDocument* newDoc = dynamic_cast<ProjectionFileDocument*>(m_pDocTemplProjection->CreateDocument (""));
if (newDoc) {
ProjectionFileView* pView = newDoc->getView();
if (pView) {
wxFrame* pFrame = pView->getFrame();
- if (pFrame)
- pFrame->SetSize(0,0);
+ if (pFrame) {
+ pFrame->SetSize (0,0);
+ pFrame->Show (false);
+ }
}
newDoc->OnNewDocument();
-// newDoc->SetFilename(strFilename, true);
}
return newDoc;
ImageFileDocument*
CTSimApp::newImageDoc()
{
- wxString strFilename (getUntitledFilename());
- strFilename += ".pj";
-
- ImageFileDocument* newDoc = dynamic_cast<ImageFileDocument*>(m_pDocTemplImage->CreateDocument (strFilename));
+ ImageFileDocument* newDoc = dynamic_cast<ImageFileDocument*>(m_pDocTemplImage->CreateDocument (""));
if (newDoc) {
ImageFileView* pView = newDoc->getView();
if (pView) {
wxFrame* pFrame = pView->getFrame();
- if (pFrame)
- pFrame->SetSize(0,0);
+ if (pFrame) {
+ pFrame->SetSize (0,0);
+ pFrame->Show (false);
+ }
}
newDoc->OnNewDocument();
-// newDoc->SetFilename(strFilename, true);
}
return newDoc;
PlotFileDocument*
CTSimApp::newPlotDoc()
{
- wxString strFilename (getUntitledFilename());
- strFilename += ".plt";
-
- PlotFileDocument* newDoc = dynamic_cast<PlotFileDocument*>(m_pDocTemplPlot->CreateDocument (strFilename));
+ PlotFileDocument* newDoc = dynamic_cast<PlotFileDocument*>(m_pDocTemplPlot->CreateDocument (""));
if (newDoc) {
PlotFileView* pView = newDoc->getView();
if (pView) {
wxFrame* pFrame = pView->getFrame();
- if (pFrame)
- pFrame->SetSize(0,0);
+ if (pFrame) {
+ wxSize size;
+ m_pFrame->GetClientSize (&size.x, &size.y);
+ pFrame->SetSize (size.x / 2, size.y / 2);
+ }
}
newDoc->OnNewDocument();
-// newDoc->SetFilename(strFilename, true);
}
return newDoc;
wxString strFilename (getUntitledFilename());
strFilename += ".txt";
- TextFileDocument* newDoc = dynamic_cast<TextFileDocument*>(m_pDocTemplText->CreateDocument (strFilename));
+ TextFileDocument* newDoc = dynamic_cast<TextFileDocument*>(m_pDocTemplText->CreateDocument (""));
if (newDoc) {
TextFileView* pView = newDoc->getView();
if (pView) {
wxFrame* pFrame = pView->getFrame();
- if (pFrame)
- pFrame->SetSize(0,0);
+ if (pFrame) {
+ wxSize size;
+ m_pFrame->GetClientSize (&size.x, &size.y);;
+ pFrame->SetSize (size.x / 2, size.y / 2);
+ pFrame->Show (false);
+ }
}
newDoc->OnNewDocument();
-// newDoc->SetFilename(strFilename, true);
}
return newDoc;
PhantomFileDocument*
CTSimApp::newPhantomDoc()
{
- wxString strFilename (getUntitledFilename());
- strFilename += ".phm";
-
- PhantomFileDocument* newDoc = dynamic_cast<PhantomFileDocument*>(m_pDocTemplPhantom->CreateDocument (strFilename));
+ PhantomFileDocument* newDoc = dynamic_cast<PhantomFileDocument*>(m_pDocTemplPhantom->CreateDocument (""));
if (newDoc) {
PhantomFileView* pView = newDoc->getView();
if (pView) {
wxFrame* pFrame = pView->getFrame();
if (pFrame)
- pFrame->SetSize(0,0);
+ pFrame->SetSize (0,0);
}
newDoc->OnNewDocument();
-// newDoc->SetFilename(strFilename, true);
}
return newDoc;