X-Git-Url: http://git.kpe.io/?p=ctsim.git;a=blobdiff_plain;f=src%2Fctsim.h;h=b944560cf7aee791c892a2f869f683ddcd58096d;hp=6185d8639ed1a09ea960c1d2ba9a21a42aa68f39;hb=67a6c34b5a6f38d34e8cbe66091853f453fd2d7a;hpb=1e88cf0f7fa4f690ea9f110e8ed3f2b5338d0a10 diff --git a/src/ctsim.h b/src/ctsim.h index 6185d86..b944560 100644 --- a/src/ctsim.h +++ b/src/ctsim.h @@ -9,7 +9,7 @@ ** This is part of the CTSim program ** Copyright (C) 1983-2000 Kevin Rosenberg ** -** $Id: ctsim.h,v 1.5 2000/08/25 15:59:13 kevin Exp $ +** $Id: ctsim.h,v 1.15 2000/12/29 19:30:08 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 @@ -28,7 +28,6 @@ #ifndef __CTSIMH__ #define __CTSIMH__ -#include "wx/docview.h" #ifdef HAVE_CONFIG_H #include "config.h" #endif @@ -36,12 +35,24 @@ #include #endif -// Define a new frame +class wxMenu; +class wxDocument; +class ImageFileDocument; +#include + +#include "wx/docview.h" + +// Define a new frame for main window class MainFrame: public wxDocParentFrame { DECLARE_CLASS(MainFrame) private: wxTextCtrl* m_pLog; + wxMenu* m_pWindowMenu; + + enum { MAX_WINDOW_MENUITEMS = 20 }; + wxMenuItem* m_apWindowMenuItems[MAX_WINDOW_MENUITEMS]; + wxDocument* m_apWindowMenuData[MAX_WINDOW_MENUITEMS]; public: MainFrame(wxDocManager *manager, wxFrame *frame, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, const long type); @@ -51,27 +62,58 @@ public: void OnCreatePhantom (wxCommandEvent& event); void OnExit (wxCommandEvent& event); + void OnUpdateUI (wxUpdateUIEvent& event); + wxTextCtrl* getLog() { return m_pLog; } + void OnWindowMenu0 (wxCommandEvent& event); + void OnWindowMenu1 (wxCommandEvent& event); + void OnWindowMenu2 (wxCommandEvent& event); + void OnWindowMenu3 (wxCommandEvent& event); + void OnWindowMenu4 (wxCommandEvent& event); + void OnWindowMenu5 (wxCommandEvent& event); + void OnWindowMenu6 (wxCommandEvent& event); + void OnWindowMenu7 (wxCommandEvent& event); + void OnWindowMenu8 (wxCommandEvent& event); + void OnWindowMenu9 (wxCommandEvent& event); + void OnWindowMenu10 (wxCommandEvent& event); + void OnWindowMenu11 (wxCommandEvent& event); + void OnWindowMenu12 (wxCommandEvent& event); + void OnWindowMenu13 (wxCommandEvent& event); + void OnWindowMenu14 (wxCommandEvent& event); + void OnWindowMenu15 (wxCommandEvent& event); + void OnWindowMenu16 (wxCommandEvent& event); + void OnWindowMenu17 (wxCommandEvent& event); + void OnWindowMenu18 (wxCommandEvent& event); + void OnWindowMenu19 (wxCommandEvent& event); + + void DoWindowMenu (int iMenuPosition, wxCommandEvent& event); + DECLARE_EVENT_TABLE() }; + class wxDocManager; class CTSimApp: public wxApp { public: - CTSimApp(void); - bool OnInit(void); - int OnExit(void); - MainFrame* getMainFrame(void) const + CTSimApp(); + bool OnInit(); + int OnExit(); + MainFrame* getMainFrame() const { return m_pFrame; } - wxTextCtrl* getLog(void) + wxTextCtrl* getLog() { return m_pFrame->getLog(); } wxDocManager* getDocManager() { return m_docManager; } - wxString getUntitledFilename(void); + wxString getUntitledFilename(); + + void getCompatibleImages (const ImageFileDocument* pIFDoc, std::vector& vecIF); + + bool getSetModifyNewDocs() const + { return false; } private: wxDocManager* m_docManager; @@ -97,11 +139,28 @@ enum { IFMENU_FILE_PROPERTIES, PJMENU_FILE_PROPERTIES, PHMMENU_FILE_PROPERTIES, - PJMENU_PROCESS_RECONSTRUCT, + PJMENU_PROCESS_RECONSTRUCT, + IFMENU_PLOT_ROW, + IFMENU_PLOT_COL, IFMENU_VIEW_SCALE_AUTO, - IFMENU_VIEW_SCALE_MINMAX, + IFMENU_VIEW_SCALE_MINMAX, + IFMENU_COMPARE_IMAGES, + IFMENU_COMPARE_ROW, + IFMENU_COMPARE_COL, + IFMENU_PROCESS_INVERTVALUES, + IFMENU_PROCESS_SQRT, + IFMENU_PROCESS_SQUARE, + IFMENU_PROCESS_LOG, + IFMENU_PROCESS_EXP, + IFMENU_PROCESS_FOURIER, + IFMENU_PROCESS_INVERSE_FOURIER, + IFMENU_PROCESS_MAGNITUDE, + IFMENU_PROCESS_PHASE, PHMMENU_PROCESS_RASTERIZE, - PHMMENU_PROCESS_PROJECTIONS, + PHMMENU_PROCESS_PROJECTIONS, + PLOTMENU_VIEW_SCALE_MINMAX, + PLOTMENU_VIEW_SCALE_AUTO, + MAINMENU_WINDOW_BASE, }; #endif