]> git.saurik.com Git - wxWidgets.git/blobdiff - contrib/samples/canvas/test/test.cpp
Removed obsolete library.
[wxWidgets.git] / contrib / samples / canvas / test / test.cpp
diff --git a/contrib/samples/canvas/test/test.cpp b/contrib/samples/canvas/test/test.cpp
deleted file mode 100644 (file)
index ac52ef0..0000000
+++ /dev/null
@@ -1,747 +0,0 @@
-/*
- * Program: canvas
- *
- * Author: Robert Roebling
- *
- * Copyright: (C) 1998, Robert Roebling
- *
- */
-
-#ifdef __GNUG__
-    #pragma implementation "test.cpp"
-#endif
-
-// For compilers that support precompilation
-#include "wx/wxprec.h"
-
-#ifdef __BORLANDC__
-    #pragma hdrstop
-#endif
-
-#include "test.h"
-#include "smile.xpm"
-
-//-----------------------------------------------------
-// class MywxCanvasObjectRef
-//-----------------------------------------------------
-
-BEGIN_EVENT_TABLE(MywxCanvasObjectRef,wxCanvasObjectRef)
-  EVT_MOUSE_EVENTS( MywxCanvasObjectRef::OnMouseEvent )
-END_EVENT_TABLE()
-
-IMPLEMENT_DYNAMIC_CLASS(MywxCanvasObjectRef, wxCanvasObjectRef)
-
-MywxCanvasObjectRef::MywxCanvasObjectRef(double x, double y,wxCanvasObjectGroup* group)
-    :wxCanvasObjectRef(x,y,group)
-{
-}
-
-MywxCanvasObjectRef::MywxCanvasObjectRef()
-    :wxCanvasObjectRef(0,0,NULL)
-{
-}
-
-MywxCanvasObjectRef::~MywxCanvasObjectRef()
-{
-}
-
-void MywxCanvasObjectRef::OnMouseEvent(wxMouseEvent &event)
-{
-    if (!m_dragable)
-    {
-        event.Skip();
-        return;
-    }
-
-    static double xprev;
-    static double yprev;
-
-    //new position of the mouse relative within the object
-    double x = m_admin->DeviceToLogicalX(event.GetX());
-    double y = m_admin->DeviceToLogicalY(event.GetY());
-
-    if (event.LeftDown())
-    {
-        CaptureMouse();
-        if (m_dragmode != wxDRAG_REDRAW)
-            DragStart();
-    }
-    else if (event.LeftUp())
-    {
-        ReleaseMouse();
-        if (m_dragmode != wxDRAG_REDRAW)
-            DragEnd();
-    }
-    else if (IsCapturedMouse())
-    {
-        if (m_dragmode != wxDRAG_REDRAW)
-            DragRelative(x-xprev,y-yprev);
-        else
-            MoveRelative(x-xprev,y-yprev);
-        m_admin->UpdateNow();
-    }
-    xprev=x;
-    yprev=y;
-    //well do something extra
-    if (IsCapturedMouse())
-        m_admin->GetActive()->SetCursor(*wxHOURGLASS_CURSOR);
-    else
-        m_admin->GetActive()->SetCursor(*wxSTANDARD_CURSOR);
-}
-
-//---------------------------------------------------
-// class MyEventHandler
-//---------------------------------------------------
-
-BEGIN_EVENT_TABLE(MyEventHandler,wxEvtHandler)
-  EVT_MOUSE_EVENTS( MyEventHandler::OnMouseEvent )
-END_EVENT_TABLE()
-
-MyEventHandler::MyEventHandler()
-{
-}
-
-void MyEventHandler::OnMouseEvent(wxMouseEvent &event)
-{
-    wxCanvasObject* obj=(wxCanvasObject*)event.GetEventObject();
-
-    if (!obj->GetDraggable())
-        return;
-
-    static double xprev;
-    static double yprev;
-
-    wxCanvasAdmin* adm=obj->GetAdmin();
-
-    //new position of the mouse relative within the object
-    double x = adm->DeviceToLogicalX(event.GetX());
-    double y = adm->DeviceToLogicalY(event.GetY());
-
-    if (event.LeftDown())
-    {
-        obj->CaptureMouse();
-        if (obj->GetDragMode() != wxDRAG_REDRAW)
-            obj->DragStart();
-    }
-    else if (event.LeftUp())
-    {
-        obj->ReleaseMouse();
-        if (obj->GetDragMode() != wxDRAG_REDRAW)
-            obj->DragEnd();
-    }
-    else if (obj->IsCapturedMouse())
-    {
-        if (obj->GetDragMode() != wxDRAG_REDRAW)
-            obj->DragRelative(x-xprev,y-yprev);
-        else
-            obj->MoveRelative(x-xprev,y-yprev);
-        adm->UpdateNow();
-    }
-    xprev=x;
-    yprev=y;
-    //well do something extra
-    if (obj->IsCapturedMouse())
-        obj->GetAdmin()->GetActive()->SetCursor(*wxHOURGLASS_CURSOR);
-    else
-        obj->GetAdmin()->GetActive()->SetCursor(*wxSTANDARD_CURSOR);
-}
-
-//------------------------------------------------
-// class MyFrame
-//------------------------------------------------
-
-class MyApp;
-class MyCanvas;
-
-BEGIN_EVENT_TABLE(MyFrame, wxFrame)
-  EVT_MENU(SPLIT_VERTICAL, MyFrame::SplitVertical)
-  EVT_MENU(SPLIT_HORIZONTAL, MyFrame::SplitHorizontal)
-  EVT_MENU(SPLIT_UNSPLIT, MyFrame::Unsplit)
-  EVT_MENU(SPLIT_QUIT, MyFrame::Quit)
-  EVT_MENU(SPLIT_SETMINSIZE, MyFrame::SetMinSize)
-
-  EVT_UPDATE_UI(SPLIT_VERTICAL, MyFrame::UpdateUIVertical)
-  EVT_UPDATE_UI(SPLIT_HORIZONTAL, MyFrame::UpdateUIHorizontal)
-  EVT_UPDATE_UI(SPLIT_UNSPLIT, MyFrame::UpdateUIUnsplit)
-
-  EVT_MENU    (ID_ABOUT, MyFrame::OnAbout)
-  EVT_TIMER   (-1,       MyFrame::OnTimer)
-END_EVENT_TABLE()
-
-// My frame constructor
-MyFrame::MyFrame(wxFrame* frame, const wxString& title, const wxPoint& pos, const wxSize& size):
-    wxFrame(frame, SPLITTER_FRAME, title, pos, size)
-{
-    m_eventhandler =new MyEventHandler();
-
-    wxPathList pathList;
-    pathList.Add(".");
-    pathList.Add("..");
-
-    wxString path = pathList.FindValidPath("pat36.bmp");
-    gs_bmp36_mono.LoadFile(path, wxBITMAP_TYPE_BMP);
-    wxMask* mask36 = new wxMask(gs_bmp36_mono, *wxBLACK);
-    /* associate a monochrome mask with this bitmap */
-    gs_bmp36_mono.SetMask(mask36);
-
-    CreateStatusBar(2);
-
-    // Make a menubar
-    fileMenu = new wxMenu;
-    fileMenu->Append(SPLIT_VERTICAL, "Split &Vertically\tCtrl-V", "Split vertically");
-    fileMenu->Append(SPLIT_HORIZONTAL, "Split &Horizontally\tCtrl-H", "Split horizontally");
-    fileMenu->Append(SPLIT_UNSPLIT, "&Unsplit", "Unsplit");
-//    fileMenu->Append(SPLIT_UNSPLIT, "&Unsplit\tCtrl-U", "Unsplit");
-    fileMenu->AppendSeparator();
-    fileMenu->Append(SPLIT_SETMINSIZE, "Set &min size", "Set minimum pane size");
-    fileMenu->AppendSeparator();
-    fileMenu->Append(SPLIT_QUIT, "E&xit\tAlt-X", "Exit");
-    fileMenu->Append( ID_ABOUT, "&About...");
-
-
-    menuBar = new wxMenuBar;
-    menuBar->Append(fileMenu, "&File");
-
-    SetMenuBar(menuBar);
-
-    m_splitter = new MySplitterWindow(this, SPLITTER_WINDOW);
-
-    m_canvas1 = new MyCanvas(&m_canvasadmin, m_splitter, CANVAS1, wxPoint(0, 0), wxSize(400, 400),wxHSCROLL|wxVSCROLL);
-    m_canvas1->SetYaxis(FALSE);
-    m_canvas1->SetMappingScroll(-300,-300,500,500,false);
-    m_canvas1->SetScroll(-400,-400,600,600);
-    m_canvas1->SetColour(wxColour(255, 255, 255) );
-    m_canvas1->SetCursor(wxCursor(wxCURSOR_MAGNIFIER));
-
-    m_canvas2 = new MyCanvas(&m_canvasadmin, m_splitter, CANVAS2, wxPoint(0, 0), wxSize(400, 400),wxHSCROLL|wxVSCROLL);
-    m_canvas2->SetMappingScroll(-100,-100,500,500,false);
-    m_canvas2->SetScroll(-400,-400,600,600);
-    m_canvas2->SetColour( wxColour(187, 215, 243) );
-    m_canvas2->Show(FALSE);
-
-    m_canvasadmin.Append(m_canvas1);
-    m_canvasadmin.Append(m_canvas2);
-    m_canvasadmin.SetActive(m_canvas1);
-
-    m_splitter->Initialize(m_canvas1);
-    SetStatusText("Min pane size = 0", 1);
-
-    int widths[] = { -1, 100 };
-    SetStatusWidths( 2, widths );
-
-    //root group always at 0,0
-    m_datatree = new wxCanvasObjectGroup(0,0);
-    m_datatree->DeleteContents( TRUE );
-    m_datatree->SetAdmin(&m_canvasadmin);
-
-    wxBitmap bitmap( smile_xpm );
-    wxImage image( bitmap.ConvertToImage() );
-
-//    m_sm1 = new wxCanvasImage( image, 0,70,32,32 );
-//    m_datatree->Append( m_sm1 );
-
-    int i;
-    for (i = 10; i < 300; i+=10)
-    {
-        wxCanvasRect *r = new wxCanvasRect( i,50,3,140 );
-        r->SetBrush( *wxRED_BRUSH );
-        m_datatree->Append( r );
-    }
-
-
-//    m_sm2 = new wxCanvasImage( image, 0,140,24,24 );
-//    m_datatree->Append( m_sm2 );
-
-    for (i = 15; i < 300; i+=10)
-    {
-        wxCanvasRect* rec= new wxCanvasRect( i,50,3,140 );
-        rec->SetBrush(wxBrush(wxColour(0,10+i,2+i),wxSOLID));
-        rec->SetDraggable(FALSE);
-        m_datatree->Append( rec );
-    }
-
-/*
-    wxButton *button = new wxButton( m_canvas1, -1, "Hello", wxPoint(80,50) );
-    m_datatree->Append( new wxCanvasControl( button ) );
-
-    m_datatree->Append( new wxCanvasText( "Hello", 180, 50,
-                      wxGetApp().GetFontPath() + "/times.ttf", 20 ) );
-
-    m_datatree->Append( new wxCanvasText( "How are you?", 180, 10,
-                      wxGetApp().GetFontPath() + "/times.ttf", 8 ) );
-
-    m_datatree->Append( new wxCanvasText( "How are you?", 180, 20,
-                      wxGetApp().GetFontPath() + "/times.ttf", 10 ) );
-
-    m_datatree->Append( new wxCanvasText( "How are you?", 180, 30,
-                      wxGetApp().GetFontPath() + "/times.ttf", 12 ) );
-    m_sm3 = new wxCanvasImage( image, 0,210,32,32 );
-    m_datatree->Append( m_sm3 );
-*/
-    for (i = 10; i < 300; i+=10)
-        m_datatree->Append( new wxCanvasLine( 10,-15,i,300 ) );
-/*
-    m_sm4 = new wxCanvasImage( image, 0,270,64,32 );
-    m_sm4->SetDragMode(wxDRAG_RECTANGLE);
-    m_datatree->Append( m_sm4 );
-*/
-
-//    m_canvas->Append( new wxCanvasLine( 10,-1500e6,50,300000e6, 0,255,0 ) );
-//    m_canvas->Append( new wxCanvasLine( 10,-150000,50,300000, 0,255,0 ) );
-
-
-    //make a group of wxCanvasObjects
-    wxCanvasObjectGroup* group1 = new wxCanvasObjectGroup(0,0);
-
-    wxCanvasLine* line = new wxCanvasLine( 10,-35,50,190);
-    line->SetPen(wxPen(wxColour(255,161,5),5,wxDOT_DASH ));
-    group1->Prepend( line );
-    group1->Prepend( new wxCanvasImage( image, 4,38,32,32 ) );
-    wxCanvasRect* rec3 = new wxCanvasRect(20,-20,50,170);
-    rec3->SetBrush(wxBrush(wxColour(0,120,240),wxSOLID));
-    rec3->SetPen(wxPen(wxColour(252,54,252 ),3,wxSOLID));
-    group1->Prepend( rec3 );
-
-    wxCanvasRect* rec2 = new wxCanvasRect(10,20,104,52);
-    rec2->SetBrush(wxBrush(wxColour(0,240,240),wxSOLID));
-    rec2->SetPen(wxPen(wxColour(210,40,50 ),1,wxSOLID));
-    group1->Prepend( rec2 );
-
-
-
-    wxPoint2DDouble* todraw2 = new wxPoint2DDouble[3];
-    todraw2[0].m_x=230;
-    todraw2[0].m_y=220;
-    todraw2[1].m_x=300;
-    todraw2[1].m_y=200;
-    todraw2[2].m_x=300;
-    todraw2[2].m_y=300;
-    wxCanvasPolyline* poly2= new wxCanvasPolyline(3,todraw2);
-    poly2->SetPen(wxPen(wxColour(200,0,64 ),4,wxDOT));
-    m_datatree->Prepend( poly2 );
-
-
-
-    //make another group of wxCanvasObjects
-    wxCanvasObjectGroup* group2 = new wxCanvasObjectGroup(0,0);
-    group2->Prepend( new wxCanvasImage( image, 60,38,52,32 ) );
-    wxCanvasRect* rr = new wxCanvasRect(10,20,104,52,30);
-    rr->SetBrush(wxBrush(wxColour(10,17,255),wxHORIZONTAL_HATCH ));
-    rr->SetPen(wxPen(wxColour(9,115,64 ),4,wxSOLID));
-    group2->Prepend( rr );
-
-
-    //this a reference to group2 put into group1
-    MywxCanvasObjectRef* m_subref = new MywxCanvasObjectRef(60,50, group2);
-    m_subref->SetRotation(35);
-    m_subref->SetRotation(0);
-    group1->Prepend( m_subref );
-
-
-    wxPoint2DDouble* todraw = new wxPoint2DDouble[5];
-    todraw[0].m_x=-30;
-    todraw[0].m_y=-20;
-    todraw[1].m_x=100;
-    todraw[1].m_y=0;
-    todraw[2].m_x=100;
-    todraw[2].m_y=100;
-    todraw[3].m_x=50;
-    todraw[3].m_y=150;
-    todraw[4].m_x=0;
-    todraw[4].m_y=100;
-
-    wxCanvasPolygon* poly= new wxCanvasPolygon(5,todraw);
-    poly->SetBrush(wxBrush(wxColour(100,17,255),wxCROSSDIAG_HATCH ));
-    poly->SetPen(wxPen(wxColour(9,115,64 ),4,wxSOLID));
-    group1->Prepend( poly );
-
-    wxPoint2DDouble* todraw4 = new wxPoint2DDouble[4];
-
-    todraw4[0].m_x=-50;
-    todraw4[0].m_y=-30;
-    todraw4[1].m_x=-50;
-    todraw4[1].m_y=70;
-    todraw4[2].m_x=150;
-    todraw4[2].m_y=70;
-    todraw4[3].m_x=150;
-    todraw4[3].m_y=-30;
-
-    wxCanvasPolygon* poly5= new wxCanvasPolygon(4,todraw4);
-    poly5->SetBrush(wxBrush(wxColour(100,17,255),wxCROSSDIAG_HATCH ));
-//    poly5->SetBrush(wxBrush(wxColour(100,17,255),wxSOLID ));
-//    poly5->SetPen(wxPen(wxColour(9,115,64 ),1,wxSOLID));
-    poly5->SetPen(wxPen(wxColour(9,115,64 ),4,wxSOLID));
-    wxCanvasObjectGroup* group3 = new wxCanvasObjectGroup(0,0);
-    group3->Prepend( poly5 );
-
-    wxList* pointlist = new wxList();
-    wxPoint2DDouble* point = new wxPoint2DDouble(0,0);
-    pointlist->Append((wxObject*)point);
-    point = new wxPoint2DDouble(-300,100);
-    pointlist->Append((wxObject*)point);
-    point = new wxPoint2DDouble(-100,100);
-    pointlist->Append((wxObject*)point);
-    point = new wxPoint2DDouble(-100,0);
-    pointlist->Append((wxObject*)point);
-    point = new wxPoint2DDouble(-200,50);
-    pointlist->Append((wxObject*)point);
-
-    wxCanvasPolygonL* poly15= new wxCanvasPolygonL(pointlist,TRUE);
-    poly15->SetColour1(wxColour(250,78,216 ));
-    poly15->SetColour2(*wxRED);
-    poly15->SetBrush(wxBrush(gs_bmp36_mono));
-    poly15->SetTransParent(TRUE);
-    poly15->SetPen(wxPen(*wxRED,4,wxSOLID));
-    group1->Prepend( poly15 );
-
-    wxList* pointlist2 = new wxList();
-    wxPoint2DDouble* point2 = new wxPoint2DDouble(-400,100);
-    pointlist2->Append((wxObject*)point2);
-    point2 = new wxPoint2DDouble(-400,200);
-    pointlist2->Append((wxObject*)point2);
-    point2 = new wxPoint2DDouble(0,200);
-    pointlist2->Append((wxObject*)point2);
-    point2 = new wxPoint2DDouble(0,100);
-    pointlist2->Append((wxObject*)point2);
-    point2 = new wxPoint2DDouble(-200,175);
-    pointlist2->Append((wxObject*)point2);
-
-    wxCanvasPolylineL* poly16= new wxCanvasPolylineL(pointlist2,TRUE);
-    poly16->SetPen(wxPen(wxColour(9,115,64 ),4,wxSOLID));
-    m_datatree->Prepend( poly16 );
-
-
-    wxPoint2DDouble* todraw6 = new wxPoint2DDouble[5];
-    todraw6[0].m_x=50;
-    todraw6[0].m_y=305;
-    todraw6[1].m_x=-200;
-    todraw6[1].m_y=200;
-    todraw6[2].m_x=0;
-    todraw6[2].m_y=500;
-    todraw6[3].m_x=300;
-    todraw6[3].m_y=200;
-    todraw6[4].m_x=-300;
-    todraw6[4].m_y=-300;
-
-    wxCanvasPolygon* poly17= new wxCanvasPolygon(5,todraw6,TRUE);
-    poly17->SetBrush(wxBrush(wxColour(100,17,255),wxSOLID));
-    poly17->SetPen(wxPen(wxColour(10,17,25),16,wxLONG_DASH  ));
-    poly17->SetColour1(*wxGREEN);
-    poly17->SetColour2(*wxRED);
-    poly17->SetGradient(TRUE,wxPen(wxColour(0,0,0),0,wxSOLID),0);
-    wxCanvasObjectRef* m_refc = new wxCanvasObjectRef(0,-200, poly17);
-    m_refc->SetRotation(90);
-    m_datatree->Prepend( m_refc );
-    wxCanvasObjectRef* m_refd = new wxCanvasObjectRef(200,-50, poly17);
-    m_refd->SetRotation(0);
-    m_datatree->Append( m_refd );
-
-    //now make two references to group1 into root group of the canvas
-    m_ref = new MywxCanvasObjectRef(350,-200, group1);
-    m_ref->SetRotation(25);
-    //TODO if rotation is 0 scaling is weird
-//    m_ref->SetScale(2,3.2);
-    m_datatree->Append( m_ref );
-
-    group3->Prepend( m_ref );
-
-
-    //this a reference to group2 put into group1
-    MywxCanvasObjectRef* subref2 = new MywxCanvasObjectRef(20,130, group2);
-    subref2->SetRotation(15);
-    group3->Prepend( subref2 );
-    m_datatree->Prepend( subref2 );
-
-    m_ref2 = new MywxCanvasObjectRef(80,450, group1);
-    m_ref2->SetRotation(-35);
-    m_ref2->SetDragMode(wxDRAG_RECTANGLE);
-    m_datatree->Prepend( m_ref2 );
-
-    wxCanvasCircle* cir = new  wxCanvasCircle( -100, -150, 100 );
-    cir->SetBrush(wxBrush(wxColour(19,215,6),wxHORIZONTAL_HATCH ));
-    cir->SetPen(wxPen(wxColour(198,3,105 ),30,wxSOLID));
-    cir->SetDragMode(wxDRAG_REDRAW);
-    m_datatree->Prepend( cir );
-
-    wxCanvasEllipse* elp = new  wxCanvasEllipse( -100, 250, 100,300 );
-    elp->SetBrush(wxBrush(wxColour(100,17,55),wxVERTICAL_HATCH ));
-    elp->SetPen(wxPen(wxColour(2,255,6 ),10,wxDOT));
-    m_datatree->Prepend( elp );
-
-    wxCanvasEllipticArc* aelp = new  wxCanvasEllipticArc( -230, 250, 100,300, 30,270 );
-    aelp->SetBrush(wxBrush(wxColour(100,17,155),wxSOLID ));
-    aelp->SetPen(wxPen(wxColour(1,215,6 ),10,wxSOLID));
-    m_datatree->Prepend( aelp );
-
-    //HOW BAD DO THINGS GET
-    int kk;
-    for (kk=0;kk<100;kk++)
-    {
-//        MywxCanvasObjectRef* m_refx = new MywxCanvasObjectRef(180,50+kk*30, group1);
-//        m_refx->SetRotation(-35);
-//        m_datatree->Prepend( m_refx );
-    }
-
-/*
-    m_log = new wxTextCtrl( this, -1, "", wxPoint(0,0), wxSize(100,100), wxTE_MULTILINE );
-    wxLog *old_log = wxLog::SetActiveTarget( new wxLogTextCtrl( m_log ) );
-    delete old_log;
-
-    wxBoxSizer *topsizer = new wxBoxSizer( wxVERTICAL );
-
-    topsizer->Add( m_canvas, 1, wxEXPAND );
-    topsizer->Add( m_log, 0, wxEXPAND );
-
-    SetAutoLayout( TRUE );
-    SetSizer( topsizer );
-*/
-
-    //fancy background
-    wxPoint2DDouble* todraw8 = new wxPoint2DDouble[4];
-    todraw8[0].m_x=-350;
-    todraw8[0].m_y=-350;
-    todraw8[1].m_x=-350;
-    todraw8[1].m_y=550;
-    todraw8[2].m_x=550;
-    todraw8[2].m_y=550;
-    todraw8[3].m_x=550;
-    todraw8[3].m_y=-350;
-
-    wxCanvasPolygon* poly18= new wxCanvasPolygon(4,todraw8);
-    poly18->SetPen(wxPen(wxColour(10,17,25),16,wxTRANSPARENT  ));
-    poly18->SetColour1(wxColour(0,0,0));
-    poly18->SetColour2(wxColour(0,255,255));
-    poly18->SetGradient(TRUE,wxPen(wxColour(0,0,0),0,wxSOLID),0);
-
-    wxCanvasObjectRef* m_refb = new wxCanvasObjectRef(200,0, poly18);
-    m_refb->SetRotation(90);
-
-    m_datatree->Prepend( m_refb );
-
-/*
-    wxCanvasCircle* cir = new  wxCanvasCircle( -100, -150, 100 );
-    cir->SetBrush(wxBrush(wxColour(19,215,6),wxHORIZONTAL_HATCH ));
-    cir->SetPen(wxPen(wxColour(198,3,105 ),30,wxSOLID));
-    m_datatree->Prepend( cir );
-*/
-    m_datatree->SetAdmin(&m_canvasadmin);
-    m_datatree->AppendEventHandler( m_eventhandler );
-    m_canvas1->SetRoot(m_datatree);
-
-    //wxCanvasObjectGroup* group3 = new wxCanvasObjectGroup(0,0);
-   // group3->Prepend( cir );
-
-    group3->SetAdmin(&m_canvasadmin);
-    m_canvas2->SetRoot(group3);
-
-    m_timer = new wxTimer( this );
-    //m_timer->Start( 100, FALSE );
-}
-
-MyFrame::~MyFrame()
-{
-   m_datatree->RemoveLastEventHandler( FALSE );
-   delete m_eventhandler;
-   delete m_timer;
-}
-
-void MyFrame::Quit(wxCommandEvent& WXUNUSED(event) )
-{
-  Close(TRUE);
-}
-
-void MyFrame::SplitHorizontal(wxCommandEvent& WXUNUSED(event) )
-{
-  if ( m_splitter->IsSplit() )
-    m_splitter->Unsplit();
-  m_canvas1->Show(TRUE);
-  m_canvas2->Show(TRUE);
-  m_splitter->SplitHorizontally( m_canvas1, m_canvas2 );
-  UpdatePosition();
-}
-
-void MyFrame::SplitVertical(wxCommandEvent& WXUNUSED(event) )
-{
-  if ( m_splitter->IsSplit() )
-    m_splitter->Unsplit();
-  m_canvas1->Show(TRUE);
-  m_canvas2->Show(TRUE);
-  m_splitter->SplitVertically( m_canvas1, m_canvas2 );
-  UpdatePosition();
-}
-
-void MyFrame::Unsplit(wxCommandEvent& WXUNUSED(event) )
-{
-  if ( m_splitter->IsSplit() )
-    m_splitter->Unsplit();
-  SetStatusText("No splitter");
-}
-
-void MyFrame::SetMinSize(wxCommandEvent& WXUNUSED(event) )
-{
-  wxString str;
-  str.Printf( _T("%d"), m_splitter->GetMinimumPaneSize());
-  str = wxGetTextFromUser("Enter minimal size for panes:", "", str, this);
-  if ( str.IsEmpty() )
-    return;
-
-  int minsize = wxStrtol( str, (wxChar**)NULL, 10 );
-  m_splitter->SetMinimumPaneSize(minsize);
-  str.Printf( _T("Min pane size = %d"), minsize);
-  SetStatusText(str, 1);
-}
-
-void MyFrame::UpdateUIHorizontal(wxUpdateUIEvent& event)
-{
-  event.Enable( ( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_HORIZONTAL) ) );
-}
-
-void MyFrame::UpdateUIVertical(wxUpdateUIEvent& event)
-{
-  event.Enable( ( (!m_splitter->IsSplit()) || (m_splitter->GetSplitMode() != wxSPLIT_VERTICAL) ) );
-}
-
-void MyFrame::UpdateUIUnsplit(wxUpdateUIEvent& event)
-{
-  event.Enable( m_splitter->IsSplit() );
-}
-
-void MyFrame::UpdatePosition()
-{
-  wxString str;
-  str.Printf( "Sash position = %d", m_splitter->GetSashPosition());
-  SetStatusText(str);
-}
-
-void MyFrame::OnQuit( wxCommandEvent &WXUNUSED(event) )
-{
-    Close( TRUE );
-}
-
-void MyFrame::OnTimer( wxTimerEvent &WXUNUSED(event) )
-{
-    m_sm1->MoveRelative( 1, 0);
-    m_sm2->MoveRelative( 1, 0);
-    m_sm3->MoveRelative( 1, 0);
-    m_sm4->MoveRelative( 2, 0);
-
-//    m_ref->MoveRelative( 1, 0 );
-    m_ref2->MoveRelative( 2, 0 );
-    m_canvas1->UpdateNow();
-
-
-    wxWakeUpIdle();
-}
-
-void MyFrame::OnAbout( wxCommandEvent &WXUNUSED(event) )
-{
-   (void)wxMessageBox( "wxCanvas demo\n"
-                      "Robert Roebling (c) 1998,2000 \n Modified by Klaas Holwerda 2000",
-                      "About wxCanvas Demo", wxICON_INFORMATION | wxOK );
-}
-
-
-//------------------------------------------------
-// class MyCanvas
-//------------------------------------------------
-
-// the event tables connect the wxWindows events with the functions (event
-// handlers) which process them.
-BEGIN_EVENT_TABLE(MyCanvas,wxVectorCanvas)
-    EVT_MOUSE_EVENTS (MyCanvas::OnMouseEvent)
-END_EVENT_TABLE()
-
-MyCanvas::MyCanvas(wxCanvasAdmin* admin, MySplitterWindow *parent, wxWindowID id,
-    const wxPoint &position, const wxSize& size, long style ) :
-    wxVectorCanvas( admin, parent, id, position, size, style )
-{
-    m_parent=parent;
-}
-
-void MyCanvas::OnMouseEvent(wxMouseEvent& event)
-{
-    wxClientDC dc(this);
-    PrepareDC(dc);
-
-    wxPoint pos = event.GetPosition();
-
-    m_mouse_worldx = DeviceToLogicalX( pos.x );
-    m_mouse_worldy = DeviceToLogicalY( pos.y );
-
-    wxString str;
-    str.Printf( "Current mouse position: %f,%f", m_mouse_worldx, m_mouse_worldy );
-    m_parent->SetStatusText( str );
-
-    if (!event.m_controlDown && !GetCaptured())
-    {
-        if (event.LeftDown())
-        {
-            m_zoom_x1=m_zoom_x2=pos.x;
-            m_zoom_y1=m_zoom_y2=pos.y;
-        }
-        if (event.RightDown())
-        {
-            SetMappingScroll(m_virtm_minX,m_virtm_minY,m_virtm_maxX,m_virtm_maxY,0);
-            Update( 0,0, GetBufferWidth(), GetBufferHeight(), TRUE );
-            UpdateNow();
-        }
-        if (event.LeftUp())
-        {
-            m_zoom_x2=pos.x;
-            m_zoom_y2=pos.y;
-            double x_virt_min=DeviceToLogicalX(m_zoom_x1);
-            double y_virt_min=DeviceToLogicalY(m_zoom_y2);
-            double x_virt_max=DeviceToLogicalX(m_zoom_x2);
-            double y_virt_max=DeviceToLogicalY(m_zoom_y1);
-            SetMappingScroll(x_virt_min,y_virt_min,x_virt_max,y_virt_max,0);
-            Update( 0,0, GetBufferWidth(), GetBufferHeight(), TRUE );
-            UpdateNow();
-        }
-        if (event.Dragging()&& event.m_leftDown)
-        {
-            dc.SetLogicalFunction(wxINVERT);
-            dc.DrawRectangle(m_zoom_x1,m_zoom_y1,m_zoom_x2-m_zoom_x1,m_zoom_y2-m_zoom_y1 );
-            m_zoom_x2=pos.x;
-            m_zoom_y2=pos.y;
-            dc.DrawRectangle(m_zoom_x1,m_zoom_y1,m_zoom_x2-m_zoom_x1,m_zoom_y2-m_zoom_y1 );
-        }
-    }
-    else
-    {
-        wxVectorCanvas::OnMouse(event);
-    }
-}
-
-
-//-----------------------------------------------------------------------------
-// MyApp
-//-----------------------------------------------------------------------------
-
-// main program
-
-IMPLEMENT_APP(MyApp)
-
-bool MyApp::OnInit()
-{
-  m_fontpath = getenv("TRUETYPE");
-  m_fontpath = "c:/WINNT/Fonts/times.ttf";
-  if ( !m_fontpath )
-  {
-      wxLogError("Please set env var TRUETYPE to the path where times.ttf lives.");
-
-      return FALSE;
-
-  }
-
-#if wxUSE_LIBPNG
-  wxImage::AddHandler( new wxPNGHandler );
-#endif
-
-  wxFrame *frame = new MyFrame((wxFrame *) NULL, "wxCanvas Example", wxPoint(0,0), wxSize(400,500));
-  frame->Show( TRUE );
-
-  SetTopWindow(frame);
-
-  return TRUE;
-}
-