X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/833615dd4d989427dfb43927aa5d46d4f1b7175d..fad535eea353fa1ce2f15e3053fc3b96e9a0b02d:/src/os2/window.cpp diff --git a/src/os2/window.cpp b/src/os2/window.cpp index d032c864b7..2aef2aaeff 100644 --- a/src/os2/window.cpp +++ b/src/os2/window.cpp @@ -332,6 +332,7 @@ bool wxWindow::Create( { HWND hParent = NULLHANDLE; wxPoint vPos = rPos; // The OS/2 position + ULONG ulCreateFlags = 0L; wxCHECK_MSG(pParent, FALSE, wxT("can't create wxWindow without parent")); @@ -354,16 +355,25 @@ bool wxWindow::Create( // // OS2 uses normal coordinates, no bassackwards Windows ones // - nTempy = pParent->GetSize().y - (vPos.y + rSize.y); -#if 0 - if (nTempy < 0) + if (pParent->IsKindOf(CLASSINFO(wxGenericScrolledWindow)) || + pParent->IsKindOf(CLASSINFO(wxScrolledWindow)) + ) { - nTempy = pParent->GetSize().y + (vPos.y + rSize.y); - pParent->SetSize(0, 0, pParent->GetSize().x, nTempy); - nTempy = pParent->GetSize().y - (vPos.y + rSize.y); + wxWindow* pGrandParent = NULL; + + pGrandParent = pParent->GetParent(); + if (pGrandParent) + nTempy = pGrandParent->GetSize().y - (vPos.y + rSize.y); + else + nTempy = pParent->GetSize().y - (vPos.y + rSize.y); } -#endif + else + nTempy = pParent->GetSize().y - (vPos.y + rSize.y); vPos.y = nTempy; + if ( pParent->IsKindOf(CLASSINFO(wxGenericScrolledWindow)) || + pParent->IsKindOf(CLASSINFO(wxScrolledWindow)) + ) + ulCreateFlags |= WS_CLIPSIBLINGS; } else { @@ -374,9 +384,6 @@ bool wxWindow::Create( vPos.y = vRect.yTop - (vPos.y + rSize.y); } - ULONG ulCreateFlags = 0L; - - // // Most wxSTYLES are really PM Class specific styles and will be // set in those class create procs. PM's basic windows styles are @@ -385,7 +392,7 @@ bool wxWindow::Create( ulCreateFlags |= WS_VISIBLE; - if ( lStyle & wxCLIP_SIBLINGS ) + if (lStyle & wxCLIP_SIBLINGS) ulCreateFlags |= WS_CLIPSIBLINGS; if (lStyle & wxCLIP_CHILDREN ) @@ -907,15 +914,35 @@ void wxWindow::ScrollWindow( { wxWindow* pChildWin = pCurrent->GetData(); - ::WinQueryWindowPos(pChildWin->GetHWND(), &vSwp); - ::WinSetWindowPos( pChildWin->GetHWND() - ,HWND_TOP - ,vSwp.x + nDx - ,vSwp.y + nDy - ,0 - ,0 - , SWP_MOVE | SWP_SHOW - ); + if (pChildWin->GetHWND() != NULLHANDLE) + { + ::WinQueryWindowPos(pChildWin->GetHWND(), &vSwp); + ::WinQueryWindowRect(pChildWin->GetHWND(), &vRect); + if (pChildWin->GetHWND() == m_hWndScrollBarVert || + pChildWin->GetHWND() == m_hWndScrollBarHorz) + { + ::WinSetWindowPos( pChildWin->GetHWND() + ,HWND_TOP + ,vSwp.x + nDx + ,vSwp.y + nDy + ,0 + ,0 + ,SWP_MOVE | SWP_SHOW | SWP_ZORDER + ); + } + else + { + ::WinSetWindowPos( pChildWin->GetHWND() + ,HWND_BOTTOM + ,vSwp.x + nDx + ,vSwp.y + nDy + ,0 + ,0 + ,SWP_MOVE | SWP_ZORDER + ); + ::WinInvalidateRect(pChildWin->GetHWND(), &vRect, FALSE); + } + } pCurrent = pCurrent->GetNext(); } } // end of wxWindow::ScrollWindow @@ -2573,10 +2600,8 @@ bool wxWindow::OS2Create( RECTL vParentRect; HWND hWndClient; - if (lX > -1L) - lX1 = lX; - if (lY > -1L) - lY1 = lY; + lX1 = lX; + lY1 = lY; if (lWidth > -1L) lWidth1 = lWidth; if (lHeight > -1L)