X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ee22a3a2a62bb37d7f3a8c3cbcbce0f8f1fbcf67..ae8eee38f480032f4d1b756419f0d70b5f05f156:/include/wx/msw/calctrl.h diff --git a/include/wx/msw/calctrl.h b/include/wx/msw/calctrl.h index abf0e4fc0b..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,14 +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) };