]> git.saurik.com Git - wxWidgets.git/blobdiff - demos/forty/forty.h
more test tweaks
[wxWidgets.git] / demos / forty / forty.h
index 1fbf6449f150008857b6cd825f264b6ead624584..2b8a93005a17c0c843029acd6d736206e6172022 100644 (file)
@@ -6,9 +6,9 @@
 // Created:     21/07/97
 // RCS-ID:      $Id$
 // Copyright:   (c) 1993-1998 Chris Breeze
-// Licence:    wxWindows licence
+// Licence:     wxWindows licence
 //---------------------------------------------------------------------------
-// Last modified: 22nd July 1998 - ported to wxWindows 2.0
+// Last modified: 22nd July 1998 - ported to wxWidgets 2.0
 /////////////////////////////////////////////////////////////////////////////
 #ifndef _FORTY_H_
 #define _FORTY_H_
 class FortyApp: public wxApp
 {
 public:
-       bool OnInit();
+    FortyApp();
+    ~FortyApp();
+    bool OnInit();
 
-       static const wxColour& BackgroundColour();
-       static const wxColour& TextColour();
-       static const wxBrush&  BackgroundBrush();
+    static const wxColour& BackgroundColour();
+    static const wxColour& TextColour();
+    static const wxBrush&  BackgroundBrush();
+    const wxString& GetHelpFile() const { return m_helpFile; }
 
 private:
-       static wxColour* m_backgroundColour;
-       static wxColour* m_textColour;
-       static wxBrush*  m_backgroundBrush;
+    static wxColour* m_backgroundColour;
+    static wxColour* m_textColour;
+    static wxBrush*  m_backgroundBrush;
+    wxString m_helpFile;
 };
 
+DECLARE_APP(FortyApp)
+
+class FortyCanvas;
+class FortyFrame: public wxFrame
+{
+public:
+  FortyFrame(wxFrame* frame, const wxString& title, const wxPoint& pos, const wxSize& size, bool largecards);
+    virtual ~FortyFrame();
+
+    void OnCloseWindow(wxCloseEvent& event);
+
+    // Menu callbacks
+    void NewGame(wxCommandEvent& event);
+    void Exit(wxCommandEvent& event);
+    void About(wxCommandEvent& event);
+    void Help(wxCommandEvent& event);
+    void Undo(wxCommandEvent& event);
+    void Redo(wxCommandEvent& event);
+    void Scores(wxCommandEvent& event);
+    void ToggleRightButtonUndo(wxCommandEvent& event);
+    void ToggleHelpingHand(wxCommandEvent& event);
+    void ToggleCardSize(wxCommandEvent& event);
+
+    FortyCanvas* GetCanvas() { return m_canvas; }
+
+    DECLARE_EVENT_TABLE()
+
+private:
+    enum MenuCommands { 
+        NEW_GAME = 10, 
+        SCORES,
+        UNDO, 
+        REDO,
+        RIGHT_BUTTON_UNDO, 
+        HELPING_HAND, 
+        LARGE_CARDS
+    };
+
+    wxMenuBar* m_menuBar;
+    FortyCanvas* m_canvas;
+};
+
+//----------------------------------------------------------------------------
+// stAboutDialog
+//----------------------------------------------------------------------------
+
+class FortyAboutDialog: public wxDialog
+{
+public:
+    // constructors and destructors
+    FortyAboutDialog( wxWindow *parent, wxWindowID id, const wxString &title,
+        const wxPoint& pos = wxDefaultPosition,
+        const wxSize& size = wxDefaultSize,
+        long style = wxDEFAULT_DIALOG_STYLE );
+    
+    bool AddControls(wxWindow* parent);
+
+private:
+    DECLARE_EVENT_TABLE()
+};
+
+#define ID_ABOUT_HTML_WINDOW    1000
+
 #endif