+void
+ImageFileView::OnFourier (wxCommandEvent& event)
+{
+ ImageFile& rIF = GetDocument()->getImageFile();
+ wxProgressDialog dlgProgress (wxString("Fourier"), wxString("Fourier Progress"), 1, m_frame, wxPD_APP_MODAL);
+ rIF.fourier (rIF);
+ rIF.labelAdd ("Fourier Image");
+ m_bMinSpecified = false;
+ m_bMaxSpecified = false;
+ if (theApp->getSetModifyNewDocs())
+ GetDocument()->Modify(TRUE);
+ GetDocument()->UpdateAllViews(this);
+}
+
+void
+ImageFileView::OnInverseFourier (wxCommandEvent& event)
+{
+ ImageFile& rIF = GetDocument()->getImageFile();
+ wxProgressDialog dlgProgress (wxString("Inverse Fourier"), wxString("Inverse Fourier Progress"), 1, m_frame, wxPD_APP_MODAL);
+ rIF.inverseFourier (rIF);
+ rIF.labelAdd ("Inverse Fourier Image");
+ m_bMinSpecified = false;
+ m_bMaxSpecified = false;
+ if (theApp->getSetModifyNewDocs())
+ GetDocument()->Modify(TRUE);
+ GetDocument()->UpdateAllViews(this);
+}
+
+void
+ImageFileView::OnShuffleNaturalToFourierOrder (wxCommandEvent& event)
+{
+ ImageFile& rIF = GetDocument()->getImageFile();
+ Fourier::shuffleNaturalToFourierOrder (rIF);
+ rIF.labelAdd ("Shuffle Natural To Fourier Order");
+ m_bMinSpecified = false;
+ m_bMaxSpecified = false;
+ if (theApp->getSetModifyNewDocs())
+ GetDocument()->Modify(TRUE);
+ GetDocument()->UpdateAllViews(this);
+}
+
+void
+ImageFileView::OnShuffleFourierToNaturalOrder (wxCommandEvent& event)
+{
+ ImageFile& rIF = GetDocument()->getImageFile();
+ Fourier::shuffleFourierToNaturalOrder (rIF);
+ rIF.labelAdd ("Shuffle Fourier To Natural Order");
+ m_bMinSpecified = false;
+ m_bMaxSpecified = false;
+ if (theApp->getSetModifyNewDocs())
+ GetDocument()->Modify(TRUE);
+ GetDocument()->UpdateAllViews(this);
+}
+
+void
+ImageFileView::OnMagnitude (wxCommandEvent& event)
+{
+ ImageFile& rIF = GetDocument()->getImageFile();
+ if (rIF.isComplex()) {
+ rIF.magnitude (rIF);
+ rIF.labelAdd ("Magnitude of complex-image");
+ m_bMinSpecified = false;
+ m_bMaxSpecified = false;
+ if (theApp->getSetModifyNewDocs())
+ GetDocument()->Modify(TRUE);
+ GetDocument()->UpdateAllViews(this);
+ }
+}
+
+void
+ImageFileView::OnPhase (wxCommandEvent& event)
+{
+ ImageFile& rIF = GetDocument()->getImageFile();
+ if (rIF.isComplex()) {
+ rIF.phase (rIF);
+ rIF.labelAdd ("Phase of complex-image");
+ m_bMinSpecified = false;
+ m_bMaxSpecified = false;
+ if (theApp->getSetModifyNewDocs())
+ GetDocument()->Modify(TRUE);
+ GetDocument()->UpdateAllViews(this);
+ }
+}
+
+
+ImageFileCanvas*
+ImageFileView::CreateCanvas (wxView *view, wxFrame *parent)
+{
+ ImageFileCanvas* pCanvas;
+ int width, height;
+ parent->GetClientSize(&width, &height);
+
+ pCanvas = new ImageFileCanvas (dynamic_cast<ImageFileView*>(view), parent, wxPoint(0, 0), wxSize(width, height), 0);
+
+ pCanvas->SetScrollbars(20, 20, 50, 50);
+ pCanvas->SetBackgroundColour(*wxWHITE);
+ pCanvas->Clear();
+
+ return pCanvas;
+}
+
+wxFrame*
+ImageFileView::CreateChildFrame(wxDocument *doc, wxView *view)
+{
+#if CTSIM_MDI
+ wxMDIChildFrame *subframe = new wxMDIChildFrame(theApp->getMainFrame(), -1, "ImageFile Frame", wxPoint(-1, -1), wxSize(0, 0), wxDEFAULT_FRAME_STYLE);
+#else
+ wxDocChildFrame *subframe = new wxDocChildFrame(doc, view, theApp->getMainFrame(), -1, "ImageFile Frame", wxPoint(-1, -1), wxSize(0, 0), wxDEFAULT_FRAME_STYLE);
+#endif
+
+ wxMenu *file_menu = new wxMenu;
+
+ file_menu->Append(MAINMENU_FILE_CREATE_PHANTOM, "Cr&eate Phantom...");
+ file_menu->Append(MAINMENU_FILE_CREATE_FILTER, "Create &Filter...");
+ file_menu->Append(wxID_OPEN, "&Open...");
+ file_menu->Append(wxID_SAVE, "&Save");
+ file_menu->Append(wxID_SAVEAS, "Save &As...");
+ file_menu->Append(wxID_CLOSE, "&Close");
+
+ file_menu->AppendSeparator();
+ file_menu->Append(IFMENU_FILE_PROPERTIES, "P&roperties");
+ file_menu->Append(IFMENU_FILE_EXPORT, "&Export...");
+
+ file_menu->AppendSeparator();
+ file_menu->Append(wxID_PRINT, "&Print...");
+ file_menu->Append(wxID_PRINT_SETUP, "Print &Setup...");
+ file_menu->Append(wxID_PREVIEW, "Print Pre&view");
+
+ wxMenu *view_menu = new wxMenu;
+ view_menu->Append(IFMENU_VIEW_SCALE_MINMAX, "Display Scale &Set...");
+ view_menu->Append(IFMENU_VIEW_SCALE_AUTO, "Display Scale &Auto...");
+ view_menu->Append(IFMENU_VIEW_SCALE_FULL, "Display &Full Scale");
+
+ wxMenu* filter_menu = new wxMenu;
+ filter_menu->Append (IFMENU_FILTER_INVERTVALUES, "&Invert Values");
+ filter_menu->Append (IFMENU_FILTER_SQUARE, "&Square");
+ filter_menu->Append (IFMENU_FILTER_SQRT, "Square &Root");
+ filter_menu->Append (IFMENU_FILTER_LOG, "&Log");
+ filter_menu->Append (IFMENU_FILTER_EXP, "&Exp");
+ filter_menu->AppendSeparator();
+#ifdef HAVE_FFT
+ filter_menu->Append (IFMENU_FILTER_FFT, "2D &FFT");
+ filter_menu->Append (IFMENU_FILTER_IFFT, "2D &IFFT");
+ filter_menu->Append (IFMENU_FILTER_FFT_ROWS, "FFT Rows");
+ filter_menu->Append (IFMENU_FILTER_IFFT_ROWS, "IFFT Rows");
+ filter_menu->Append (IFMENU_FILTER_FFT_COLS, "FFT Columns");
+ filter_menu->Append (IFMENU_FILTER_IFFT_COLS, "IFFT Columns");
+ filter_menu->Append (IFMENU_FILTER_FOURIER, "F&ourier");
+ filter_menu->Append (IFMENU_FILTER_INVERSE_FOURIER, "Inverse Fo&urier");
+#else
+ filter_menu->Append (IFMENU_FILTER_FOURIER, "&Fourier");
+ filter_menu->Append (IFMENU_FILTER_INVERSE_FOURIER, "&Inverse Fourier");
+#endif
+ filter_menu->Append (IFMENU_FILTER_SHUFFLEFOURIERTONATURALORDER, "S&huffle Fourier to Natural Order");
+ filter_menu->Append (IFMENU_FILTER_SHUFFLENATURALTOFOURIERORDER, "Shu&ffle Natural to Fourier Order");
+ filter_menu->Append (IFMENU_FILTER_MAGNITUDE, "&Magnitude");
+ filter_menu->Append (IFMENU_FILTER_PHASE, "&Phase");
+
+ wxMenu* image_menu = new wxMenu;
+ image_menu->Append (IFMENU_IMAGE_ADD, "&Add...");
+ image_menu->Append (IFMENU_IMAGE_SUBTRACT, "&Subtract...");
+ image_menu->Append (IFMENU_IMAGE_MULTIPLY, "&Multiply...");
+ image_menu->Append (IFMENU_IMAGE_DIVIDE, "&Divide...");
+ image_menu->AppendSeparator();
+ image_menu->Append (IFMENU_IMAGE_SCALESIZE, "S&cale Size...");
+
+ wxMenu *analyze_menu = new wxMenu;
+ analyze_menu->Append (IFMENU_PLOT_ROW, "Plot &Row");
+ analyze_menu->Append (IFMENU_PLOT_COL, "Plot &Column");
+ analyze_menu->Append (IFMENU_PLOT_HISTOGRAM, "Plot &Histogram");
+ analyze_menu->AppendSeparator();
+ analyze_menu->Append (IFMENU_PLOT_FFT_ROW, "Plot FFT Row");
+ analyze_menu->Append (IFMENU_PLOT_FFT_COL, "Plot FFT Column");
+ analyze_menu->AppendSeparator();
+ analyze_menu->Append (IFMENU_COMPARE_IMAGES, "Compare &Images...");
+ analyze_menu->Append (IFMENU_COMPARE_ROW, "Compare &Row");
+ analyze_menu->Append (IFMENU_COMPARE_COL, "Compare &Column");
+
+ wxMenu *help_menu = new wxMenu;
+ help_menu->Append(MAINMENU_HELP_ABOUT, "&About");
+
+ wxMenuBar *menu_bar = new wxMenuBar;
+
+ menu_bar->Append(file_menu, "&File");
+ menu_bar->Append(view_menu, "&View");
+ menu_bar->Append(image_menu, "&Image");
+ menu_bar->Append(filter_menu, "Fi<er");
+ menu_bar->Append(analyze_menu, "&Analyze");
+ menu_bar->Append(help_menu, "&Help");
+
+ subframe->SetMenuBar(menu_bar);
+
+ subframe->Centre(wxBOTH);
+
+ return subframe;
+}
+
+
+bool
+ImageFileView::OnCreate (wxDocument *doc, long WXUNUSED(flags) )
+{
+ m_frame = CreateChildFrame(doc, this);
+ SetFrame (m_frame);
+
+ m_bMinSpecified = false;
+ m_bMaxSpecified = false;
+ m_dAutoScaleFactor = 1.;
+
+ int width, height;
+ m_frame->GetClientSize (&width, &height);
+ m_frame->SetTitle("ImageFileView");
+ m_canvas = CreateCanvas (this, m_frame);
+
+ int x, y; // X requires a forced resize
+ m_frame->GetSize(&x, &y);
+ m_frame->SetSize(-1, -1, x, y);
+ m_frame->SetFocus();
+ m_frame->Show(true);
+ Activate(true);
+
+ return true;