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 -