X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a4fcd589a85e735e6c17f1470e739d9fcc946e9e..09b895cb4a954494063eb17d3dc302a654fd99e5:/include/wx/msw/calctrl.h diff --git a/include/wx/msw/calctrl.h b/include/wx/msw/calctrl.h index 9a2da34dd2..1b56830df8 100644 --- a/include/wx/msw/calctrl.h +++ b/include/wx/msw/calctrl.h @@ -13,7 +13,7 @@ class WXDLLIMPEXP_ADV wxCalendarCtrl : public wxCalendarCtrlBase { public: - wxCalendarCtrl() { } + wxCalendarCtrl() { Init(); } wxCalendarCtrl(wxWindow *parent, wxWindowID id, const wxDateTime& date = wxDefaultDateTime, @@ -22,6 +22,8 @@ public: long style = wxCAL_SHOW_HOLIDAYS, const wxString& name = wxCalendarNameStr) { + Init(); + Create(parent, id, date, pos, size, style, name); } @@ -48,16 +50,38 @@ public: wxDateTime *date = NULL, wxDateTime::WeekDay *wd = NULL); + virtual void SetWindowStyleFlag(long style); + protected: - virtual wxSize wxCalendarCtrl::DoGetBestSize() const; + virtual wxSize DoGetBestSize() const; virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const; virtual bool MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result); + void MSWOnClick(wxMouseEvent& event); + void MSWOnDoubleClick(wxMouseEvent& event); + private: + void Init() { m_marks = 0; } + + // bring the control in sync with m_marks + void UpdateMarks(); + + // set first day of week in the control to correspond to our + // wxCAL_MONDAY_FIRST flag + void UpdateFirstDayOfWeek(); + + + // current date, we need to store it instead of simply retrieving it from + // the control as needed in order to be able to generate the correct events + // from MSWOnNotify() wxDateTime m_date; + // bit field containing the state (marked or not) of all days in the month + wxUint32 m_marks; + + DECLARE_DYNAMIC_CLASS(wxCalendarCtrl) DECLARE_NO_COPY_CLASS(wxCalendarCtrl) };