X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/30954328be6e8261886c60cf509cbf303fd279bf..445365141a2b028acbd779aa352bf664d930cfb5:/include/wx/gtk/scrolwin.h diff --git a/include/wx/gtk/scrolwin.h b/include/wx/gtk/scrolwin.h index f28f92c8d3..4cc8040a11 100644 --- a/include/wx/gtk/scrolwin.h +++ b/include/wx/gtk/scrolwin.h @@ -26,7 +26,9 @@ WXDLLEXPORT_DATA(extern const wxChar*) wxPanelNameStr; // default scrolled window style +#ifndef wxScrolledWindowStyle #define wxScrolledWindowStyle (wxHSCROLL | wxVSCROLL) +#endif // ---------------------------------------------------------------------------- // wxScrolledWindow @@ -35,18 +37,18 @@ WXDLLEXPORT_DATA(extern const wxChar*) wxPanelNameStr; class WXDLLEXPORT wxScrolledWindow : public wxPanel { public: - wxScrolledWindow(); + wxScrolledWindow() + { Init(); } + wxScrolledWindow(wxWindow *parent, wxWindowID id = -1, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = wxScrolledWindowStyle, const wxString& name = wxPanelNameStr) - { - Create(parent, id, pos, size, style, name); - } + { Create(parent, id, pos, size, style, name); } - ~wxScrolledWindow(); + void Init(); bool Create(wxWindow *parent, wxWindowID id, @@ -60,7 +62,7 @@ public: // window (e.g. a child of it in order to scroll only a portion // the area between the scrollbars (spreadsheet: only cell area // will move). - virtual void SetTargetWindow( wxWindow *target ); + virtual void SetTargetWindow( wxWindow *target, bool pushEventHandler = FALSE ); virtual wxWindow *GetTargetWindow(); // Number of pixels per user unit (0 or -1 for no scrollbar) @@ -108,14 +110,30 @@ public: // Adjust the scrollbars virtual void AdjustScrollbars(); - + + // Set the scale factor, used in PrepareDC + void SetScale(double xs, double ys) { m_scaleX = xs; m_scaleY = ys; } + double GetScaleX() const { return m_scaleX; } + double GetScaleY() const { return m_scaleY; } + // implementation from now on + void OnScroll(wxScrollWinEvent& event); void OnSize(wxSizeEvent& event); void OnPaint(wxPaintEvent& event); void OnChar(wxKeyEvent& event); - + void GtkVScroll( float value ); void GtkHScroll( float value ); + void GtkVConnectEvent(); + void GtkHConnectEvent(); + void GtkVDisconnectEvent(); + void GtkHDisconnectEvent(); + + // Calculate scroll increment + virtual int CalcScrollInc(wxScrollWinEvent& event); + + // Overridden from wxWindows due callback being static + virtual void SetScrollPos( int orient, int pos, bool refresh = TRUE ); protected: wxWindow *m_targetWindow; @@ -130,6 +148,8 @@ protected: int m_xScrollLinesPerPage; int m_yScrollLinesPerPage; + double m_scaleY,m_scaleX; + private: DECLARE_EVENT_TABLE() DECLARE_ABSTRACT_CLASS(wxScrolledWindow)