r641: no message
[ctsim.git] / src / graph3dview.h
index 6ae6e78783ddde408632715a4ef6966aa85d3e4b..7933f17b5853eae97a10b334092de0eceffcc012 100644 (file)
@@ -9,7 +9,7 @@
 **  This is part of the CTSim program
 **  Copyright (c) 1983-2001 Kevin Rosenberg
 **
-**  $Id: graph3dview.h,v 1.2 2001/01/30 10:58:13 kevin Exp $
+**  $Id: graph3dview.h,v 1.8 2001/03/21 21:45:31 kevin Exp $
 **
 **  This program is free software; you can redistribute it and/or modify
 **  it under the terms of the GNU General Public License (version 2) as
@@ -46,15 +46,33 @@ private:
   DECLARE_EVENT_TABLE()
    
   wxMenu* m_pFileMenu;
+  wxMenu *m_pViewMenu;
+  wxStatusBar* m_pStatusBar;
+
   GLfloat m_dXRotate;
   GLfloat m_dYRotate;
-  GLboolean m_bUseVertexArrays;
-  GLboolean m_bDoubleBuffer;
-  GLboolean m_bSmooth;
-  GLboolean m_bLighting;
+  GLfloat m_dZRotate;
+  bool m_bUseVertexArrays;
+  bool m_bDoubleBuffer;
+  bool m_bSmooth;
+  bool m_bLighting;
+  bool m_bWireframe;
+  bool m_bColor;
+  enum {
+    DISPLAYLIST_COLOR = 1,
+    DISPLAYLIST_NO_COLOR = 2,
+  };
+
+  double m_dGraphMin;
+  double m_dGraphMax;
+  double m_dColorScaleMin;
+  double m_dColorScaleMax;
+  bool m_bColorScaleMinSet;
+  bool m_bColorScaleMaxSet;
 
   void Draw();
   void DrawSurface();
+  void CreateDisplayList();
   void InitMaterials();
   void InitGL();
 
@@ -76,6 +94,8 @@ private:
   { return m_pFrame; }
 #endif
 
+  void intensityToColor (double dIntensity, GLfloat* vecColor);
+
 public:
   Graph3dFileView();
   virtual ~Graph3dFileView();
@@ -87,13 +107,20 @@ public:
   void OnUpdate(wxView *sender, wxObject *hint = NULL);
   bool OnClose (bool deleteWindow = true);
   void OnProperties (wxCommandEvent& event);
-
+  void OnLighting (wxCommandEvent& event);
+  void OnWireframe (wxCommandEvent& event);
+  void OnColor (wxCommandEvent& event);
+  void OnSmooth (wxCommandEvent& event);
+  void OnScaleSet (wxCommandEvent& event);
+  void OnScaleAuto (wxCommandEvent& event);
+  void OnScaleFull (wxCommandEvent& event);
+  
 #if CTSIM_MDI
   wxDocMDIChildFrame* getFrame() { return m_pFrame; }
 #else
   wxDocChildFrame* getFrame() { return m_pFrame; }
 #endif
-
+  Graph3dFileCanvas* getCanvas() { return m_pCanvas; }
   Graph3dFileDocument* GetDocument() 
   { return dynamic_cast<Graph3dFileDocument*>(wxView::GetDocument()); }
 };
@@ -109,7 +136,7 @@ private:
 
 public:
    Graph3dFileCanvas (Graph3dFileView* view, wxWindow *parent, const wxPoint& pos = wxDefaultPosition,
-      const wxSize& size = wxDefaultSize, long style = 0, int* gl_attrib = NULL);
+      const wxSize& size = wxDefaultSize, long style = 0);
    virtual ~Graph3dFileCanvas();
 
    virtual void OnDraw(wxDC& dc);