#include "wx/utils.h"
#include "wx/dcclient.h"
-#ifdef __WXMSW__
-#include "windows.h"
-#endif
-
#ifdef __BORLANDC__
#pragma hdrstop
#endif
IMPLEMENT_DYNAMIC_CLASS(wxScrolledWindow, wxWindow)
#endif
+#ifdef __WXMSW__
+#include "windows.h"
+#endif
+
wxScrolledWindow::wxScrolledWindow(void)
{
m_xScrollPixelsPerLine = 0;
if (do_refresh && !noRefresh) Refresh();
#ifdef __WXMSW__
+ // Necessary?
UpdateWindow ((HWND) GetHWND());
#endif
}
int nScrollInc = CalcScrollInc(event);
if (nScrollInc == 0) return;
- // TODO: should we store the scroll position here as well as in wxWindow?
if (orient == wxHORIZONTAL)
{
int newPos = m_xScrollPosition + nScrollInc;
SetScrollPos(wxVERTICAL, newPos, TRUE );
}
-/*
- // TODO We need to multiply the ScrollWindow amount by the scaling
- // factor, but how do we know what this is in wxWin 2.0???
- float scaleX = 1.0;
- float scaleY = 1.0;
-
- if ( this->IsKindOf(CLASSINFO(wxCanvas)) )
- {
- wxDC* dc = ((wxCanvas *)this)->GetDC();
- dc->GetUserScale(&scaleX, &scaleY);
- }
-*/
-
if (orient == wxHORIZONTAL)
{
m_xScrollPosition += nScrollInc;
break;
}
}
+
if (orient == wxHORIZONTAL)
{
if (m_xScrollPixelsPerLine > 0) {
m_xScrollPosition = wxMax( 0, m_xScrollPosition );
SetScrollbar(wxHORIZONTAL, m_xScrollPosition, noPagePositions, m_xScrollLines);
-// SetScrollPageSize(wxHORIZONTAL, noPagePositions);
+ // The amount by which we scroll when paging
+ SetScrollPageSize(wxHORIZONTAL, noPagePositions);
}
else
{
m_yScrollPosition = wxMax( 0, m_yScrollPosition );
SetScrollbar(wxVERTICAL, m_yScrollPosition, noPagePositions, m_yScrollLines);
-// SetScrollPageSize(wxVERTICAL, noPagePositions);
+ // The amount by which we scroll when paging
+ SetScrollPageSize(wxVERTICAL, noPagePositions);
}
else
{
Refresh();
#ifdef __WXMSW__
+ // Necessary?
::UpdateWindow ((HWND) GetHWND());
#endif
}