X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/16361ec94128d2cea3a08c2c84a4eb38232715d6..c40555e948e48d5c10f30d0c83b2c7702d23fa8e:/include/wx/scrolwin.h?ds=sidebyside diff --git a/include/wx/scrolwin.h b/include/wx/scrolwin.h index 62ccdb04b1..860c65d559 100644 --- a/include/wx/scrolwin.h +++ b/include/wx/scrolwin.h @@ -208,6 +208,17 @@ protected: // in wxScrollHelperEvtHandler::ProcessEvent() void ResetDrawnFlag(); + // helper of AdjustScrollbars(): does the work for the single scrollbar + // + // notice that the parameters passed by non-const references are modified + // by this function + void AdjustScrollbar(int orient, + int clientSize, + int virtSize, + int& pixelsPerUnit, + int& scrollUnits, + int& scrollPosition); + double m_scaleX; double m_scaleY; @@ -237,6 +248,19 @@ protected: wxScrollHelperEvtHandler *m_handler; +private: + // this function should be overridden to return the size available for + // m_targetWindow inside m_win of the given size + // + // the default implementation is only good for m_targetWindow == m_win + // case, if we're scrolling a subwindow you must override this method + virtual wxSize GetSizeAvailableForScrollTarget(const wxSize& size) + { + wxASSERT_MSG( m_targetWindow == m_win, "must be overridden" ); + + return size; + } + DECLARE_NO_COPY_CLASS(wxScrollHelper) }; @@ -271,7 +295,7 @@ struct WXDLLIMPEXP_CORE wxScrolledT_Helper const wxScrollHelperNative *helper, const wxSize& origBest); #ifdef __WXMSW__ - static WXLRESULT FilterMSWWindowProc(WXLRESULT origResult); + static WXLRESULT FilterMSWWindowProc(WXUINT nMsg, WXLRESULT origResult); #endif }; @@ -306,7 +330,7 @@ public: m_targetWindow = this; #ifdef __WXMAC__ - MacSetClipChildren(true); + this->MacSetClipChildren(true); #endif this->Connect(wxEVT_PAINT, wxPaintEventHandler(wxScrolled::OnPaint)); @@ -325,7 +349,7 @@ public: #ifdef __WXMSW__ virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam) { - return FilterMSWWindowProc(T::MSWWindowProc(nMsg, wParam, lParam)); + return FilterMSWWindowProc(nMsg, T::MSWWindowProc(nMsg, wParam, lParam)); } #endif // __WXMSW__ @@ -348,7 +372,11 @@ private: event.Skip(); } + // VC++ 6 gives warning for the declaration of template member function + // without definition +#if !defined(__VISUALC__) || wxCHECK_VISUALC_VERSION(7) DECLARE_NO_COPY_CLASS(wxScrolled) +#endif }; // VC++ <= 6 requires this; it's unlikely any other specializations would