PyGTK - การจัดการเหตุการณ์
นอกจากกลไกของสัญญาณแล้วเหตุการณ์ของระบบหน้าต่างยังสามารถเชื่อมต่อกับฟังก์ชันโทรกลับได้อีกด้วย การปรับขนาดหน้าต่างการกดปุ่มเหตุการณ์การเลื่อน ฯลฯ เป็นเหตุการณ์ของระบบหน้าต่างทั่วไป เหตุการณ์เหล่านี้รายงานไปยังลูปหลักของแอปพลิเคชัน จากนั้นระบบจะส่งผ่านสัญญาณไปยังฟังก์ชันเรียกกลับ
เหตุการณ์ของระบบบางส่วนมีการระบุไว้ด้านล่าง -
- button_press_event
- button_release_event
- scroll_event
- motion_notify_event
- delete_event
- destroy_event
- expose_event
- key_press_event
- key_release_event
วิธีการเชื่อมต่อ () ใช้เพื่อเชื่อมโยงเหตุการณ์กับฟังก์ชันเรียกกลับตามไวยากรณ์ -
Object.connect(name, function, data)
ในที่นี้ name ย่อมาจากสตริงที่ตรงกับชื่อของเหตุการณ์ที่จะบันทึก และ,function เป็นชื่อของไฟล์ callbackฟังก์ชันที่จะเรียกใช้เมื่อมีเหตุการณ์เกิดขึ้น ข้อมูลคืออาร์กิวเมนต์ที่จะส่งต่อไปยังฟังก์ชันเรียกกลับ
ดังนั้นรหัสต่อไปนี้จะเชื่อมต่อวิดเจ็ตปุ่มและบันทึกเหตุการณ์ button_press -
self.btn.connect("button_press_event", self.hello)
ต่อไปนี้จะเป็นฟังก์ชัน Prototype of hello () -
def hello(self,widget,event):
ตัวอย่าง
ต่อไปนี้เป็นรหัสสำหรับตัวจัดการเหตุการณ์ปุ่ม -
import gtk
class PyApp(gtk.Window):
def __init__(self):
super(PyApp, self).__init__()
self.set_title("Hello World in PyGTK")
self.set_default_size(400,300)
self.set_position(gtk.WIN_POS_CENTER)
self.label = gtk.Label("Enter name")
self.entry = gtk.Entry()
self.btn = gtk.Button("Say Hello")
self.btn.connect("button_press_event", self.hello)
fixed = gtk.Fixed()
fixed.put(self.label, 100,100)
fixed.put(self.entry, 100,125)
fixed.put(self.btn,100,150)
self.add(fixed)
self.show_all()
def hello(self,widget,event):
print "hello",self.entry.get_text()
PyApp()
gtk.main()
เมื่อคุณรันโค้ดด้านบนจะแสดงผลลัพธ์ต่อไปนี้บนคอนโซล -
Hello TutorialsPoint