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.22 2001/02/22 11:05:38 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 std::vector<ThreadedReconstructor*> m_vecpActiveReconstructors;
97 wxCriticalSection m_criticalSection;
100 virtual bool OnSaveDocument (const wxString& filename);
101 virtual bool OnOpenDocument (const wxString& filename);
102 virtual bool IsModified () const;
103 virtual void Modify (bool mod);
105 ProjectionFileDocument ()
106 : m_bBadFileOpen(false)
108 m_pProjectionFile = new Projections;
111 virtual ~ProjectionFileDocument ();
113 const Projections& getProjections () const { return *m_pProjectionFile; }
114 Projections& getProjections () { return *m_pProjectionFile; }
116 void setProjections (Projections* pProjections)
117 { delete m_pProjectionFile;
118 m_pProjectionFile = pProjections;
121 ProjectionFileView* getView() const;
122 bool getBadFileOpen() const { return m_bBadFileOpen; }
123 void setBadFileOpen() { m_bBadFileOpen = true; }
124 void addReconstructor (ThreadedReconstructor* pRecon);
125 void removeReconstructor (ThreadedReconstructor* pRecon);
129 class PhantomFileDocument: public wxDocument
132 DECLARE_DYNAMIC_CLASS(PhantomFileDocument)
135 wxString m_namePhantom;
139 PhantomFileDocument ()
140 : m_idPhantom(Phantom::PHM_INVALID), m_bBadFileOpen(false)
143 virtual ~PhantomFileDocument ()
146 const int getPhantomID () const { return m_idPhantom; }
148 const wxString& getPhantomName () const { return m_namePhantom; }
150 const Phantom& getPhantom () const { return m_phantom; }
152 Phantom& getPhantom () { return m_phantom; }
154 virtual bool OnOpenDocument (const wxString& filename);
155 virtual bool OnSaveDocument (const wxString& filename);
156 virtual bool IsModified () const;
157 virtual void Modify (bool mod);
158 PhantomFileView* getView() const;
159 bool getBadFileOpen() const { return m_bBadFileOpen; }
160 void setBadFileOpen() { m_bBadFileOpen = true; }
164 class PlotFileDocument: public wxDocument
167 DECLARE_DYNAMIC_CLASS(PlotFileDocument)
174 : m_bBadFileOpen(false)
177 virtual ~PlotFileDocument ()
180 const wxString& getPlotName () const
181 { return m_namePlot; }
183 const PlotFile& getPlotFile () const
186 PlotFile& getPlotFile ()
189 virtual bool OnOpenDocument (const wxString& filename);
190 virtual bool OnSaveDocument (const wxString& filename);
191 virtual bool IsModified () const;
192 virtual void Modify (bool mod);
193 PlotFileView* getView() const;
194 bool getBadFileOpen() const { return m_bBadFileOpen; }
195 void setBadFileOpen() { m_bBadFileOpen = true; }
199 class TextFileDocument: public wxDocument
202 DECLARE_DYNAMIC_CLASS(TextFileDocument)
206 TextFileDocument(void)
207 : m_bBadFileOpen(false)
210 virtual ~TextFileDocument(void) {}
212 virtual bool OnSaveDocument(const wxString& filename);
213 virtual bool OnOpenDocument(const wxString& filename);
214 virtual bool IsModified(void) const;
216 wxTextCtrl* getTextCtrl();
218 TextFileView* getView() const;
219 bool getBadFileOpen() const { return m_bBadFileOpen; }
220 void setBadFileOpen() { m_bBadFileOpen = true; }
228 typedef GLfloat glTripleFloat[3];
230 class Graph3dFileDocument: public wxDocument
232 friend Graph3dFileView;
235 DECLARE_DYNAMIC_CLASS(Graph3dFileDocument)
238 glTripleFloat* m_pVertices;
239 glTripleFloat* m_pNormals;
242 ImageFileArray m_array;
245 Graph3dFileDocument(void);
246 virtual ~Graph3dFileDocument(void);
248 virtual bool OnSaveDocument (const wxString& filename);
249 virtual bool OnOpenDocument (const wxString& filename);
250 virtual bool IsModified () const;
252 Graph3dFileView* getView() const;
253 bool getBadFileOpen() const { return m_bBadFileOpen; }
254 void setBadFileOpen() { m_bBadFileOpen = true; }
255 bool createFromImageFile (const ImageFile& rImageFile);
257 int nx() const { return m_nx; }
258 int ny() const { return m_ny; }
259 ImageFileArray getArray() { return m_array; }
260 ImageFileArrayConst getArray() const { return m_array; }
262 #endif // wxUSE_GLCANVAS