PyGTK - Classe de calendrier
Le widget Calendrier de la boîte à outils PyGTK affiche un calendrier simple avec une vue mensuelle à la fois. Les commandes de navigation pour changer le mois et l'année sont affichées par défaut. Les options d'affichage peuvent être configurées de manière appropriée.
La valeur de la propriété du mois est comprise entre 0 et 11, et celle de la propriété de la date est comprise entre 1 et 31.
Il existe un constructeur simple pour créer un objet gtk.Calendar -
cal = gtk.Calendar()
Le style d'affichage par défaut indique le mois et l'année en cours ainsi que les noms des jours.
La classe gtk.Calendar a les méthodes suivantes -
Calendar.select_month (mm, yy) - Ceci modifie l'affichage du calendrier en mm et yy.
Calendar.select_day (dd) - Ceci sélectionne le dd sur le calendrier lorsqu'il a une valeur comprise entre 1 et 31. Si dd vaut 0, alors la sélection du jour en cours est supprimée.
Calendar.display_options () - Ceci définit les options d'affichage du calendrier sur la valeur spécifiée par flags. Les options d'affichage possibles sont une combinaison de:
gtk.CALENDAR_SHOW_HEADING | Spécifie que le mois et l'année doivent être affichés. |
gtk.CALENDAR_SHOW_DAY_NAMES | Spécifie que des descriptions de jours de trois lettres doivent être présentes. |
gtk.CALENDAR_NO_MONTH_CHANGE | Empêche l'utilisateur de changer de mois avec le calendrier. |
gtk.CALENDAR_SHOW_WEEK_NUMBERS | Affiche les numéros de chaque semaine de l'année en cours, sur le côté gauche du calendrier. |
gtk.CALENDAR_WEEK_START_MONDAY | Démarre la semaine du calendrier le lundi au lieu du dimanche par défaut. |
Calendar.
Le widget gtk.Calendar émet les signaux suivants -
jour sélectionné | Ceci est émis lorsqu'un jour est sélectionné par l'utilisateur ou par programme. |
mois changé | Ceci est émis lorsque le mois calendaire est modifié par programme ou par l'utilisateur. |
le mois prochain | Ceci est émis lorsque l'utilisateur clique sur le contrôle de navigation "le mois suivant" dans l'en-tête du calendrier. |
l'année prochaine | Ceci est émis lorsque l'utilisateur clique sur le contrôle de navigation "année suivante" dans l'en-tête du calendrier. |
mois précédent | Ceci est émis lorsque l'utilisateur clique sur le contrôle de navigation "mois précédent" dans l'en-tête du calendrier. |
année précédente | Ceci est émis lorsque l'utilisateur clique sur le contrôle de navigation "année précédente" dans l'en-tête du calendrier. |
Dans l'exemple suivant, un contrôle gtk.Calendar et quatre boutons sont placés dans la fenêtre de niveau supérieur.
Lorsque vous cliquez sur le bouton «En-tête», les options d'affichage du calendrier sont définies sur SHOW_HEADING -
def heading(self, widget):
self.cal.set_display_options(gtk.CALENDAR_SHOW_HEADING)
Lorsque l'utilisateur clique sur le bouton 'nom du jour', le rappel définit les options d'affichage sur SHOW_DAY_NAMES -
def dayname(self, widget):
self.cal.set_display_options(gtk.CALENDAR_SHOW_DAY_NAMES)
Les deux options d'affichage sont activées lorsque vous appuyez sur le bouton «les deux». Pour commencer, tous les indicateurs d'options d'affichage sont supprimés en le définissant sur 0.
self.cal.set_display_options(0)
Le bouton «définir» fait apparaître une boîte de message affichant la date actuellement marquée.
tp = self.cal.get_date()
str1 = str(tp[0])
str2 = str(tp[1]+1)
str3 = str(tp[2])
label = gtk.Label("Date selected:"+str3+"-"+str2+"-"+str1)
dialog.vbox.add(label)
label.show()
Exemple
Respectez le code suivant -
import gtk
class PyApp(gtk.Window):
def __init__(self):
super(PyApp, self).__init__()
self.set_title("Calendar Demo")
self.set_size_request(300, 200)
self.set_position(gtk.WIN_POS_CENTER)
vbox = gtk.VBox(False, 5)
self.cal = gtk.Calendar()
halign1 = gtk.Alignment(0.5, 0.5, 0, 0)
halign1.add(self.cal)
self.cal.set_display_options(0)
valign = gtk.Alignment(0, 1, 0, 0)
vbox.pack_start(halign1)
self.btn1 = gtk.Button("set")
self.btn2 = gtk.Button("heading")
self.btn3 = gtk.Button("day name")
self.btn4 = gtk.Button("Both")
hbox = gtk.HBox(True, 3)
hbox.add(self.btn1)
hbox.add(self.btn2)
hbox.add(self.btn3)
hbox.add(self.btn4)
halign = gtk.Alignment(0.5, 0.5, 0, 0)
halign.add(hbox)
vbox.pack_start(halign, False, True, 10)
self.add(vbox)
self.btn1.connect("clicked", self.selectdate)
self.btn2.connect("clicked", self.heading)
self.btn3.connect("clicked", self.dayname)
self.btn4.connect("clicked", self.bothflags)
self.connect("destroy", gtk.main_quit)
self.show_all()
def heading(self, widget):
self.cal.set_display_options(gtk.CALENDAR_SHOW_HEADING)
def dayname(self, widget):
self.cal.set_display_options(gtk.CALENDAR_SHOW_DAY_NAMES)
def bothflags(self, widget):
self.cal.set_display_options(gtk.CALENDAR_SHOW_HEADING|gtk.CALENDAR_SHOW_DAY_NAMES)
def selectdate(self, widget):
tp = self.cal.get_date()
dialog = gtk.Dialog("My dialog",
self,
gtk.DIALOG_MODAL | gtk.DIALOG_DESTROY_WITH_PARENT,
(gtk.STOCK_OK, gtk.RESPONSE_ACCEPT))
str1 = str(tp[0])
str2 = str(tp[1]+1)
str3 = str(tp[2])
label = gtk.Label("Date selected:"+str3+"-"+str2+"-"+str1)
dialog.vbox.add(label)
label.show()
res = dialog.run()
dialog.destroy()
PyApp()
gtk.main()
Le code ci-dessus générera la sortie suivante -