]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/opengl/penguin/penguin.h
Extract compiler-specific macro definitions in a new wx/compiler.h.
[wxWidgets.git] / samples / opengl / penguin / penguin.h
index 0020b657afe8c29b5511586c251da2f5fe89e4bb..3f2559090719e8abcac7c56b3aeb0910dfa0bb2f 100644 (file)
 #include "wx/app.h"
 #include "wx/menu.h"
 #include "wx/dcclient.h"
+#include "wx/wfstream.h"
+#if wxUSE_ZLIB
+#include "wx/zstream.h"
+#endif
 
 #include "wx/glcanvas.h"
 
-extern "C" {
-#include "lw.h"
+extern "C"
+{
 #include "trackball.h"
 }
 
-/* information needed to display lightwave mesh */
-typedef struct 
+#include "dxfrenderer.h"
+
+
+// OpenGL view data
+struct GLData
 {
-//  gint do_init;         /* true if initgl not yet called */
-    int do_init;
-    lwObject *lwobject;   /* lightwave object mesh */
-    float beginx,beginy;  /* position of mouse */
-    float quat[4];        /* orientation of object */
-    float zoom;           /* field of view in degrees */
-} mesh_info;
+    bool initialized;           // have OpenGL been initialized?
+    float beginx, beginy;       // position of mouse
+    float quat[4];              // orientation of object
+    float zoom;                 // field of view in degrees
+};
 
 
-/* Define a new application type */
-class MyApp: public wxApp
+// Define a new application type
+class MyApp : public wxApp
 {
 public:
-    bool OnInit(void);
+    virtual bool OnInit();
 };
 
-/* Define a new frame type */
+
+// Define a new frame type
 class TestGLCanvas;
 
-class MyFrame: public wxFrame
+
+class MyFrame : public wxFrame
 {
 public:
-    MyFrame(wxFrame *frame, const wxString& title, const wxPoint& pos, const wxSize& size,
-        long style = wxDEFAULT_FRAME_STYLE);
-
-    void OnExit(wxCommandEvent& event);
-    
-#if wxUSE_GLCANVAS
-    void SetCanvas( TestGLCanvas *canvas )    { m_canvas = canvas; }
-    TestGLCanvas *GetCanvas()                 { return m_canvas; }
-    
+    MyFrame(wxFrame *frame, const wxString& title, const wxPoint& pos,
+            const wxSize& size, long style = wxDEFAULT_FRAME_STYLE);
+
+    void OnMenuFileOpen(wxCommandEvent& event);
+    void OnMenuFileExit(wxCommandEvent& event);
+    void OnMenuHelpAbout(wxCommandEvent& event);
+
+    void SetCanvas(TestGLCanvas *canvas) { m_canvas = canvas; }
+    TestGLCanvas *GetCanvas() { return m_canvas; }
+
 private:
-    TestGLCanvas*    m_canvas;
-#endif
+    TestGLCanvas *m_canvas;
 
     DECLARE_EVENT_TABLE()
 };
 
-#if wxUSE_GLCANVAS
 
-class TestGLCanvas: public wxGLCanvas
+class TestGLCanvas : public wxGLCanvas
 {
 public:
-    TestGLCanvas(wxWindow *parent, const wxWindowID id = -1, const wxPoint& pos = wxDefaultPosition,
-        const wxSize& size = wxDefaultSize, long style = 0, const wxString& name = wxT("TestGLCanvas"));
-    ~TestGLCanvas(void);
+    TestGLCanvas(wxWindow *parent, wxWindowID id = wxID_ANY,
+        const wxPoint& pos = wxDefaultPosition,
+        const wxSize& size = wxDefaultSize, long style = 0,
+        const wxString& name = wxT("TestGLCanvas"));
+
+    virtual ~TestGLCanvas();
+
+    void LoadDXF(const wxString& filename);
 
+protected:
     void OnPaint(wxPaintEvent& event);
     void OnSize(wxSizeEvent& event);
     void OnEraseBackground(wxEraseEvent& event);
-    void LoadLWO( const wxString &filename);
-    void OnMouse( wxMouseEvent& event );
-    void InitGL(void);
-   
-    mesh_info  info;
-    bool       block;
+    void OnMouse(wxMouseEvent& event);
 
 private:
-    DECLARE_EVENT_TABLE()
-};
+    void InitGL();
+    void ResetProjectionMode();
 
-#endif
+    wxGLContext* m_glRC;
+    GLData       m_gldata;
+    DXFRenderer  m_renderer;
 
-#endif
+    wxDECLARE_NO_COPY_CLASS(TestGLCanvas);
+    DECLARE_EVENT_TABLE()
+};
 
+#endif // #ifndef _WX_PENGUIN_H_