X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d3a809c7dccc2f72da17fbf52f10cfb27e0ee8f0..d6f0a4b367c6d68d9fea84817f5a982163665f37:/include/wx/generic/plot.h diff --git a/include/wx/generic/plot.h b/include/wx/generic/plot.h index 386117cfa8..7d36701c35 100644 --- a/include/wx/generic/plot.h +++ b/include/wx/generic/plot.h @@ -16,15 +16,66 @@ #pragma interface "plot.h" #endif +#include "wx/defs.h" + +#if wxUSE_PLOT + #include "wx/scrolwin.h" +#include "wx/event.h" //----------------------------------------------------------------------------- // classes //----------------------------------------------------------------------------- -class wxPlotCurve; -class wxPlotArea; -class wxPlotWindow; +class WXDLLEXPORT wxPlotEvent; +class WXDLLEXPORT wxPlotCurve; +class WXDLLEXPORT wxPlotArea; +class WXDLLEXPORT wxPlotXAxisArea; +class WXDLLEXPORT wxPlotYAxisArea; +class WXDLLEXPORT wxPlotWindow; + +//----------------------------------------------------------------------------- +// consts +//----------------------------------------------------------------------------- + +#define wxPLOT_X_AXIS 0x0004 +#define wxPLOT_Y_AXIS 0x0008 +#define wxPLOT_BUTTON_MOVE 0x0010 +#define wxPLOT_BUTTON_ZOOM 0x0020 +#define wxPLOT_BUTTON_ENLARGE 0x0040 + +#define wxPLOT_BUTTON_ALL (wxPLOT_BUTTON_MOVE|wxPLOT_BUTTON_ZOOM|wxPLOT_BUTTON_ENLARGE) +#define wxPLOT_DEFAULT (wxPLOT_X_AXIS|wxPLOT_Y_AXIS | wxPLOT_BUTTON_ALL) + +//----------------------------------------------------------------------------- +// wxPlotEvent +//----------------------------------------------------------------------------- + +class WXDLLEXPORT wxPlotEvent: public wxNotifyEvent +{ +public: + wxPlotEvent( wxEventType commandType = wxEVT_NULL, int id = 0 ); + + wxPlotCurve *GetCurve() + { return m_curve; } + void SetCurve( wxPlotCurve *curve ) + { m_curve = curve; } + + double GetZoom() + { return m_zoom; } + void SetZoom( double zoom ) + { m_zoom = zoom; } + + wxInt32 GetPosition() + { return m_position; } + void SetPosition( wxInt32 pos ) + { m_position = pos; } + +private: + wxPlotCurve *m_curve; + double m_zoom; + wxInt32 m_position; +}; //----------------------------------------------------------------------------- // wxPlotCurve @@ -34,7 +85,7 @@ class WXDLLEXPORT wxPlotCurve: public wxObject { public: wxPlotCurve( int offsetY, double startY, double endY ); - + virtual wxInt32 GetStartX() = 0; virtual wxInt32 GetEndX() = 0; @@ -52,7 +103,7 @@ public: { m_offsetY = offsetY; } int GetOffsetY() { return m_offsetY; } - + private: int m_offsetY; double m_startY; @@ -70,20 +121,63 @@ class WXDLLEXPORT wxPlotArea: public wxWindow public: wxPlotArea() {} wxPlotArea( wxPlotWindow *parent ); - + void OnPaint( wxPaintEvent &event ); void OnMouse( wxMouseEvent &event ); void DrawCurve( wxDC *dc, wxPlotCurve *curve, int from = -1, int to = -1 ); void DeleteCurve( wxPlotCurve *curve, int from = -1, int to = -1 ); - + + virtual void ScrollWindow( int dx, int dy, const wxRect *rect ); + private: - wxPlotWindow *m_owner; + wxPlotWindow *m_owner; + bool m_zooming; DECLARE_CLASS(wxPlotArea) DECLARE_EVENT_TABLE() }; +//----------------------------------------------------------------------------- +// wxPlotXAxisArea +//----------------------------------------------------------------------------- + +class WXDLLEXPORT wxPlotXAxisArea: public wxWindow +{ +public: + wxPlotXAxisArea() {} + wxPlotXAxisArea( wxPlotWindow *parent ); + + void OnPaint( wxPaintEvent &event ); + void OnMouse( wxMouseEvent &event ); + +private: + wxPlotWindow *m_owner; + + DECLARE_CLASS(wxPlotXAxisArea) + DECLARE_EVENT_TABLE() +}; + +//----------------------------------------------------------------------------- +// wxPlotYAxisArea +//----------------------------------------------------------------------------- + +class WXDLLEXPORT wxPlotYAxisArea: public wxWindow +{ +public: + wxPlotYAxisArea() {} + wxPlotYAxisArea( wxPlotWindow *parent ); + + void OnPaint( wxPaintEvent &event ); + void OnMouse( wxMouseEvent &event ); + +private: + wxPlotWindow *m_owner; + + DECLARE_CLASS(wxPlotYAxisArea) + DECLARE_EVENT_TABLE() +}; + //----------------------------------------------------------------------------- // wxPlotWindow //----------------------------------------------------------------------------- @@ -92,41 +186,121 @@ class WXDLLEXPORT wxPlotWindow: public wxScrolledWindow { public: wxPlotWindow() {} - wxPlotWindow( wxWindow *parent, wxWindowID id, const wxPoint &pos, const wxSize &size, int flags ); + wxPlotWindow( wxWindow *parent, wxWindowID id, const wxPoint &pos, const wxSize &size, int flags = wxPLOT_DEFAULT ); ~wxPlotWindow(); - + + // curve accessors + // --------------- + void Add( wxPlotCurve *curve ); size_t GetCount(); wxPlotCurve *GetAt( size_t n ); void SetCurrent( wxPlotCurve* current ); wxPlotCurve *GetCurrent(); - + + void Delete( wxPlotCurve* curve ); + + // vertical representation + // ----------------------- + void Move( wxPlotCurve* curve, int pixels_up ); void Enlarge( wxPlotCurve *curve, double factor ); + // horizontal representation + // ------------------------- + + void SetUnitsPerValue( double upv ); + double GetUnitsPerValue() + { return m_xUnitsPerValue; } + + void SetZoom( double zoom ); + double GetZoom() + { return m_xZoom; } + + // options + // ------- + + void SetScrollOnThumbRelease( bool scrollOnThumbRelease = TRUE ) + { m_scrollOnThumbRelease = scrollOnThumbRelease; } + bool GetScrollOnThumbRelease() + { return m_scrollOnThumbRelease; } + + void SetEnlargeAroundWindowCentre( bool enlargeAroundWindowCentre = TRUE ) + { m_enlargeAroundWindowCentre = enlargeAroundWindowCentre; } + bool GetEnlargeAroundWindowCentre() + { return m_enlargeAroundWindowCentre; } + + // events (may be overridden) + // -------------------------- + void OnMoveUp( wxCommandEvent& event ); void OnMoveDown( wxCommandEvent& event ); - - void OnEnlarge100( wxCommandEvent& event ); - void OnEnlarge50( wxCommandEvent& event ); - void OnShrink50( wxCommandEvent& event ); - void OnShrink33( wxCommandEvent& event ); - - void OnPaint( wxPaintEvent &event ); + void OnEnlarge( wxCommandEvent& event ); + void OnShrink( wxCommandEvent& event ); + void OnZoomIn( wxCommandEvent& event ); + void OnZoomOut( wxCommandEvent& event ); + + void OnScroll2( wxScrollWinEvent& event ); + + // utilities + // --------- + + void RedrawEverything(); + void RedrawXAxis(); void RedrawYAxis(); - + + void ResetScrollbar(); + private: friend wxPlotArea; - - wxList m_curves; - wxPlotArea *m_area; - wxPlotCurve *m_current; + friend wxPlotXAxisArea; + friend wxPlotYAxisArea; + + double m_xUnitsPerValue; + double m_xZoom; + + wxList m_curves; + wxPlotArea *m_area; + wxPlotXAxisArea *m_xaxis; + wxPlotYAxisArea *m_yaxis; + wxPlotCurve *m_current; + + bool m_scrollOnThumbRelease; + bool m_enlargeAroundWindowCentre; DECLARE_CLASS(wxPlotWindow) DECLARE_EVENT_TABLE() }; +// ---------------------------------------------------------------------------- +// calendar events macros +// ---------------------------------------------------------------------------- + +#define EVT_PLOT(id, fn) { wxEVT_PLOT_DOUBLECLICKED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_SEL_CHANGING(id, fn) { wxEVT_PLOT_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_SEL_CHANGED(id, fn) { wxEVT_PLOT_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_CLICKED(id, fn) { wxEVT_PLOT_CLICKED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_DOUBLECLICKED(id, fn) { wxEVT_PLOT_DOUBLECLICKED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_ZOOM_IN(id, fn) { wxEVT_PLOT_ZOOM_IN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_ZOOM_OUT(id, fn) { wxEVT_PLOT_ZOOM_OUT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_VALUE_SEL_CREATING(id, fn) { wxEVT_PLOT_VALUE_SEL_CREATING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_VALUE_SEL_CREATED(id, fn) { wxEVT_PLOT_VALUE_SEL_CREATED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_VALUE_SEL_CHANGING(id, fn) { wxEVT_PLOT_VALUE_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_VALUE_SEL_CHANGED(id, fn) { wxEVT_PLOT_VALUE_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_AREA_SEL_CREATING(id, fn) { wxEVT_PLOT_AREA_SEL_CREATING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_AREA_SEL_CREATED(id, fn) { wxEVT_PLOT_AREA_SEL_CREATED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_AREA_SEL_CHANGING(id, fn) { wxEVT_PLOT_AREA_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_AREA_SEL_CHANGED(id, fn) { wxEVT_PLOT_AREA_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_BEGIN_X_LABEL_EDIT(id, fn) { wxEVT_PLOT_BEGIN_X_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_END_X_LABEL_EDIT(id, fn) { wxEVT_PLOT_END_X_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_BEGIN_Y_LABEL_EDIT(id, fn) { wxEVT_PLOT_BEGIN_Y_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_END_Y_LABEL_EDIT(id, fn) { wxEVT_PLOT_END_Y_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_BEGIN_TITLE_EDIT(id, fn) { wxEVT_PLOT_BEGIN_TITLE_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, +#define EVT_PLOT_END_TITLE_EDIT(id, fn) { wxEVT_PLOT_END_TITLE_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxCommandEventFunction) & fn, (wxObject *) NULL }, + +#endif // wxUSE_PLOT + #endif // _WX_PLOT_H_