X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/299647acac7960652aadb008775429c1f8ea9b8d..6a6e2822455ac3275dad20d5a0b474e4eb4b2582:/wxPython/demo/CalendarCtrl.py diff --git a/wxPython/demo/CalendarCtrl.py b/wxPython/demo/CalendarCtrl.py index 03fc569b4d..ee5586608b 100644 --- a/wxPython/demo/CalendarCtrl.py +++ b/wxPython/demo/CalendarCtrl.py @@ -1,10 +1,6 @@ -# 11/15/2003 - Jeff Grimmett (grimmtooth@softhome.net) -# -# o Updated for wx namespace -# import wx -import wx.lib.calendar as calendar +import wx.calendar #---------------------------------------------------------------------- @@ -13,36 +9,45 @@ class TestPanel(wx.Panel): wx.Panel.__init__(self, parent, ID) self.log = log - cal = calendar.CalendarCtrl(self, -1, wx.DateTime_Now(), pos = (25,50), - style = calendar.CAL_SHOW_HOLIDAYS - | calendar.CAL_SUNDAY_FIRST - | calendar.CAL_SEQUENTIAL_MONTH_SELECTION + cal = wx.calendar.CalendarCtrl(self, -1, wx.DateTime_Now(), pos = (25,50), + style = wx.calendar.CAL_SHOW_HOLIDAYS + | wx.calendar.CAL_SUNDAY_FIRST + | wx.calendar.CAL_SEQUENTIAL_MONTH_SELECTION ) - - self.Bind(calendar.EVT_CALENDAR, self.OnCalSelected, id=cal.GetId()) - - b = wx.Button(self, -1, "Destroy the Calendar", pos = (250, 50)) - self.Bind(wx.EVT_BUTTON, self.OnButton, id= b.GetId()) self.cal = cal + self.Bind(wx.calendar.EVT_CALENDAR, self.OnCalSelected, id=cal.GetId()) # Set up control to display a set of holidays: - self.Bind(calendar.EVT_CALENDAR_MONTH, self.OnChangeMonth, id=cal.GetId()) + self.Bind(wx.calendar.EVT_CALENDAR_MONTH, self.OnChangeMonth, cal) self.holidays = [(1,1), (10,31), (12,25) ] # (these don't move around) self.OnChangeMonth() - def OnButton(self, evt): - self.cal.Destroy() - self.cal = None + cal2 = wx.calendar.CalendarCtrl(self, -1, wx.DateTime_Now(), pos = (325,50)) + self.Bind(wx.calendar.EVT_CALENDAR_SEL_CHANGED, + self.OnCalSelChanged, cal2) def OnCalSelected(self, evt): self.log.write('OnCalSelected: %s\n' % evt.GetDate()) def OnChangeMonth(self, evt=None): cur_month = self.cal.GetDate().GetMonth() + 1 # convert wxDateTime 0-11 => 1-12 - for month, day in self.holidays: if month == cur_month: self.cal.SetHoliday(day) + if cur_month == 8: + attr = wx.calendar.CalendarDateAttr(border=wx.calendar.CAL_BORDER_SQUARE, + colBorder="blue") + self.cal.SetAttr(14, attr) + else: + self.cal.ResetAttr(14) + + def OnCalSelChanged(self, evt): + cal = evt.GetEventObject() + self.log.write("OnCalSelChanged:\n\t%s: %s\n\t%s: %s\n\t%s: %s\n\t" % + ("EventObject", cal, + "Date ", cal.GetDate(), + "Ticks ", cal.GetDate().GetTicks(), + )) #---------------------------------------------------------------------- @@ -55,7 +60,7 @@ def runTest(frame, nb, log): overview = """\ -

wxCalendarCtrl

+

CalendarCtrl

Yet another calendar control. This one is a wrapper around the C++ version described in the docs. This one will probably be a bit more efficient @@ -64,10 +69,8 @@ so I think both will stay in wxPython. """ - - if __name__ == '__main__': import sys,os import run - run.main(['', os.path.basename(sys.argv[0])]) + run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])