+#if CTSIM_MDI
+ wxDocMDIChildFrame* subframe = new wxDocMDIChildFrame (doc, view, 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
+ theApp->setIconForFrame (subframe);
+
+ wxMenu *m_pFileMenu = new wxMenu;
+
+ m_pFileMenu->Append(MAINMENU_FILE_CREATE_PHANTOM, "Cr&eate Phantom...\tCtrl-P");
+ m_pFileMenu->Append(MAINMENU_FILE_CREATE_FILTER, "Create &Filter...\tCtrl-F");
+ m_pFileMenu->Append(wxID_OPEN, "&Open...\tCtrl-O");
+ m_pFileMenu->Append(wxID_SAVE, "&Save\tCtrl-S");
+ m_pFileMenu->Append(wxID_SAVEAS, "Save &As...");
+ m_pFileMenu->Append(wxID_CLOSE, "&Close\tCtrl-W");
+
+ m_pFileMenu->AppendSeparator();
+ m_pFileMenu->Append(IFMENU_FILE_PROPERTIES, "P&roperties");
+ m_pFileMenu->Append(IFMENU_FILE_EXPORT, "&Export...");
+
+ m_pFileMenu->AppendSeparator();
+ m_pFileMenu->Append(wxID_PRINT, "&Print...");
+ m_pFileMenu->Append(wxID_PRINT_SETUP, "Print &Setup...");
+ m_pFileMenu->Append(wxID_PREVIEW, "Print Pre&view");
+#ifdef CTSIM_MDI
+ m_pFileMenu->AppendSeparator();
+ m_pFileMenu->Append(MAINMENU_FILE_EXIT, "E&xit");
+#endif
+ theApp->getDocManager()->FileHistoryAddFilesToMenu(m_pFileMenu);
+ theApp->getDocManager()->FileHistoryUseMenu(m_pFileMenu);
+
+ wxMenu *view_menu = new wxMenu;
+ view_menu->Append(IFMENU_VIEW_SCALE_MINMAX, "Display Scale S&et...\tCtrl-E");
+ view_menu->Append(IFMENU_VIEW_SCALE_AUTO, "Display Scale &Auto...\tCtrl-A");
+ view_menu->Append(IFMENU_VIEW_SCALE_FULL, "Display F&ull Scale\tCtrl-U");
+
+ 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_CONTENTS, "&Contents\tF1");
+ help_menu->Append(MAINMENU_HELP_TOPICS, "&Topics\tCtrl-H");
+ help_menu->Append(MAINMENU_HELP_ABOUT, "&About");
+
+ wxMenuBar *menu_bar = new wxMenuBar;
+
+ menu_bar->Append(m_pFileMenu, "&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);
+
+ wxAcceleratorEntry accelEntries[10];
+ accelEntries[0].Set (wxACCEL_CTRL, static_cast<int>('O'), wxID_OPEN);
+ accelEntries[1].Set (wxACCEL_CTRL, static_cast<int>('S'), wxID_SAVE);
+ accelEntries[2].Set (wxACCEL_CTRL, static_cast<int>('W'), wxID_CLOSE);
+ accelEntries[3].Set (wxACCEL_CTRL, static_cast<int>('H'), MAINMENU_HELP_TOPICS);
+ accelEntries[4].Set (wxACCEL_CTRL, static_cast<int>('P'), MAINMENU_FILE_CREATE_PHANTOM);
+ accelEntries[5].Set (wxACCEL_CTRL, static_cast<int>('F'), MAINMENU_FILE_CREATE_FILTER);
+ accelEntries[6].Set (wxACCEL_NORMAL, WXK_F1, MAINMENU_HELP_CONTENTS);
+ accelEntries[7].Set (wxACCEL_CTRL, static_cast<int>('A'), IFMENU_VIEW_SCALE_AUTO);
+ accelEntries[8].Set (wxACCEL_CTRL, static_cast<int>('U'), IFMENU_VIEW_SCALE_FULL);
+ accelEntries[9].Set (wxACCEL_CTRL, static_cast<int>('E'), IFMENU_VIEW_SCALE_MINMAX);
+ wxAcceleratorTable accelTable (10, accelEntries);
+ subframe->SetAcceleratorTable (accelTable);
+
+ 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;
+}
+
+void
+ImageFileView::OnDraw (wxDC* dc)
+{
+ wxSize sizeWindow = m_frame->GetClientSize();
+ wxSize sizeBest = m_canvas->GetBestSize();
+ if (sizeWindow.x > sizeBest.x || sizeWindow.y > sizeBest.y)
+ m_frame->SetClientSize (sizeBest);
+
+ if (m_bitmap.Ok())
+ dc->DrawBitmap(m_bitmap, 0, 0, false);
+
+ int xCursor, yCursor;
+ if (m_canvas->GetCurrentCursor (xCursor, yCursor))
+ m_canvas->DrawRubberBandCursor (*dc, xCursor, yCursor);
+}
+
+
+void
+ImageFileView::OnUpdate (wxView *WXUNUSED(sender), wxObject *WXUNUSED(hint) )
+{
+ const ImageFile& rIF = dynamic_cast<ImageFileDocument*>(GetDocument())->getImageFile();
+ ImageFileArrayConst v = rIF.getArray();
+ int nx = rIF.nx();
+ int ny = rIF.ny();
+ if (v != NULL && nx != 0 && ny != 0) {
+ if (! m_bMinSpecified || ! m_bMaxSpecified) {
+ double min, max;
+ rIF.getMinMax (min, max);
+ if (! m_bMinSpecified)
+ m_dMinPixel = min;
+ if (! m_bMaxSpecified)
+ m_dMaxPixel = max;
+ }
+ double scaleWidth = m_dMaxPixel - m_dMinPixel;