]> git.saurik.com Git - wxWidgets.git/blobdiff - contrib/samples/gizmos/dynsash/dynsash.cpp
don't use wxStaticCast to wxBookCtrlBase -- it doesn't work
[wxWidgets.git] / contrib / samples / gizmos / dynsash / dynsash.cpp
index 8e7bbb4efe37b02456f8c6a2b38495ab111f7cad..e24229b4c344c7f60e5be4f3e5b3b01f245b97d2 100644 (file)
 // Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
 // Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
-#include <wx/app.h>
-#include <wx/gizmos/dynamicsash.h>
-#include <wx/html/htmlwin.h>
-#include <wx/image.h>
-
-class Demo : public wxApp {
+// For compilers that support precompilation, includes "wx/wx.h".
+#include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+    #pragma hdrstop
+#endif
+
+// for all others, include the necessary headers (this file is usually all you
+// need because it includes almost all "standard" wxWidgets headers)
+#ifndef WX_PRECOMP
+    #include "wx/wx.h"
+#endif
+
+#include "wx/app.h"
+#include "wx/frame.h"
+#include "wx/gizmos/dynamicsash.h"
+#include "wx/html/htmlwin.h"
+#include "wx/image.h"
+#include "wx/cmdline.h"
+
+class Demo : public wxApp
+{
 public:
     bool OnInit();
 };
 
 public:
     bool OnInit();
 };
 
-class SashHtmlWindow : public wxHtmlWindow {
+class SashHtmlWindow : public wxHtmlWindow
+{
 public:
 public:
-    SashHtmlWindow(wxWindow *parent, wxWindowID id = -1,
-                   const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
-                   long style = wxHW_SCROLLBAR_NEVER, const wxString& name = "sashHtmlWindow");
+    SashHtmlWindow(wxWindow *parent, wxWindowID id = wxID_ANY,
+                   const wxPoint& pos = wxDefaultPosition,
+                   const wxSize& size = wxDefaultSize,
+                   long style = wxHW_SCROLLBAR_NEVER,
+                   const wxString& name = wxT("sashHtmlWindow"));
 
     wxSize DoGetBestSize() const;
 
 
     wxSize DoGetBestSize() const;
 
@@ -36,51 +55,60 @@ private:
 
 IMPLEMENT_APP(Demo)
 
 
 IMPLEMENT_APP(Demo)
 
-char *HTML_content =
-"<P><H1>wxDynamicSashWindow demo</H1>"
-"<P>Here is an example of how you can use <TT>wxDynamicSashWindow</TT> to allow your users to "
-"dynamically split and unify the views of your windows.  Try dragging out a few splits "
-"and then reunifying the window."
-"<P>Also, see the <TT>dynsash_switch</TT> sample for an example of an application which "
-"manages the scrollbars provided by <TT>wxDynamicSashWindow</TT> itself."
-;
+const wxChar *HTML_content =
+wxT("<P><H1>wxDynamicSashWindow demo</H1>")
+wxT("<P>Here is an example of how you can use <TT>wxDynamicSashWindow</TT> to allow your users to ")
+wxT("dynamically split and unify the views of your windows.  Try dragging out a few splits ")
+wxT("and then reunifying the window.")
+wxT("<P>Also, see the <TT>dynsash_switch</TT> sample for an example of an application which ")
+wxT("manages the scrollbars provided by <TT>wxDynamicSashWindow</TT> itself.");
 
 
-bool Demo::OnInit() {
+bool Demo::OnInit()
+{
     wxInitAllImageHandlers();
 
     wxInitAllImageHandlers();
 
-    wxFrame *frame = new wxFrame(NULL, -1, "Dynamic Sash Demo");
+    wxFrame *frame = new wxFrame(NULL, wxID_ANY, wxT("Dynamic Sash Demo"));
     frame->SetSize(480, 480);
 
     frame->SetSize(480, 480);
 
-    wxDynamicSashWindow *sash = new wxDynamicSashWindow(frame, -1);
-    wxHtmlWindow *html = new SashHtmlWindow(sash, -1);
+    wxDynamicSashWindow *sash = new wxDynamicSashWindow(frame, wxID_ANY);
+    wxHtmlWindow *html = new SashHtmlWindow(sash, wxID_ANY);
     html->SetPage(HTML_content);
 
     frame->Show();
 
     html->SetPage(HTML_content);
 
     frame->Show();
 
-    return TRUE;
+    return true;
 }
 
 
 SashHtmlWindow::SashHtmlWindow(wxWindow *parent, wxWindowID id,
 }
 
 
 SashHtmlWindow::SashHtmlWindow(wxWindow *parent, wxWindowID id,
-                               const wxPoint& pos, const wxSize& size, long style, const wxString& name) :
-                                    wxHtmlWindow(parent, id, pos, size, style, name) {
-    Connect(-1, wxEVT_DYNAMIC_SASH_SPLIT, (wxObjectEventFunction)&SashHtmlWindow::OnSplit);
+                               const wxPoint& pos,
+                               const wxSize& size,
+                               long style,
+                               const wxString& name)
+              : wxHtmlWindow(parent, id, pos, size, style, name)
+{
+    Connect(wxEVT_DYNAMIC_SASH_SPLIT,
+            wxDynamicSashSplitEventHandler(SashHtmlWindow::OnSplit));
 
     m_dyn_sash = parent;
 }
 
 
     m_dyn_sash = parent;
 }
 
-wxSize SashHtmlWindow::DoGetBestSize() const {
+wxSize SashHtmlWindow::DoGetBestSize() const
+{
     wxHtmlContainerCell *cell = GetInternalRepresentation();
     wxSize size = GetSize();
 
     wxHtmlContainerCell *cell = GetInternalRepresentation();
     wxSize size = GetSize();
 
-    if (cell) {
+    if (cell)
+    {
         cell->Layout(size.GetWidth());
         return wxSize(cell->GetWidth(), cell->GetHeight());
         cell->Layout(size.GetWidth());
         return wxSize(cell->GetWidth(), cell->GetHeight());
-    } else
-        return wxHtmlWindow::GetBestSize();
+    }
+
+    return wxHtmlWindow::GetBestSize();
 }
 
 }
 
-void SashHtmlWindow::OnSplit(wxDynamicSashSplitEvent& event) {
-    wxHtmlWindow *html = new SashHtmlWindow(m_dyn_sash, -1);
+void SashHtmlWindow::OnSplit(wxDynamicSashSplitEvent& WXUNUSED(event))
+{
+    wxHtmlWindow *html = new SashHtmlWindow(m_dyn_sash, wxID_ANY);
     html->SetPage(HTML_content);
 }
     html->SetPage(HTML_content);
 }