PyGTK - Classe de presse-papiers
Un objet Clipboard contient des données partagées entre deux processus ou deux widgets de la même application. Le gtk.Clipboard est une interface de haut niveau pour la classe gtk.SelectionData.
Ce qui suit est un prototype du constructeur gtk.Clipboard -
gtk.Clipboard(display,selction)
Ici, le paramètre d'affichage correspond à l'objet gtk.gdk.Display pour lequel le presse-papiers doit être créé ou récupéré. Par défaut, il s'agit du périphérique de sortie standard. Le paramètre de sélection est défini par défaut sur CLIPBOARD, un objet représentant une chaîne internée.
PyGTK fournit une fonction pratique pour créer un objet de presse-papiers avec des valeurs par défaut.
gtk.clipboard.get()
La classe gtk.Clipboard a les méthodes suivantes -
Clipboard.store () - Cela stocke les données actuelles du presse-papiers quelque part afin qu'elles restent là même après la fermeture de l'application.
Clipboard.clear () - Cela supprime le contenu du presse-papiers.
Clipboard.set_text (text) - Ceci définit le contenu du presse-papiers sur la chaîne.
Clipboard.request_text () - Cela demande le contenu du presse-papiers sous forme de texte. Lorsque le texte est reçu ultérieurement,callback sera appelé avec les données spécifiées par user_data. La signature decallback est:
def callback (presse-papiers, texte, données) - le texte contiendra le text récupéré du presse-papiers.
À titre de démonstration du presse-papiers, le code suivant utilise deux TextViews et deux boutons sur un gtk.Window de niveau supérieur. Le bouton 'Set' appelle leon_set() fonction qui place le texte du premier textView dans le presse-papiers.
buf = self.tv1.get_buffer()
text = buf.get_text(buf.get_start_iter(), buf.get_end_iter())
self.clipboard = gtk.clipboard_get()
self.clipboard.set_text(text)
self.clipboard.store()
Lorsque le deuxième bouton ('récupéré') est enfoncé, les données du presse-papiers sont récupérées par la méthode request_text () -
self.clipboard.request_text(self.readclipboard, user_data = None)
Le contenu de user_data va à une méthode de rappel readclipboard() qui l'affiche sur la deuxième vue de texte.
def readclipboard(self, clipboard, text, data):
buffer = gtk.TextBuffer()
buffer.set_text(text)
self.tv2.set_buffer(buffer)
Exemple
Ce qui suit est le code complet pour le fonctionnement du presse-papiers -
import gtk
class PyApp(gtk.Window):
def __init__(self):
super(PyApp, self).__init__()
self.set_title("Clipboard demo")
self.set_size_request(300,200)
self.set_position(gtk.WIN_POS_CENTER)
vbox = gtk.VBox(False, 5)
self.tv1 = gtk.TextView()
vbox.add(self.tv1)
self.tv2 = gtk.TextView()
vbox.add(self.tv2)
hbox = gtk.HBox(True, 3)
Set = gtk.Button("set")
Set.set_size_request(70, 30)
retrieve = gtk.Button("retrieve")
hbox.add(Set)
hbox.add(retrieve)
halign = gtk.Alignment(1, 0, 0, 0)
halign.add(hbox)
vbox.pack_start(halign, False, False, 3)
self.add(vbox)
Set.connect("clicked", self.on_set)
retrieve.connect("clicked", self.on_retrieve)
self.connect("destroy", gtk.main_quit)
self.show_all()
def on_set(self, widget):
buf = self.tv1.get_buffer()
text = buf.get_text(buf.get_start_iter(), buf.get_end_iter())
self.clipboard = gtk.clipboard_get()
self.clipboard.set_text(text)
self.clipboard.store()
def on_retrieve(self, widget):
self.clipboard.request_text(self.readclipboard, user_data=None)
def readclipboard(self, clipboard, text, data):
buffer = gtk.TextBuffer()
buffer.set_text(text)
self.tv2.set_buffer(buffer)
PyApp()
gtk.main()
Le code ci-dessus générera la sortie suivante -