r427: Changes for MDI support
[ctsim.git] / src / ctsim.h
index 06c18b35c8b9e200cc3e10a961a3548a32753eec..103f08aa195d1113ef91eeaf813fcf52f18414b0 100644 (file)
@@ -9,7 +9,7 @@
 **  This is part of the CTSim program
 **  Copyright (C) 1983-2000 Kevin Rosenberg
 **
-**  $Id: ctsim.h,v 1.24 2001/01/13 10:14:06 kevin Exp $
+**  $Id: ctsim.h,v 1.29 2001/01/20 08:10:33 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
 
 #ifdef MSVC
-// #define CTSIM_MDI 1
+#define CTSIM_MDI 1
 #endif
 
+#if defined(CTSIM_MDI) && !wxUSE_MDI_ARCHITECTURE
+#error You must set wxUSE_MDI_ARCHITECTURE to 1 in setup.h!
+#endif
+#ifdef CTSIM_MDI
+#include "wx/docmdi.h"
+#endif
 
 class wxMenu;
 class wxDocument;
@@ -54,9 +60,15 @@ class ImageFileDocument;
 #include "wx/docview.h"
 #include "wx/textctrl.h"
 #include "wx/menu.h"
+#include "wx/help.h"
+#include "wx/html/helpctrl.h"
 #include "dlgezplot.h"
 
 
+#if defined(__WXMSW__)
+#define CTSIM_WINHELP   1
+#endif
+
 // Define a new frame for main window
 #if CTSIM_MDI
 class MainFrame: public wxMDIParentFrame
@@ -83,14 +95,36 @@ private:
   double m_dDefaultFilterInputScale;
   double m_dDefaultFilterOutputScale;
   
+#if CTSIM_WINHELP
+  wxWinHelpController      m_winHelp;
+#endif
+  wxHtmlHelpController     m_htmlHelp;
   
 public:
   MainFrame(wxDocManager *manager, wxFrame *frame, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, const long type);
-  
+
+  void OnMRUFile (wxCommandEvent& event);
+
+  void OnSize (wxSizeEvent& event);
+
+#if CTSIM_WINHELP
+  wxWinHelpController&   getWinHelpController()
+  {return m_winHelp; }
+#endif
+  wxHtmlHelpController&  getHtmlHelpController()
+  { return m_htmlHelp; }
+
+  void showHelp (int commandID);
+
   void OnAbout (wxCommandEvent& event);
+  void OnHelpTopics (wxCommandEvent& event);
   void OnHelpContents (wxCommandEvent& event);
   void OnCreatePhantom (wxCommandEvent& event);
   
+#if defined(CTSIM_WINHELP) && (defined(DEBUG) || defined(_DEBUG))
+  void OnHelpSecondary (wxCommandEvent& event);
+#endif
+
   void OnCreateFilter (wxCommandEvent& event);
   void OnExit (wxCommandEvent& event);
   
@@ -98,7 +132,7 @@ public:
   
   wxTextCtrl* getLog() 
   { return m_pLog; }
-  
+
   void OnWindowMenu0 (wxCommandEvent& event);
   void OnWindowMenu1 (wxCommandEvent& event);
   void OnWindowMenu2 (wxCommandEvent& event);
@@ -135,8 +169,10 @@ public:
   int OnExit();
   MainFrame* getMainFrame() const
   { return m_pFrame; }
+
   wxTextCtrl* getLog()
   { return m_pFrame->getLog(); }
+
   wxDocManager* getDocManager() 
   { return m_docManager; }
   
@@ -167,11 +203,12 @@ DECLARE_APP(CTSimApp)
 
 extern class CTSimApp* theApp;
 
-
 enum {
-  MAINMENU_HELP_ABOUT = 500,
-    MAINMENU_WINDOW_BASE,
+    MAINMENU_WINDOW_BASE = 500,
+    MAINMENU_HELP_ABOUT = 600,
     MAINMENU_HELP_CONTENTS,
+    MAINMENU_HELP_TOPICS,
+    MAINMENU_HELP_SECONDARY,
     MAINMENU_FILE_CREATE_PHANTOM,
     
     MAINMENU_FILE_CREATE_FILTER,
@@ -229,8 +266,7 @@ enum {
     
     PLOTMENU_VIEW_SCALE_MINMAX,
     PLOTMENU_VIEW_SCALE_AUTO,
-    PLOTMENU_VIEW_SCALE_FULL,
-    
+    PLOTMENU_VIEW_SCALE_FULL,    
 };
 
 #endif