X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/bcc4c54184e715365e3b02b73131ac34e08fdb45..19abd352e88f9ae4bd41ee41dbce86212015ce8f:/samples/opengl/penguin/penguin.h diff --git a/samples/opengl/penguin/penguin.h b/samples/opengl/penguin/penguin.h index d04c39988f..63efc497f4 100644 --- a/samples/opengl/penguin/penguin.h +++ b/samples/opengl/penguin/penguin.h @@ -17,73 +17,91 @@ #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 -{ -// 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; +#include "dxfrenderer.h" +// OpenGL view data +struct GLData +{ + 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 */ +// Define a new application type class MyApp: public wxApp { public: - bool OnInit(void); + bool OnInit(); }; -/* Define a new frame type */ +// Define a new frame type class TestGLCanvas; 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); - - 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); + +#if wxUSE_GLCANVAS + void SetCanvas( TestGLCanvas *canvas ) { m_canvas = canvas; } + TestGLCanvas *GetCanvas() { return m_canvas; } + private: - TestGLCanvas* m_canvas; + TestGLCanvas *m_canvas; +#endif DECLARE_EVENT_TABLE() }; +#if wxUSE_GLCANVAS + 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")); + + ~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: + void InitGL(); + void ResetProjectionMode(); + + GLData m_gldata; + DXFRenderer m_renderer; + DECLARE_EVENT_TABLE() }; -#endif +#endif // #if wxUSE_GLCANVAS + +#endif // #ifndef _WX_PENGUIN_H_