1 /*****************************************************************************
5 ** Purpose: Header file for Document routines of CTSim program
6 ** Programmer: Kevin Rosenberg
7 ** Date Started: July 2000
9 ** This is part of the CTSim program
10 ** Copyright (c) 1983-2001 Kevin Rosenberg
12 ** $Id: docs.h,v 1.23 2001/02/23 18:56:56 kevin Exp $
14 ** This program is free software; you can redistribute it and/or modify
15 ** it under the terms of the GNU General Public License (version 2) as
16 ** published by the Free Software Foundation.
18 ** This program is distributed in the hope that it will be useful,
19 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
20 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 ** GNU General Public License for more details.
23 ** You should have received a copy of the GNU General Public License
24 ** along with this program; if not, write to the Free Software
25 ** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
26 ******************************************************************************/
35 #include "wx/docview.h"
38 #include "imagefile.h"
40 #include "projections.h"
42 #include "threadrecon.h"
44 class ProjectionFileView;
45 class PhantomFileView;
49 class Graph3dFileView;
51 class ImageFileDocument: public wxDocument
54 DECLARE_DYNAMIC_CLASS(ImageFileDocument)
55 ImageFile* m_pImageFile;
59 virtual bool OnSaveDocument (const wxString& filename);
60 virtual bool OnOpenDocument (const wxString& filename);
61 virtual bool IsModified () const;
62 virtual bool Revert ();
63 virtual void Modify (bool mod);
66 : m_bBadFileOpen(false)
68 m_pImageFile = new ImageFile;
71 virtual ~ImageFileDocument ()
76 const ImageFile& getImageFile() const { return *m_pImageFile; }
77 ImageFile& getImageFile() { return *m_pImageFile; }
78 void setImageFile (ImageFile* pImageFile)
81 m_pImageFile = pImageFile;
84 ImageFileView* getView() const;
85 bool getBadFileOpen() const { return m_bBadFileOpen; }
86 void setBadFileOpen() { m_bBadFileOpen = true; }
90 class ProjectionFileDocument: public wxDocument
93 DECLARE_DYNAMIC_CLASS(ProjectionFileDocument)
94 Projections* m_pProjectionFile;
96 typedef BackgroundSupervisor BackgroundObject;
97 typedef std::vector<BackgroundObject*> BackgroundContainer ;
98 BackgroundContainer m_vecpBackgroundSupervisors;
99 wxCriticalSection m_criticalSection;
102 virtual bool OnSaveDocument (const wxString& filename);
103 virtual bool OnOpenDocument (const wxString& filename);
104 virtual bool IsModified () const;
105 virtual void Modify (bool mod);
107 ProjectionFileDocument ()
108 : m_bBadFileOpen(false)
110 m_pProjectionFile = new Projections;
113 virtual ~ProjectionFileDocument ();
115 const Projections& getProjections () const { return *m_pProjectionFile; }
116 Projections& getProjections () { return *m_pProjectionFile; }
118 void setProjections (Projections* pProjections)
119 { delete m_pProjectionFile;
120 m_pProjectionFile = pProjections;
123 ProjectionFileView* getView() const;
124 bool getBadFileOpen() const { return m_bBadFileOpen; }
125 void setBadFileOpen() { m_bBadFileOpen = true; }
127 void OnAddBackground (wxCommandEvent& event);
128 void OnRemoveBackground (wxCommandEvent& event);
130 void addReconstructor (BackgroundSupervisor* pRecon);
131 void removeReconstructor (BackgroundSupervisor* pRecon);
133 DECLARE_EVENT_TABLE()
137 class PhantomFileDocument: public wxDocument
140 DECLARE_DYNAMIC_CLASS(PhantomFileDocument)
143 wxString m_namePhantom;
147 PhantomFileDocument ()
148 : m_idPhantom(Phantom::PHM_INVALID), m_bBadFileOpen(false)
151 virtual ~PhantomFileDocument ()
154 const int getPhantomID () const { return m_idPhantom; }
156 const wxString& getPhantomName () const { return m_namePhantom; }
158 const Phantom& getPhantom () const { return m_phantom; }
160 Phantom& getPhantom () { return m_phantom; }
162 virtual bool OnOpenDocument (const wxString& filename);
163 virtual bool OnSaveDocument (const wxString& filename);
164 virtual bool IsModified () const;
165 virtual void Modify (bool mod);
166 PhantomFileView* getView() const;
167 bool getBadFileOpen() const { return m_bBadFileOpen; }
168 void setBadFileOpen() { m_bBadFileOpen = true; }
172 class PlotFileDocument: public wxDocument
175 DECLARE_DYNAMIC_CLASS(PlotFileDocument)
182 : m_bBadFileOpen(false)
185 virtual ~PlotFileDocument ()
188 const wxString& getPlotName () const
189 { return m_namePlot; }
191 const PlotFile& getPlotFile () const
194 PlotFile& getPlotFile ()
197 virtual bool OnOpenDocument (const wxString& filename);
198 virtual bool OnSaveDocument (const wxString& filename);
199 virtual bool IsModified () const;
200 virtual void Modify (bool mod);
201 PlotFileView* getView() const;
202 bool getBadFileOpen() const { return m_bBadFileOpen; }
203 void setBadFileOpen() { m_bBadFileOpen = true; }
207 class TextFileDocument: public wxDocument
210 DECLARE_DYNAMIC_CLASS(TextFileDocument)
214 TextFileDocument(void)
215 : m_bBadFileOpen(false)
218 virtual ~TextFileDocument(void) {}
220 virtual bool OnSaveDocument(const wxString& filename);
221 virtual bool OnOpenDocument(const wxString& filename);
222 virtual bool IsModified(void) const;
224 wxTextCtrl* getTextCtrl();
226 TextFileView* getView() const;
227 bool getBadFileOpen() const { return m_bBadFileOpen; }
228 void setBadFileOpen() { m_bBadFileOpen = true; }
236 typedef GLfloat glTripleFloat[3];
238 class Graph3dFileDocument: public wxDocument
240 friend Graph3dFileView;
243 DECLARE_DYNAMIC_CLASS(Graph3dFileDocument)
246 glTripleFloat* m_pVertices;
247 glTripleFloat* m_pNormals;
250 ImageFileArray m_array;
253 Graph3dFileDocument(void);
254 virtual ~Graph3dFileDocument(void);
256 virtual bool OnSaveDocument (const wxString& filename);
257 virtual bool OnOpenDocument (const wxString& filename);
258 virtual bool IsModified () const;
260 Graph3dFileView* getView() const;
261 bool getBadFileOpen() const { return m_bBadFileOpen; }
262 void setBadFileOpen() { m_bBadFileOpen = true; }
263 bool createFromImageFile (const ImageFile& rImageFile);
265 int nx() const { return m_nx; }
266 int ny() const { return m_ny; }
267 ImageFileArray getArray() { return m_array; }
268 ImageFileArrayConst getArray() const { return m_array; }
270 #endif // wxUSE_GLCANVAS