PyGTK - Classe de barre de défilement
Cette classe est une classe de base abstraite pour les widgets gtk.Hscrollbar et gtk.Vscrollbar. Les deux sont associés à un objet Adjustment. La position du pouce de la barre de défilement est contrôlée par des réglages de défilement. Les attributs de l'objet de réglage sont utilisés comme suit -
inférieur | La valeur minimale de la région de défilement |
plus haut | La valeur maximale de la région de défilement |
valeur | Représente la position de la barre de défilement, qui doit être entre inférieure et supérieure |
taille de la page | Représente la taille de la zone de défilement visible |
step_increment | Distance à parcourir lorsque les petites flèches pas à pas sont cliquées |
page_increment | Distance à parcourir lorsque le Page Up ou Page Down touches enfoncées |
Le programme suivant montre un HScale et un widget HScrollbar placés dans une VBox ajoutée à la fenêtre de niveau supérieur. Chacun d'eux est associé à un objet de réglage.
adj1 = gtk.Adjustment(0, 0, 101, 0.1, 1, 1)
self.adj2 = gtk.Adjustment(10,0,101,5,1,1)
Un widget gtk.HScale est un contrôle de curseur associé à adj1. Sa politique de mise à jour, le nombre et la position de la valeur du dessin sont définis comme suit -
scale1 = gtk.HScale(adj1)
scale1.set_update_policy(gtk.UPDATE_CONTINUOUS)
scale1.set_digits(1)
scale1.set_value_pos(gtk.POS_TOP)
scale1.set_draw_value(True)
gtk.HScrollbar fournit une barre de défilement horizontale. Il est associé à l'objet adj2. Sa politique de mise à jour est également définie sur CONTINU.
self.bar1 = gtk.HScrollbar(self.adj2)
self.bar1.set_update_policy(gtk.UPDATE_CONTINUOUS)
Afin d'afficher la valeur instantanée de la barre de défilement, le signal `` valeur modifiée '' de the adjustment object — adj2 est connecté à la fonction de rappel on_scrolled(). La fonction récupère la propriété value de l'objet de réglage et l'affiche sur une étiquette sous la barre de défilement.
self.adj2.connect("value_changed", self.on_scrolled)
def on_scrolled(self, widget, data = None):
self.lbl2.set_text("HScrollbar value: "+str(int(self.adj2.value)))
Exemple
Respectez le code suivant -
import gtk
class PyApp(gtk.Window):
def __init__(self):
super(PyApp, self).__init__()
self.set_title("Range widgets Demo")
self.set_default_size(250, 200)
self.set_position(gtk.WIN_POS_CENTER)
adj1 = gtk.Adjustment(0.0, 0.0, 101.0, 0.1, 1.0, 1.0)
self.adj2 = gtk.Adjustment(10,0,101,5,1,1)
scale1 = gtk.HScale(adj1)
scale1.set_update_policy(gtk.UPDATE_CONTINUOUS)
scale1.set_digits(1)
scale1.set_value_pos(gtk.POS_TOP)
scale1.set_draw_value(True)
vb = gtk.VBox()
vb.add(scale1)
lbl1 = gtk.Label("HScale")
vb.add(lbl1)
self.bar1 = gtk.HScrollbar(self.adj2)
self.bar1.set_update_policy(gtk.UPDATE_CONTINUOUS)
vb.add(self.bar1)
self.lbl2 = gtk.Label("HScrollbar value: ")
vb.add(self.lbl2)
self.adj2.connect("value_changed", self.on_scrolled)
self.add(vb)
self.connect("destroy", gtk.main_quit)
self.show_all()
def on_scrolled(self, widget, data=None):
self.lbl2.set_text("HScrollbar value: "+str(int(self.adj2.value)))
if __name__ == '__main__':
PyApp()
gtk.main()
Le code ci-dessus générera la sortie suivante -