X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ab45fb147bbfa253219d43a685103cc5b073ee85..f155075229d771430f0793700f5048ad4be00e9d:/tests/misc/guifuncs.cpp?ds=sidebyside diff --git a/tests/misc/guifuncs.cpp b/tests/misc/guifuncs.cpp index 83411a685e..e63835d92f 100644 --- a/tests/misc/guifuncs.cpp +++ b/tests/misc/guifuncs.cpp @@ -28,6 +28,9 @@ #include "wx/button.h" #include "wx/clipbrd.h" #include "wx/dataobj.h" +#include "wx/panel.h" + +#include "asserthelper.h" // ---------------------------------------------------------------------------- // test class @@ -43,12 +46,14 @@ private: CPPUNIT_TEST( DisplaySize ); CPPUNIT_TEST( URLDataObject ); CPPUNIT_TEST( ParseFileDialogFilter ); + CPPUNIT_TEST( ClientToScreen ); CPPUNIT_TEST( FindWindowAtPoint ); CPPUNIT_TEST_SUITE_END(); void DisplaySize(); void URLDataObject(); void ParseFileDialogFilter(); + void ClientToScreen(); void FindWindowAtPoint(); DECLARE_NO_COPY_CLASS(MiscGUIFuncsTestCase) @@ -134,6 +139,39 @@ void MiscGUIFuncsTestCase::ParseFileDialogFilter() ); } +void MiscGUIFuncsTestCase::ClientToScreen() +{ + wxWindow* const tlw = wxTheApp->GetTopWindow(); + CPPUNIT_ASSERT( tlw ); + + wxPanel* const + p1 = new wxPanel(tlw, wxID_ANY, wxPoint(0, 0), wxSize(100, 50)); + wxPanel* const + p2 = new wxPanel(tlw, wxID_ANY, wxPoint(0, 50), wxSize(100, 50)); + wxWindow* const + b = new wxWindow(p2, wxID_ANY, wxPoint(10, 10), wxSize(30, 10)); + + // We need this to realize the windows created above under wxGTK. + wxYield(); + + const wxPoint tlwOrig = tlw->ClientToScreen(wxPoint(0, 0)); + + CPPUNIT_ASSERT_EQUAL + ( + tlwOrig + wxPoint(0, 50), + p2->ClientToScreen(wxPoint(0, 0)) + ); + + CPPUNIT_ASSERT_EQUAL + ( + tlwOrig + wxPoint(10, 60), + b->ClientToScreen(wxPoint(0, 0)) + ); + + p1->Destroy(); + p2->Destroy(); +} + namespace { @@ -169,6 +207,13 @@ void MiscGUIFuncsTestCase::FindWindowAtPoint() // assertion messages. parent->SetLabel("parent"); + wxWindow* btn1 = new TestButton(parent, "1", wxPoint(10, 10)); + wxWindow* btn2 = new TestButton(parent, "2", wxPoint(10, 90)); + wxWindow* btn3 = new TestButton(btn2, "3", wxPoint(20, 20)); + + // We need this to realize the windows created above under wxGTK. + wxYield(); + CPPUNIT_ASSERT_EQUAL_MESSAGE ( "No window for a point outside of the window", @@ -176,7 +221,6 @@ void MiscGUIFuncsTestCase::FindWindowAtPoint() GetLabelOfWindowAtPoint(parent, 900, 900) ); - wxWindow* btn1 = new TestButton(parent, "1", wxPoint(10, 10)); CPPUNIT_ASSERT_EQUAL_MESSAGE ( "Point over a child control corresponds to it", @@ -191,7 +235,6 @@ void MiscGUIFuncsTestCase::FindWindowAtPoint() GetLabelOfWindowAtPoint(parent, 5, 5) ); - wxWindow* btn2 = new TestButton(parent, "2", wxPoint(10, 90)); btn2->Disable(); CPPUNIT_ASSERT_EQUAL_MESSAGE ( @@ -209,16 +252,22 @@ void MiscGUIFuncsTestCase::FindWindowAtPoint() ); btn2->Show(); - wxWindow* btn3 = new TestButton(btn2, "3", wxPoint(0, 0)); + CPPUNIT_ASSERT_EQUAL_MESSAGE + ( + "Point over child control corresponds to the child", + btn3->GetLabel(), + GetLabelOfWindowAtPoint(parent, 31, 111) + ); + btn3->Disable(); CPPUNIT_ASSERT_EQUAL_MESSAGE ( - "Point over recursive disabled child controls corresponds to deepest child", + "Point over disabled child controls still corresponds to this child", btn3->GetLabel(), - GetLabelOfWindowAtPoint(parent, 11, 91) + GetLabelOfWindowAtPoint(parent, 31, 111) ); - wxDELETE(btn1); - wxDELETE(btn3); // delete child before parent - wxDELETE(btn2); + btn1->Destroy(); + btn2->Destroy(); + // btn3 was already deleted when its parent was }