]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/msw/calctrl.h
eliminate the hysteresis when scrollbars didn't disappear when the window was resized...
[wxWidgets.git] / include / wx / msw / calctrl.h
index 50df43095ed358c7a505943db926df0de4b40804..d27875cf06b280d57ef4a9178bc48df9fd253267 100644 (file)
@@ -45,6 +45,7 @@ public:
     virtual bool EnableMonthChange(bool enable = true);
 
     virtual void Mark(size_t day, bool mark);
     virtual bool EnableMonthChange(bool enable = true);
 
     virtual void Mark(size_t day, bool mark);
+    virtual void SetHoliday(size_t day);
 
     virtual wxCalendarHitTestResult HitTest(const wxPoint& pos,
                                             wxDateTime *date = NULL,
 
     virtual wxCalendarHitTestResult HitTest(const wxPoint& pos,
                                             wxDateTime *date = NULL,
@@ -53,7 +54,7 @@ public:
     virtual void SetWindowStyleFlag(long style);
 
 protected:
     virtual void SetWindowStyleFlag(long style);
 
 protected:
-    virtual wxSize wxCalendarCtrl::DoGetBestSize() const;
+    virtual wxSize DoGetBestSize() const;
 
     virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
 
 
     virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
 
@@ -63,7 +64,7 @@ protected:
     void MSWOnDoubleClick(wxMouseEvent& event);
 
 private:
     void MSWOnDoubleClick(wxMouseEvent& event);
 
 private:
-    void Init() { m_marks = 0; }
+    void Init();
 
     // bring the control in sync with m_marks
     void UpdateMarks();
 
     // bring the control in sync with m_marks
     void UpdateMarks();
@@ -72,6 +73,12 @@ private:
     // wxCAL_MONDAY_FIRST flag
     void UpdateFirstDayOfWeek();
 
     // wxCAL_MONDAY_FIRST flag
     void UpdateFirstDayOfWeek();
 
+    // reset holiday information
+    virtual void ResetHolidayAttrs() { m_holidays = 0; }
+
+    // redisplay holidays
+    virtual void RefreshHolidays() { UpdateMarks(); }
+
 
     // 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
 
     // 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
@@ -81,6 +88,9 @@ private:
     // bit field containing the state (marked or not) of all days in the month
     wxUint32 m_marks;
 
     // bit field containing the state (marked or not) of all days in the month
     wxUint32 m_marks;
 
+    // the same but indicating whether a day is a holiday or not
+    wxUint32 m_holidays;
+
 
     DECLARE_DYNAMIC_CLASS(wxCalendarCtrl)
     DECLARE_NO_COPY_CLASS(wxCalendarCtrl)
 
     DECLARE_DYNAMIC_CLASS(wxCalendarCtrl)
     DECLARE_NO_COPY_CLASS(wxCalendarCtrl)