X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=src%2Fviews.h;h=9f57f5588ffa74bce8a213fd6814c1fcd9e18a2d;hb=dd8faeb9c2a1633c96ca31bce81e338a591fab71;hp=4e833bbee920baf543be4dce5979c21038f15f4f;hpb=1fd4f7cc977b9f1499716de10d15656bd50f4816;p=ctsim.git diff --git a/src/views.h b/src/views.h index 4e833bb..9f57f55 100644 --- a/src/views.h +++ b/src/views.h @@ -9,7 +9,7 @@ ** This is part of the CTSim program ** Copyright (C) 1983-2000 Kevin Rosenberg ** -** $Id: views.h,v 1.1 2000/07/13 07:01:59 kevin Exp $ +** $Id: views.h,v 1.29 2001/01/26 00:45:24 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 @@ -33,124 +33,390 @@ #define __VIEWSH__ #include "wx/wx.h" +#include "docs.h" #include "imagefile.h" class ImageFileCanvas; class ImageFileView : public wxView { - DECLARE_DYNAMIC_CLASS(ImageFileView) - - wxMemoryDC m_memoryDC; - wxBitmap* m_pBitmap; - private: - ImageFileCanvas *CreateCanvas(wxView *view, wxFrame *parent); - wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); - - ImageFileCanvas *m_canvas; - wxFrame *m_frame; - bool m_bMinSpecified; - bool m_bMaxSpecified; - double m_minPixel; - double m_maxPixel; + DECLARE_DYNAMIC_CLASS(ImageFileView) + + wxMemoryDC m_memoryDC; + wxBitmap m_bitmap; + + ImageFileCanvas *CreateCanvas(wxView *view, wxFrame *parent); + wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); + wxMenu* m_pFileMenu; + + ImageFileCanvas *m_canvas; + wxFrame *m_frame; + bool m_bMinSpecified; + bool m_bMaxSpecified; + double m_dMinPixel; + double m_dMaxPixel; + double m_dAutoScaleFactor; + + int m_iDefaultExportFormatID; - static bool m_bPColoursInitialized; - static wxColour* m_pColours[256]; + wxWindow* getFrameForChild() +#if CTSIM_MDI + { return theApp->getMainFrame()->GetClientWindow(); } +#else + { return m_frame; } +#endif public: - ImageFileView(void); - ~ImageFileView(void); + ImageFileView(void); + virtual ~ImageFileView(void); + void canvasClosed() + { m_canvas = NULL; m_frame = NULL; } - bool OnCreate(wxDocument *doc, long flags); - void OnDraw(wxDC* dc); - void OnUpdate(wxView *sender, wxObject *hint = NULL); - bool OnClose (bool deleteWindow = true); - void OnProperties (wxCommandEvent& event); + wxMenu* getFileMenu() + { return m_pFileMenu; } - DECLARE_EVENT_TABLE() + bool OnCreate(wxDocument *doc, long flags); + void OnDraw(wxDC* dc); + void OnUpdate(wxView *sender, wxObject *hint = NULL); + bool OnClose (bool deleteWindow = true); + + void OnScaleSize (wxCommandEvent& event); + void OnExport (wxCommandEvent& event); + + void OnProperties (wxCommandEvent& event); + void OnCompare (wxCommandEvent& event); + + void OnInvertValues (wxCommandEvent& event); + void OnSquare (wxCommandEvent& event); + void OnSquareRoot (wxCommandEvent& event); + void OnLog (wxCommandEvent& event); + void OnExp (wxCommandEvent& event); + void OnAdd (wxCommandEvent& event); + void OnSubtract (wxCommandEvent& event); + void OnMultiply (wxCommandEvent& event); + void OnDivide (wxCommandEvent& event); + void OnFourier (wxCommandEvent& event); + void OnInverseFourier (wxCommandEvent& event); + void OnShuffleNaturalToFourierOrder (wxCommandEvent& event); + void OnShuffleFourierToNaturalOrder (wxCommandEvent& event); + +#ifdef HAVE_FFT + void OnFFT (wxCommandEvent& event); + void OnIFFT (wxCommandEvent& event); + void OnFFTRows (wxCommandEvent& event); + void OnIFFTRows (wxCommandEvent& event); + void OnFFTCols (wxCommandEvent& event); + void OnIFFTCols (wxCommandEvent& event); +#endif + + void OnMagnitude (wxCommandEvent& event); + void OnPhase (wxCommandEvent& event); + + void OnScaleAuto (wxCommandEvent& event); + void OnScaleMinMax (wxCommandEvent& event); + void OnScaleFull (wxCommandEvent& event); + void OnPlotRow (wxCommandEvent& event); + void OnPlotCol (wxCommandEvent& event); +#if HAVE_FFT + void OnPlotFFTRow (wxCommandEvent& event); + void OnPlotFFTCol (wxCommandEvent& event); +#endif + void OnPlotHistogram (wxCommandEvent& event); + void OnCompareRow (wxCommandEvent& event); + void OnCompareCol (wxCommandEvent& event); + + wxFrame* getFrame() + { return m_frame; } + + ImageFileDocument* GetDocument(void) + { return dynamic_cast(wxView::GetDocument()); } + + DECLARE_EVENT_TABLE() }; class ImageFileCanvas: public wxScrolledWindow { +private: + + int m_xCursor; + int m_yCursor; + ImageFileView* m_pView; + public: - ImageFileView* m_pView; - - ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); - virtual void OnDraw(wxDC& dc); - void OnMouseEvent(wxMouseEvent& event); + ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); + virtual ~ImageFileCanvas(); + + virtual void OnDraw(wxDC& dc); + void OnMouseEvent(wxMouseEvent& event); + void DrawRubberBandCursor (wxDC& dc, int x, int y); + bool GetCurrentCursor (int& x, int& y); + + virtual wxSize GetBestSize() const; + void setView(ImageFileView* pView) + { m_pView = pView; } + - DECLARE_EVENT_TABLE() + DECLARE_EVENT_TABLE() }; -class MyTextWindow: public wxTextCtrl +class ProjectionFileCanvas; +class ProjectionFileView : public wxView { -public: - wxView *m_pView; + DECLARE_DYNAMIC_CLASS(ProjectionFileView) - MyTextWindow(wxView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); + wxMemoryDC m_memoryDC; + wxBitmap m_bitmap; + +private: + ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent); + wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); + + ProjectionFileCanvas *m_canvas; + wxFrame *m_frame; + wxMenu* m_pFileMenu; + + int m_iDefaultNX; + int m_iDefaultNY; + int m_iDefaultFilter; + int m_iDefaultFilterMethod; + double m_dDefaultFilterParam; + int m_iDefaultFilterGeneration; + int m_iDefaultZeropad; + int m_iDefaultInterpolation; + int m_iDefaultInterpParam; + int m_iDefaultBackprojector; + int m_iDefaultTrace; + + int m_iDefaultPolarNX; + int m_iDefaultPolarNY; + int m_iDefaultPolarInterpolation; + int m_iDefaultPolarZeropad; + + wxWindow* getFrameForChild() +#if CTSIM_MDI + { return theApp->getMainFrame()->GetClientWindow(); } +#else + { return m_frame; } +#endif + +public: + ProjectionFileView(void); + virtual ~ProjectionFileView(void); + void canvasClosed() + { m_canvas = NULL; m_frame = NULL; } + + bool OnCreate(wxDocument *doc, long flags); + void OnDraw(wxDC* dc); + void OnUpdate(wxView *sender, wxObject *hint = NULL); + bool OnClose (bool deleteWindow = true); + void OnProperties (wxCommandEvent& event); + void OnReconstructFBP (wxCommandEvent& event); + void OnReconstructFourier (wxCommandEvent& event); + void OnConvertPolar (wxCommandEvent& event); + void OnConvertFFTPolar (wxCommandEvent& event); + + wxFrame* getFrame () { return m_frame; } + + wxMenu* getFileMenu() { return m_pFileMenu; } + + ProjectionFileDocument* GetDocument(void) + { return dynamic_cast(wxView::GetDocument()); } + DECLARE_EVENT_TABLE() +}; + +class ProjectionFileCanvas: public wxScrolledWindow +{ +private: + ProjectionFileView* m_pView; + +public: + ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); + virtual ~ProjectionFileCanvas() ; + + virtual wxSize GetBestSize() const; + virtual void OnDraw(wxDC& dc); + void setView(ProjectionFileView* pView) + { m_pView = pView; } }; -class TextEditView: public wxView +class PhantomCanvas; +class PhantomView : public wxView { - DECLARE_DYNAMIC_CLASS(TextEditView) private: - wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); + DECLARE_DYNAMIC_CLASS(PhantomView) + DECLARE_EVENT_TABLE() + + PhantomCanvas *CreateCanvas(wxView *view, wxFrame *parent); + wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); + + PhantomCanvas *m_canvas; + wxFrame *m_frame; + wxMenu* m_pFileMenu; + + int m_iDefaultNDet; + int m_iDefaultNView; + int m_iDefaultNSample; + int m_iDefaultGeometry; + int m_iDefaultTrace; + double m_dDefaultRotation; + double m_dDefaultFocalLength; + double m_dDefaultFieldOfView; + + int m_iDefaultRasterNX; + int m_iDefaultRasterNY; + int m_iDefaultRasterNSamples; + + wxWindow* getFrameForChild() +#if CTSIM_MDI + { return theApp->getMainFrame()->GetClientWindow(); } +#else + { return m_frame; } +#endif public: - wxFrame *frame; - MyTextWindow *textsw; - - TextEditView(): wxView() { frame = (wxFrame *) NULL; textsw = (MyTextWindow *) NULL; } - ~TextEditView(void) {} - - bool OnCreate(wxDocument *doc, long flags); - void OnDraw(wxDC* dc); - void OnUpdate(wxView *sender, wxObject *hint = (wxObject *) NULL); - bool OnClose(bool deleteWindow = TRUE); + PhantomView(void); + virtual ~PhantomView(void); + void canvasClosed() + { m_canvas = NULL; m_frame = NULL; } + + bool OnCreate(wxDocument *doc, long flags); + void OnUpdate(wxView *sender, wxObject *hint = NULL); + bool OnClose (bool deleteWindow = true); + void OnDraw(wxDC* dc); + void OnProperties (wxCommandEvent& event); + void OnRasterize (wxCommandEvent& event); + void OnProjections (wxCommandEvent& event); + + PhantomDocument* GetDocument(void) + { return dynamic_cast(wxView::GetDocument()); } + + wxMenu* getFileMenu() { return m_pFileMenu; } }; -class ProjectionFileCanvas; -class ProjectionFileView : public wxView +class PhantomCanvas: public wxScrolledWindow { - DECLARE_DYNAMIC_CLASS(ProjectionFileView) +private: + PhantomView* m_pView; - wxMemoryDC m_memoryDC; - wxBitmap* m_pBitmap; +public: + PhantomCanvas (PhantomView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); + virtual ~PhantomCanvas(); + + void setView(PhantomView* pView) + { m_pView = pView; } + virtual void OnDraw(wxDC& dc); +}; + +class PlotFileCanvas; +class PlotFileView : public wxView +{ + DECLARE_DYNAMIC_CLASS(PlotFileView) + +private: + PlotFileCanvas *CreateCanvas(wxView *view, wxFrame *parent); + wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); + + PlotFileCanvas *m_canvas; + wxFrame *m_frame; + wxMenu* m_pFileMenu; + EZPlot* m_pEZPlot; + + bool m_bMinSpecified; + bool m_bMaxSpecified; + double m_dMinPixel; + double m_dMaxPixel; + double m_dAutoScaleFactor; + + wxWindow* getFrameForChild() +#if CTSIM_MDI + { return theApp->getMainFrame()->GetClientWindow(); } +#else + { return m_frame; } +#endif + +public: + PlotFileView(void); + virtual ~PlotFileView(void); + void canvasClosed() + { m_canvas = NULL; m_frame = NULL; } + + bool OnCreate(wxDocument *doc, long flags); + void OnDraw(wxDC* dc); + void OnUpdate(wxView *sender, wxObject *hint = NULL); + bool OnClose (bool deleteWindow = true); + void OnProperties (wxCommandEvent& event); + void OnScaleMinMax (wxCommandEvent& event); + void OnScaleAuto (wxCommandEvent& event); + void OnScaleFull (wxCommandEvent& event); + + wxFrame* getFrame () + { return m_frame; } + + wxMenu* getFileMenu() { return m_pFileMenu; } + PlotFileDocument* GetDocument(void) + { return dynamic_cast(wxView::GetDocument()); } + + DECLARE_EVENT_TABLE() +}; + +class PlotFileCanvas: public wxScrolledWindow +{ private: - ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent); - wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); + PlotFileView* m_pView; + +public: + PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); + virtual ~PlotFileCanvas(); + + virtual void OnDraw(wxDC& dc); + + void setView (PlotFileView* pView) + { m_pView = pView; } +}; - ProjectionFileCanvas *m_canvas; - wxFrame *m_frame; - static bool m_bPColoursInitialized; - static wxColour* m_pColours[256]; +class TextEditCanvas; +class TextEditView: public wxView +{ +private: + DECLARE_DYNAMIC_CLASS(TextEditView) + wxFrame *m_pFrame; + wxMenu* m_pFileMenu; + TextEditCanvas *m_pCanvas; + public: - ProjectionFileView(void); - ~ProjectionFileView(void); + TextEditView() + : wxView() , m_pFrame(0), m_pCanvas(0) + {} + ~TextEditView(); + void canvasClosed() + { m_pFrame = NULL; } + + wxFrame *CreateChildFrame(wxDocument *doc, wxView *view); - bool OnCreate(wxDocument *doc, long flags); - void OnDraw(wxDC* dc); - void OnUpdate(wxView *sender, wxObject *hint = NULL); - bool OnClose (bool deleteWindow = true); - void OnProperties (wxCommandEvent& event); - void OnReconstruct (wxCommandEvent& event); + bool OnCreate (wxDocument *doc, long flags); + void OnDraw (wxDC *dc); + void OnUpdate (wxView *sender, wxObject *hint = (wxObject *) NULL); + bool OnClose (bool deleteWindow = TRUE); - DECLARE_EVENT_TABLE() + TextEditCanvas* getTextCtrl() { return m_pCanvas; } + + wxMenu* getFileMenu() { return m_pFileMenu; } }; -class ProjectionFileCanvas: public wxScrolledWindow +class TextEditCanvas: public wxTextCtrl { -public: - ProjectionFileView* m_pView; - - ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); - virtual void OnDraw(wxDC& dc); + TextEditView *m_pView; + +public: + TextEditCanvas (TextEditView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, long style); + ~TextEditCanvas (); }; #endif +