+ if (!GetDocument()->Close())
+ return false;
+
+ m_canvas->Clear();
+ m_canvas->m_pView = NULL;
+ m_canvas = NULL;
+ wxString s(theApp->GetAppName());
+ if (m_frame)
+ m_frame->SetTitle(s);
+ SetFrame(NULL);
+
+ Activate(false);
+
+ if (deleteWindow) {
+ delete m_frame;
+ return true;
+ }
+ return true;
+}
+\r
+\r
+void\r
+ImageFileView::OnPlotRow (wxCommandEvent& event)\r
+{\r
+ int xCursor, yCursor;\r
+ if (! m_canvas->GetCurrentCursor (xCursor, yCursor)) {\r
+ wxMessageBox ("No row selected. Please use left mouse button on image to select column","Error");\r
+ return;\r
+ }\r
+ \r
+ const ImageFile& rIF = dynamic_cast<ImageFileDocument*>(GetDocument())->getImageFile();\r
+ ImageFileArrayConst v = rIF.getArray();\r
+ int nx = rIF.nx();\r
+ int ny = rIF.ny();\r
+ \r
+ if (v != NULL && yCursor < ny) {\r
+ double* pX = new double [nx];\r
+ double* pY = new double [nx];\r
+ for (int i = 0; i < nx; i++) {\r
+ pX[i] = i;\r
+ pY[i] = v[i][yCursor];\r
+ }\r
+ PlotFileDocument* pPlotDoc = dynamic_cast<PlotFileDocument*>(theApp->getDocManager()->CreateDocument("untitled.plt", wxDOC_SILENT));\r
+ if (! pPlotDoc) {\r
+ sys_error (ERR_SEVERE, "Internal error: unable to create Plot file");\r
+ } else {\r
+ PlotFile& rPlotFile = pPlotDoc->getPlotFile();\r
+ std::ostringstream os;\r
+ os << "Row " << yCursor;\r
+ std::string title("title ");\r
+ title += os.str();\r
+ rPlotFile.addEzsetCommand (title.c_str());\r
+ rPlotFile.addEzsetCommand ("xlabel Column");\r
+ rPlotFile.addEzsetCommand ("ylabel Pixel Value");\r
+ rPlotFile.addEzsetCommand ("lxfrac 0");\r
+ rPlotFile.addEzsetCommand ("box");\r
+ rPlotFile.addEzsetCommand ("grid");\r
+ rPlotFile.setCurveSize (2, nx);\r
+ rPlotFile.addColumn (0, pX);\r
+ rPlotFile.addColumn (1, pY);\r
+ }\r
+ delete pX;\r
+ delete pY;\r
+ if (theApp->getSetModifyNewDocs())\r
+ pPlotDoc->Modify(true);\r
+ pPlotDoc->UpdateAllViews();\r
+ }\r
+}\r
+
+void\r
+ImageFileView::OnPlotCol (wxCommandEvent& event)\r
+{\r
+ int xCursor, yCursor;\r
+ if (! m_canvas->GetCurrentCursor (xCursor, yCursor)) {\r
+ wxMessageBox ("No column selected. Please use left mouse button on image to select column","Error");\r
+ return;\r
+ }\r
+ \r
+ const ImageFile& rIF = dynamic_cast<ImageFileDocument*>(GetDocument())->getImageFile();\r
+ ImageFileArrayConst v = rIF.getArray();\r
+ int nx = rIF.nx();\r
+ int ny = rIF.ny();\r
+ \r
+ if (v != NULL && xCursor < nx) {\r
+ double* pX = new double [ny];\r
+ double* pY = new double [ny];\r
+ for (int i = 0; i < ny; i++) {\r
+ pX[i] = i;\r
+ pY[i] = v[xCursor][i];\r
+ }\r
+ PlotFileDocument* pPlotDoc = dynamic_cast<PlotFileDocument*>(theApp->getDocManager()->CreateDocument("untitled.plt", wxDOC_SILENT));\r
+ if (! pPlotDoc) {\r
+ sys_error (ERR_SEVERE, "Internal error: unable to create Plot file");\r
+ } else {\r
+ PlotFile& rPlotFile = pPlotDoc->getPlotFile();\r
+ std::ostringstream os;\r
+ os << "Column " << xCursor;\r
+ std::string title("title ");\r
+ title += os.str();\r
+ rPlotFile.addEzsetCommand (title.c_str());\r
+ rPlotFile.addEzsetCommand ("xlabel Row");\r
+ rPlotFile.addEzsetCommand ("ylabel Pixel Value");\r
+ rPlotFile.addEzsetCommand ("lxfrac 0");\r
+ rPlotFile.addEzsetCommand ("box");\r
+ rPlotFile.addEzsetCommand ("grid");\r
+ rPlotFile.setCurveSize (2, nx);\r
+ rPlotFile.addColumn (0, pX);\r
+ rPlotFile.addColumn (1, pY);\r
+ }\r
+ delete pX;\r
+ delete pY;\r
+ if (theApp->getSetModifyNewDocs())\r
+ pPlotDoc->Modify(true);\r
+ pPlotDoc->UpdateAllViews();\r
+ }\r
+}\r
+\r
+void\r
+ImageFileView::OnCompareCol (wxCommandEvent& event)\r
+{\r
+ int xCursor, yCursor;\r
+ if (! m_canvas->GetCurrentCursor (xCursor, yCursor)) {\r
+ wxMessageBox ("No column selected. Please use left mouse button on image to select column","Error");\r
+ return;\r
+ }\r
+ \r
+ std::vector<ImageFileDocument*> vecIFDoc;\r
+ theApp->getCompatibleImages (GetDocument(), vecIFDoc);\r
+ if (vecIFDoc.size() == 0) {\r
+ wxMessageBox ("No compatible images for Column Comparison", "Error");\r
+ return;\r
+ }\r
+ DialogGetComparisonImage dialogGetCompare (m_frame, "Get Comparison Image", vecIFDoc, false);\r
+ \r
+ if (dialogGetCompare.ShowModal() == wxID_OK) {\r
+ ImageFileDocument* pCompareDoc = dialogGetCompare.getImageFileDocument();\r
+ const ImageFile& rIF = GetDocument()->getImageFile();\r
+ const ImageFile& rCompareIF = pCompareDoc->getImageFile();\r
+ \r
+ ImageFileArrayConst v1 = rIF.getArray();\r
+ ImageFileArrayConst v2 = rCompareIF.getArray();\r
+ int nx = rIF.nx();\r
+ int ny = rIF.ny();\r
+ \r
+ if (v1 != NULL && xCursor < nx) {\r
+ double* pX = new double [ny];\r
+ double* pY1 = new double [ny];\r
+ double* pY2 = new double [ny];\r
+ for (int i = 0; i < ny; i++) {\r
+ pX[i] = i;\r
+ pY1[i] = v1[xCursor][i];\r
+ pY2[i] = v2[xCursor][i];\r
+ }\r
+ PlotFileDocument* pPlotDoc = dynamic_cast<PlotFileDocument*>(theApp->getDocManager()->CreateDocument("untitled.plt", wxDOC_SILENT));\r
+ if (! pPlotDoc) {\r
+ sys_error (ERR_SEVERE, "Internal error: unable to create Plot file");\r
+ } else {\r
+ PlotFile& rPlotFile = pPlotDoc->getPlotFile();\r
+ std::ostringstream os;\r
+ os << "Column " << xCursor << " Comparison";\r
+ std::string title("title ");\r
+ title += os.str();\r
+ rPlotFile.addEzsetCommand (title.c_str());\r
+ rPlotFile.addEzsetCommand ("xlabel Row");\r
+ rPlotFile.addEzsetCommand ("ylabel Pixel Value");\r
+ rPlotFile.addEzsetCommand ("lxfrac 0");\r
+ rPlotFile.addEzsetCommand ("curve 1");\r
+ rPlotFile.addEzsetCommand ("color 2");\r
+ rPlotFile.addEzsetCommand ("curve 2");\r
+ rPlotFile.addEzsetCommand ("color 4");\r
+ rPlotFile.addEzsetCommand ("dash 5");\r
+ rPlotFile.addEzsetCommand ("box");\r
+ rPlotFile.addEzsetCommand ("grid");\r
+ rPlotFile.setCurveSize (3, nx);\r
+ rPlotFile.addColumn (0, pX);\r
+ rPlotFile.addColumn (1, pY1);\r
+ rPlotFile.addColumn (2, pY2);\r
+ }\r
+ delete pX;\r
+ delete pY1;\r
+ delete pY2;\r
+ if (theApp->getSetModifyNewDocs())\r
+ pPlotDoc->Modify(true);\r
+ pPlotDoc->UpdateAllViews();\r
+ }\r
+ }\r
+}\r
+
+void\r
+ImageFileView::OnCompareRow (wxCommandEvent& event)\r
+{\r
+ int xCursor, yCursor;\r
+ if (! m_canvas->GetCurrentCursor (xCursor, yCursor)) {\r
+ wxMessageBox ("No column selected. Please use left mouse button on image to select column","Error");\r
+ return;\r
+ }\r
+ \r
+ std::vector<ImageFileDocument*> vecIFDoc;\r
+ theApp->getCompatibleImages (GetDocument(), vecIFDoc);\r
+ \r
+ if (vecIFDoc.size() == 0) {\r
+ wxMessageBox ("No compatible images for Row Comparison", "Error");\r
+ return;\r
+ }\r
+ \r
+ DialogGetComparisonImage dialogGetCompare (m_frame, "Get Comparison Image", vecIFDoc, false);\r
+ \r
+ if (dialogGetCompare.ShowModal() == wxID_OK) {\r
+ ImageFileDocument* pCompareDoc = dialogGetCompare.getImageFileDocument();\r
+ const ImageFile& rIF = GetDocument()->getImageFile();\r
+ const ImageFile& rCompareIF = pCompareDoc->getImageFile();\r
+ \r
+ ImageFileArrayConst v1 = rIF.getArray();\r
+ ImageFileArrayConst v2 = rCompareIF.getArray();\r
+ int nx = rIF.nx();\r
+ int ny = rIF.ny();\r
+ \r
+ if (v1 != NULL && yCursor < ny) {\r
+ double* pX = new double [nx];\r
+ double* pY1 = new double [nx];\r
+ double* pY2 = new double [nx];\r
+ for (int i = 0; i < nx; i++) {\r
+ pX[i] = i;\r
+ pY1[i] = v1[i][yCursor];\r
+ pY2[i] = v2[i][yCursor];\r
+ }\r
+ PlotFileDocument* pPlotDoc = dynamic_cast<PlotFileDocument*>(theApp->getDocManager()->CreateDocument("untitled.plt", wxDOC_SILENT));\r
+ if (! pPlotDoc) {\r
+ sys_error (ERR_SEVERE, "Internal error: unable to create Plot file");\r
+ } else {\r
+ PlotFile& rPlotFile = pPlotDoc->getPlotFile();\r
+ std::ostringstream os;\r
+ os << "Row " << yCursor << " Comparison";\r
+ std::string title("title ");\r
+ title += os.str();\r
+ rPlotFile.addEzsetCommand (title.c_str());\r
+ rPlotFile.addEzsetCommand ("xlabel Column");\r
+ rPlotFile.addEzsetCommand ("ylabel Pixel Value");\r
+ rPlotFile.addEzsetCommand ("lxfrac 0");\r
+ rPlotFile.addEzsetCommand ("curve 1");\r
+ rPlotFile.addEzsetCommand ("color 2");\r
+ rPlotFile.addEzsetCommand ("curve 2");\r
+ rPlotFile.addEzsetCommand ("color 4");\r
+ rPlotFile.addEzsetCommand ("dash 5");\r
+ rPlotFile.addEzsetCommand ("box");\r
+ rPlotFile.addEzsetCommand ("grid");\r
+ rPlotFile.setCurveSize (3, ny);\r
+ rPlotFile.addColumn (0, pX);\r
+ rPlotFile.addColumn (1, pY1);\r
+ rPlotFile.addColumn (2, pY2);\r
+ }\r
+ delete pX;\r
+ delete pY1;\r
+ delete pY2;\r
+ if (theApp->getSetModifyNewDocs())\r
+ pPlotDoc->Modify(true);\r
+ pPlotDoc->UpdateAllViews();\r
+ }\r
+ }\r
+}\r
+\r
+\r
+// PhantomCanvas
+
+PhantomCanvas::PhantomCanvas (PhantomView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style)
+: wxScrolledWindow(frame, -1, pos, size, style)
+{
+ m_pView = v;
+}
+
+void
+PhantomCanvas::OnDraw(wxDC& dc)
+{
+ if (m_pView)
+ m_pView->OnDraw(& dc);
+}
+
+
+// PhantomView
+
+IMPLEMENT_DYNAMIC_CLASS(PhantomView, wxView)
+
+BEGIN_EVENT_TABLE(PhantomView, wxView)
+EVT_MENU(PHMMENU_FILE_PROPERTIES, PhantomView::OnProperties)
+EVT_MENU(PHMMENU_PROCESS_RASTERIZE, PhantomView::OnRasterize)
+EVT_MENU(PHMMENU_PROCESS_PROJECTIONS, PhantomView::OnProjections)
+END_EVENT_TABLE()
+
+PhantomView::PhantomView(void)
+: wxView(), m_canvas(NULL), m_frame(NULL)
+{
+ m_iDefaultNDet = 367;
+ m_iDefaultNView = 320;
+ m_iDefaultNSample = 2;
+ m_dDefaultRotation = 2;
+ m_dDefaultFocalLength = 2;
+ m_dDefaultFieldOfView = 1;
+ m_iDefaultGeometry = Scanner::GEOMETRY_PARALLEL;
+ m_iDefaultTrace = Trace::TRACE_NONE;
+}
+
+PhantomView::~PhantomView(void)
+{
+}
+
+void
+PhantomView::OnProperties (wxCommandEvent& event)
+{
+ const int idPhantom = GetDocument()->getPhantomID();
+ const wxString& namePhantom = GetDocument()->getPhantomName();
+ std::ostringstream os;
+ os << "Phantom " << namePhantom.c_str() << " (" << idPhantom << ")\n";
+ *theApp->getLog() << os.str().c_str();
+#if DEBUG
+ const Phantom& rPhantom = GetDocument()->getPhantom();
+ rPhantom.print();
+#endif
+}