From: Włodzimierz Skiba Date: Thu, 24 Feb 2005 10:51:11 +0000 (+0000) Subject: Further improvements in composite controls (wxRadioBox) on PalmOS. X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/d289329218fb13e56c297fc27d82cb44cb849083?ds=inline Further improvements in composite controls (wxRadioBox) on PalmOS. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@32341 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/src/palmos/control.cpp b/src/palmos/control.cpp index 90a0b34af3..3b9b881995 100644 --- a/src/palmos/control.cpp +++ b/src/palmos/control.cpp @@ -123,7 +123,14 @@ bool wxControl::PalmCreateControl(ControlStyleType style, w = size.x == wxDefaultCoord ? 1 : size.x, h = size.y == wxDefaultCoord ? 1 : size.y; - AdjustForParentClientOrigin(x, y); + wxWindow *win = this; + while(win->GetParent()) + { + win = win->GetParent(); + wxPoint pt(win->GetClientAreaOrigin()); + x += pt.x; + y += pt.y; + } ControlType *control = CtlNewControl( (void **)&form, @@ -299,18 +306,23 @@ void wxControl::DoSetBounds( RectangleType &rect ) void wxControl::DoGetPosition( int *x, int *y ) const { + int ox = 0, oy = 0; + AdjustForParentClientOrigin(ox, oy); + RectangleType rect; DoGetBounds(rect); + if(x) - *x = rect.topLeft.x; + *x = rect.topLeft.x - ox; if(y) - *y = rect.topLeft.y; + *y = rect.topLeft.y - oy; } void wxControl::DoGetSize( int *width, int *height ) const { RectangleType rect; DoGetBounds(rect); + if(width) *width = rect.extent.x; if(height) diff --git a/src/palmos/radiobox.cpp b/src/palmos/radiobox.cpp index a9449d5594..a82b1e6f6f 100644 --- a/src/palmos/radiobox.cpp +++ b/src/palmos/radiobox.cpp @@ -254,6 +254,8 @@ void wxRadioBox::DoMoveWindow(int x, int y, int width, int height) { wxRect oldRect = GetRect(); + m_pos.x = x; + m_pos.y = y; m_size.x = width; m_size.y = height; @@ -292,7 +294,7 @@ void wxRadioBox::DoMoveWindow(int x, int y, int width, int height) // get the origin of the client area in the client coordinates wxPoint wxRadioBox::GetClientAreaOrigin() const { - return GetParent()->GetClientAreaOrigin() + GetPosition(); + return GetPosition(); } void wxRadioBox::SetString(int item, const wxString& label) diff --git a/src/palmos/window.cpp b/src/palmos/window.cpp index b46aad8784..02a43e497a 100644 --- a/src/palmos/window.cpp +++ b/src/palmos/window.cpp @@ -448,10 +448,10 @@ void wxWindowPalm::Refresh(bool eraseBack, const wxRect *rect) if(rect) { RectangleType dirtyRect; - dirtyRect.topLeft.x = rect->GetX(); - dirtyRect.topLeft.y = rect->GetY(); - dirtyRect.extent.x = rect->GetWidth(); - dirtyRect.extent.y = rect->GetHeight(); + dirtyRect.topLeft.x = rect->GetX() - 1; + dirtyRect.topLeft.y = rect->GetY() - 1; + dirtyRect.extent.x = rect->GetWidth() + 1; + dirtyRect.extent.y = rect->GetHeight() + 1; WinInvalidateRect(handle, &dirtyRect); } else @@ -510,6 +510,10 @@ void wxWindowPalm::DoGetClientSize(int *x, int *y) const void wxWindowPalm::DoGetPosition(int *x, int *y) const { + if(x) + *x = 0; + if(y) + *y = 0; } void wxWindowPalm::DoScreenToClient(int *x, int *y) const