PyGTK - त्वरित गाइड

PyGTK, GTK + GUI लाइब्रेरी के लिए पायथन और C में लिखे रैपर का एक सेट है। यह GNOME प्रोजेक्ट का हिस्सा है। यह पायथन में डेस्कटॉप अनुप्रयोगों के निर्माण के लिए व्यापक उपकरण प्रदान करता है। अन्य लोकप्रिय जीयूआई पुस्तकालयों के लिए पायथन बाइंडिंग भी उपलब्ध हैं।

PyQtक्यूटी लाइब्रेरी का पायथन पोर्ट है। हमारा PyQt ट्यूटोरियल मिल सकता हैhere। इसी तरह, wxPython टूलकिट wxWidgets के लिए पायथन बाइंडिंग है, एक अन्य लोकप्रिय क्रॉस-प्लेटफ़ॉर्म GUI लाइब्रेरी है। हमारा wxPython ट्यूटोरियल उपलब्ध हैhere

GTK+, या GIMP टूलकिट, ग्राफिकल यूजर इंटरफेस बनाने के लिए एक मल्टी-प्लेटफॉर्म टूलकिट है। विजेट्स का एक पूरा सेट पेश करते हुए, जीटीके + एप्लिकेशन को पूरा करने के लिए छोटे वन-ऑफ टूल से लेकर प्रोजेक्ट्स के लिए उपयुक्त है।

जीटीके + को भाषाओं की एक विस्तृत श्रृंखला का समर्थन करने के लिए जमीन से डिज़ाइन किया गया है। PyGTK GTK + के लिए पायथन रैपर है।

GTK + को निम्नलिखित चार पुस्तकालयों के आसपास बनाया गया है -

  • Glib- एक निम्न-स्तरीय कोर लाइब्रेरी जो GTK + का आधार बनती है। यह सी के लिए डेटा संरचना हैंडलिंग प्रदान करता है।

  • Pango - अंतर्राष्ट्रीयकरण पर जोर देने के साथ लेआउट और पाठ के प्रतिपादन के लिए एक पुस्तकालय।

  • Cairo - कई आउटपुट डिवाइस (X विंडो सिस्टम, Win32 सहित) के समर्थन के साथ 2 डी ग्राफिक्स के लिए एक पुस्तकालय

  • ATK - स्क्रीन रीडर, मैग्निफायर और वैकल्पिक इनपुट उपकरणों जैसे एक्सेसिबिलिटी टूल प्रदान करने वाले इंटरफेस के एक पुस्तकालय के लिए।

PyGTK प्रक्रिया को आसान बनाता है और आपको पायथन प्रोग्रामिंग भाषा का उपयोग करके एक ग्राफिकल यूजर इंटरफेस के साथ प्रोग्राम बनाने में मदद करता है। अंतर्निहित GTK + लाइब्रेरी GNOME डेस्कटॉप के लिए पूर्ण-विशेषताओं वाले एप्लिकेशन विकसित करने के लिए सभी प्रकार के दृश्य तत्व और उपयोगिताओं को प्रदान करता है। PyGTK एक क्रॉस-प्लेटफॉर्म लाइब्रेरी है। यह LGPL लाइसेंस के तहत वितरित एक मुफ्त सॉफ्टवेयर है।

PyGTK को GTK + 2.x के आसपास बनाया गया है। GTK +3 के लिए एप्लिकेशन बनाने के लिए, PyGObject बाइंडिंग भी उपलब्ध हैं।

Microsoft Windows के लिए PyGTK

Microsoft Windows के लिए PyGTK की स्थापना में निम्नलिखित चरण शामिल हैं -

  • Step 1 - एक 32-बिट पायथन दुभाषिया स्थापित करें (नवीनतम पायथन 2.7 वितरण)

  • Step 2 - जीटीके + रनटाइम डाउनलोड और इंस्टॉल करें।

  • Step 3 - GTK + रनटाइम डाउनलोड और इंस्टॉल करें -https://ftp.gnome.org

  • Step 4 - यह भी अनुशंसा की जाती है कि आप निम्नलिखित URL से PyCairo और PyGobject मॉड्यूल डाउनलोड करें - https://ftp.gnome.org https://ftp.gnome.org/pub

  • Step 5- सुविधा के लिए, ऑल-इन-वन इंस्टॉलर जो सभी PyGTK निर्भरता को संभालता है वह भी उपलब्ध है। निम्न URL से विंडोज के लिए नवीनतम ऑल-इन-वन इंस्टॉलर डाउनलोड और इंस्टॉल करें -https://ftp.gnome.org/pub/GNOME

लिनक्स के लिए PyGTK

PyGTK अधिकांश लिनक्स वितरण (डेबियन, फेडोरा, उबंटू, रेडहैट आदि सहित) में शामिल है; स्रोत कोड को निम्न URL से भी डाउनलोड और संकलित किया जा सकता है

https://ftp.gnome.org/pub/GNOME/sources/pygtk/2.24/

PyGTK का उपयोग करके एक विंडो बनाना बहुत सरल है। आगे बढ़ने के लिए, हमें सबसे पहले अपने कोड में gtk मॉड्यूल आयात करना होगा।

import gtk

Gtk मॉड्यूल में gtk.Window क्लास है। इसकी वस्तु एक ऊपरी खिड़की का निर्माण करती है। हम gtk.Window से एक वर्ग प्राप्त करते हैं।

class PyApp(gtk.Window):

कंस्ट्रक्टर को परिभाषित करें और कॉल करें show_all() gtk.window वर्ग की विधि।

def __init__(self):
   super(PyApp, self).__init__()
   self.show_all()

अब हमें इस वर्ग की वस्तु की घोषणा करनी है और इसके मुख्य () विधि को कॉल करके एक इवेंट लूप शुरू करना है।

PyApp()
gtk.main()

यह अनुशंसा की जाती है कि हम एक लेबल जोड़ें “Hello World” मूल विंडो में।

label = gtk.Label("Hello World")
self.add(label)

निम्नलिखित एक पूर्ण कोड प्रदर्शित करने के लिए है “Hello World”-

import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_default_size(300,200)
      self.set_title("Hello World in PyGTK")
      label = gtk.Label("Hello World")
      self.add(label)
      self.show_all()
PyApp()
gtk.main()

उपरोक्त कोड के कार्यान्वयन से निम्नलिखित आउटपुट प्राप्त होंगे -

PyGTK मॉड्यूल में विभिन्न विजेट हैं। gtk.Object क्लास अधिकांश विजेट्स के साथ-साथ कुछ गैर-विजेट कक्षाओं के लिए बेस क्लास के रूप में कार्य करता है। PyGTK का उपयोग कर डेस्कटॉप अनुप्रयोगों के लिए सबसे अच्छी खिड़की gtk.Window वर्ग द्वारा प्रदान की गई है। निम्न तालिका महत्वपूर्ण विगेट्स और उनके कार्यों को सूचीबद्ध करती है -

S.NO कक्षाएं और विवरण
1

gtk.Widget

यह सभी PyGTK विजेट के लिए एक gtk.base क्लास है। gtk.Widget विजेट्स के लिए तरीकों और संकेतों का एक सामान्य सेट प्रदान करता है।

2

gtk.Window

यह एक छोटी खिड़की है जिसमें एक बच्चा विजेट है। gtk.Window एक शीर्षक पट्टी के साथ सजाया गया एक प्रदर्शन क्षेत्र है, और उपयोगकर्ता को विंडो को बंद करने, आकार बदलने और स्थानांतरित करने की अनुमति देने के लिए आइटम है।

3

gtk.Button

यह एक पुशबटन विजेट है जो क्लिक करने पर सिग्नल जारी करता है। gtk.Button को आमतौर पर एक टेक्स्ट लेबल के साथ पुशबटन के रूप में प्रदर्शित किया जाता है और आमतौर पर कॉलबैक फ़ंक्शन को जोड़ने के लिए उपयोग किया जाता है।

4

gtk.Entry

यह एक सिंगल लाइन टेक्स्ट एंट्री विजेट है।

5

gtk.Label

यह विजेट केवल-पढ़ने के लिए सीमित मात्रा में पाठ प्रदर्शित करता है।

6

gtk.ButtonBox

यह विजेट के लिए एक आधार वर्ग है जिसमें कई बटन होते हैं।

7

gtk.HBox

यह एक कंटेनर है जो अपने बच्चे के विगेट्स को एक क्षैतिज पंक्ति में व्यवस्थित करता है।

8

gtk.VBox

यह एक कंटेनर है जो अपने बच्चे के विगेट्स को एक एकल कॉलम में व्यवस्थित करता है।

9

gtk.Fixed

यह एक कंटेनर है जो फिक्स्ड पोजिशन पर और पिक्सल्स में दिए गए निश्चित साइज के साथ चाइल्ड विजेट लगा सकता है।

10

gtk.Layout

यह बाल विगेट्स और कस्टम ड्राइंग वाले अनंत स्क्रॉल करने योग्य क्षेत्र प्रदान करता है।

1 1

gtk.MenuItem

यह विजेट मेनू आइटम की उपस्थिति और व्यवहार को लागू करता है। Gtk.MenuItem के व्युत्पन्न विजेट उपवर्ग मेनू के एकमात्र वैध बच्चे हैं। जब एक उपयोगकर्ता द्वारा चुना जाता है, तो वे एक पॉपअप मेनू प्रदर्शित कर सकते हैं या संबंधित फ़ंक्शन या विधि को लागू कर सकते हैं

12

gtk.Menu

यह एक ड्रॉपडाउन मेनू है जिसमें MenuItem ऑब्जेक्ट्स की एक सूची शामिल है जिसे एप्लिकेशन कार्यों को करने के लिए उपयोगकर्ता द्वारा नेविगेट और सक्रिय किया जा सकता है।

13

gtk.MenuBar

यह एप्लिकेशन विंडो या संवाद में क्षैतिज रूप से मेनू आइटम प्रदर्शित करता है।

14

gtk.ComboBox

इस विजेट का उपयोग वस्तुओं की सूची से चुनने के लिए किया जाता है।

15

gtk.Scale

यह एक संख्यात्मक मान का चयन करने के लिए एक क्षैतिज या ऊर्ध्वाधर स्लाइडर नियंत्रण है।

16

gtk.Scrollbar

यह एक क्षैतिज या ऊर्ध्वाधर स्क्रॉलबार प्रदर्शित करता है।

17

gtk.ProgressBar

इसका उपयोग लंबे समय तक चलने वाले ऑपरेशन की प्रगति को प्रदर्शित करने के लिए किया जाता है।

18

gtk.Dialog

यह उपयोगकर्ता की जानकारी और कार्रवाई के लिए एक पॉपअप विंडो प्रदर्शित करता है।

19

gtk.Notebook

यह विजेट एक कंटेनर है, जिसके बच्चे ओवरलैपिंग पृष्ठ हैं जिन्हें टैब लेबल का उपयोग करने के बीच स्विच किया जा सकता है।

20

gtk.Paned

यह दो पैन के साथ विजेट के लिए एक बेस क्लास है, जो क्षैतिज या लंबवत रूप से व्यवस्थित है। विजेट के पैन में बाल विजेट जोड़े जाते हैं। दो बच्चों के बीच विभाजन को उपयोगकर्ता द्वारा समायोजित किया जा सकता है।

21

gtk.TextView

यह विजेट एक TextBuffer ऑब्जेक्ट की सामग्री को प्रदर्शित करता है।

22

gtk.Toolbar

यह कंटेनर क्षैतिज या ऊर्ध्वाधर बार में बटनों और विगेट्स का एक सेट रखता है और उसका प्रबंधन करता है।

23

gtk.TreeView

यह विजेट मानक TreeModel (ListStore, TreeStore, TreeModelSort) की सामग्री को प्रदर्शित करता है

24

gtk.DrawingArea

यह विजेट कस्टम यूजर इंटरफेस तत्वों को बनाने में मदद करता है। gtk.DrawingArea अनिवार्य रूप से एक खाली विजेट है जिसमें एक खिड़की है जिसे आप खींच सकते हैं।

25

gtk.Calendar

यह विजेट एक कैलेंडर प्रदर्शित करता है और उपयोगकर्ता को एक तिथि का चयन करने की अनुमति देता है।

26

gtk.Viewport

यह विजेट एक बड़े विजेट के एक हिस्से को प्रदर्शित करता है।

Gtk.Window क्लास का एक ऑब्जेक्ट एक विजेट प्रदान करता है, जिसे यूजर्स आमतौर पर Wwindow समझते हैं। यह विजेट एक कंटेनर है इसलिए, यह एक चाइल्ड विजेट पकड़ सकता है। यह शीर्षक पट्टी और आकार नियंत्रण के साथ सजाया गया एक प्रदर्शन योग्य क्षेत्र प्रदान करता है।

gtk.Window क्लास में निम्न कंस्ट्रक्टर हैं -

gtk.Window(type)

टाइप पैरामटर निम्न में से एक मान लेता है -

gtk.WINDOW_TOPLEVEL (डिफ़ॉल्ट) इस विंडो का कोई अभिभावक नहीं है। Toplevel खिड़कियां मुख्य अनुप्रयोग विंडो और संवाद हैं।
gtk.WINDOW_POPUP इस विंडो में कोई फ्रेम या सजावट नहीं है। मेनू और टूलटिप्स के लिए एक पॉपअप विंडो का उपयोग किया जाता है।

Gtk.Window क्लास के कुछ महत्वपूर्ण तरीके नीचे सूचीबद्ध हैं -

S.NO तरीके और विवरण
1

set_title(string)

इसके द्वारा निर्दिष्ट मान के लिए gtk.window की "शीर्षक" संपत्ति सेट करता है title। एक विंडो का शीर्षक उसके शीर्षक बार में प्रदर्शित किया जाएगा।

2

get_title()

यह सेट होने पर एक विंडो का शीर्षक देता है।

3

set_position()

यह विंडो की स्थिति निर्धारित करता है। पूर्वनिर्धारित स्थिति स्थिरांक हैं -

  • gtk.WIN_POS_NONE

  • gtk.WIN_POS_CENTER

  • gtk.WIN_POS_MOUSE

  • gtk.WIN_POS_CENTER_ALWAYS

  • gtk.WIN_POS_CENTER_ON_PARENT

3

set_focus()

यह विंडो के लिए फ़ोकस विजेट होने के लिए निर्दिष्ट विजेट सेट करता है।

4

set_resizable()

यह डिफ़ॉल्ट रूप से सत्य है। set_resizable () उपयोगकर्ता को एक विंडो का आकार निर्धारित करने में मदद करता है।

5

set_decorated()

यह डिफ़ॉल्ट रूप से सत्य है। यदि गलत है, तो शीर्षक बार और विंडो के आकार बदलने वाले नियंत्रण अक्षम हो जाएंगे।

6

set_modal()

यदि सही है, तो विंडो मोडल बन जाती है और अन्य विंडो के साथ इंटरेक्शन को रोका जाता है। यह डायलॉग विजेट्स के लिए उपयोग किया जाता है।

7

set_default_size()

यह विंडो के डिफ़ॉल्ट आकार को पिक्सल में निर्दिष्ट चौड़ाई और ऊंचाई पर सेट करता है।

Gtk.Window विजेट निम्नलिखित संकेतों का उत्सर्जन करता है -

सक्रिय-डिफ़ॉल्ट यह तब उत्सर्जित होता है जब विंडो का डिफ़ॉल्ट चाइल्ड विजेट आमतौर पर रिटर्न या एंटर कुंजी दबाने वाले उपयोगकर्ता द्वारा सक्रिय किया जाता है।
सक्रिय फोकस यह तब उत्सर्जित होता है जब फ़ोकस वाला चाइल्ड विजेट आमतौर पर स्पेस कुंजी दबाने वाले उपयोगकर्ता द्वारा सक्रिय किया जाता है।
इस कदम फोकस यह तब उत्सर्जित होता है जब उपयोगकर्ता के टैब, शिफ्ट + टैब या अप, डाउन, लेफ्ट या राइट एरो कीज को दबाने पर विंडो के चाइल्ड विजेट के भीतर फोकस बदल जाता है।
ध्यान लगाएं यह तब उत्सर्जित होता है जब फोकस में परिवर्तन होता है widget में window

Gtk.Button विजेट को आमतौर पर एक टेक्स्ट लेबल के साथ एक पुशबटन के रूप में प्रदर्शित किया जाता है। यह आमतौर पर कॉलबैक फ़ंक्शन या विधि को संलग्न करने के लिए उपयोग किया जाता है जिसे बटन क्लिक करने पर कहा जाता है।

Gtk.Button वर्ग में निम्नलिखित निर्माता हैं -

gtk.Button(label = None, stock = None, use_underline = True)

जिसमें,

  • Label - बटन लेबल द्वारा प्रदर्शित किया जाने वाला पाठ

  • Stock- स्टॉक की पहचान करने के लिए स्टॉक आईडी और बटन में इस्तेमाल किया जाने वाला टेक्स्ट। डिफ़ॉल्ट कोई नहीं है।

  • Underline - यदि सही है, तो पाठ में एक अंडरस्कोर इंगित करता है कि अगले वर्ण को रेखांकित किया जाना चाहिए और इसका उपयोग मेमनोनिक त्वरक के लिए किया जाना चाहिए।

स्टॉक पैरामीटर के लिए पूर्वनिर्धारित स्थिरांक में से कुछ हैं -

  • STOCK_OK
  • STOCK_STOP
  • STOCK_YES
  • STOCK_NO
  • STOCK_QUIT
  • STOCK_CANCEL
  • STOCK_CLOSE

बटन वर्ग के निम्नलिखित महत्वपूर्ण तरीके हैं -

S.NO तरीके और विवरण
1

set_label()

यह बटन लेबल के पाठ को लेबल पर सेट करता है। इस स्ट्रिंग का उपयोग स्टॉक आइटम का चयन करने के लिए भी किया जाता है यदि "use_stock" गुण सत्य है।

2

get_label()

यह बटन के लेबल से पाठ को पुनः प्राप्त करता है

3

set_focus_on_click()

यदि सही है, तो माउस के साथ क्लिक करने पर बटन पकड़ता है।

4

set_alignment()

यह बच्चे के विजेट का क्षैतिज और ऊर्ध्वाधर संरेखण है। मान 0.0 से 1.0 तक है।

5

set_image()

यह छवि संपत्ति को छवि के मूल्य पर सेट करता है। "Gtkbutton-images" गुण को True पर सेट किया जाना चाहिए।

निम्नलिखित संकेत बटन विजेट द्वारा उत्सर्जित होते हैं -

सक्रिय यह तब होता है जब gtk.Widget का उपयोग किया जाता है activate()विधि कहा जाता है। एक बटन के लिए यह "क्लिक" संकेत उत्सर्जित होने का कारण बनता है।
क्लिक किए गए जब माउस बटन दबाया जाता है और पॉइंटर बटन के ऊपर या जब कीबोर्ड से बटन को ट्रिगर किया जाता है तब यह उत्सर्जित होता है।

गैर-संपादन योग्य पाठ प्रदर्शित करने के लिए एक लेबल विजेट उपयोगी है। लेबल का उपयोग कई अन्य विजेट्स द्वारा आंतरिक रूप से किया जाता है। उदाहरण के लिए, बटन में चेहरे पर पाठ दिखाने के लिए एक लेबल होता है। इसी तरह, MenuItem ऑब्जेक्ट में एक लेबल है। एक लेबल एक विंडो रहित ऑब्जेक्ट है, इसलिए यह सीधे घटनाओं को प्राप्त नहीं कर सकता है।

लेबल वर्ग का एक सरल निर्माता है -

gtk.Label(str = None)

निम्नलिखित उपयोगी विधियों का उपयोग लेबल वस्तु के साथ किया जा सकता है -

S.NO तरीके और विवरण
1

set_text()

यह नए पाठ को लेबल के रूप में सेट करता है

2

get_text()

यह लेबल से पाठ लौटाता है

3

set_use_underline()

यदि सही है, तो पाठ में एक अंडरस्कोर इंगित करता है कि अगले वर्ण का उपयोग मेम्नेनिक त्वरक कुंजी के लिए किया जाना चाहिए।

4

set_justify

यह एक दूसरे के सापेक्ष लेबल के पाठ में लाइनों के संरेखण को निर्धारित करता है।

संभावित मान हैं - gtk.JUSTIFY_LEFT, gtk.JUSTIFY_RIGHT, gtk.JUSTIFY_CENTER, और gtk.JUSTIFY_FILL।

5

Set_line_wrap()

अगर सच है, तो लाइन लपेटी जाएगी

6

set_selectable()

यदि सही है, तो लेबल का पाठ कॉपी-पेस्ट के लिए चुना जा सकता है

7

set_width_chars()

यह एक लेबल की चौड़ाई निर्धारित करता है

निम्नलिखित संकेत लेबल विजेट द्वारा उत्सर्जित होते हैं -

सक्रिय वर्तमान-लिंक यह तब उत्सर्जित होता है जब उपयोगकर्ता लेबल में एक लिंक सक्रिय करता है।
सक्रिय लिंक यह URI को सक्रिय करने के लिए उत्सर्जित होता है।
कॉपी-क्लिपबोर्ड यह तब उत्सर्जित होता है जब पाठ को क्लिपबोर्ड से कॉपी किया जाता है।

एंट्री विजेट एक सिंगल-लाइन टेक्स्ट एंट्री विजेट है। यदि दर्ज किया गया पाठ विजेट के आवंटन से अधिक लंबा है, तो विजेट स्क्रॉल करेगा ताकि कर्सर की स्थिति दिखाई दे।

इस वर्ग के set_visibility () पद्धति का उपयोग करके प्रवेश क्षेत्र को पासवर्ड मोड में परिवर्तित किया जा सकता है। दर्ज किया गया पाठ अदृश्य_चर () विधि द्वारा चुना गया चरित्र है, डिफ़ॉल्ट रूप से '*'।

प्रवेश वर्ग में निम्नलिखित निर्माता हैं -

gtk.Entry(max = 0)

यहां, वर्णों में अधिकतम लंबाई प्रवेश क्षेत्र के लिए है। पैरामीटर एक संख्यात्मक मान (0-65536) लेता है।

निम्न तालिका एक एंट्री क्लास के महत्वपूर्ण तरीकों को दिखाती है -

S.NO तरीके और विवरण
1

set_visibility(visible)

यदि गलत है, तो सामग्री को अदृश्य अदृश्य चरित्र के साथ बदलकर अस्पष्ट किया जाता है - '*'

2

set_invisible_char(char)

प्रविष्टि फ़ील्ड में डिफ़ॉल्ट '*' वर्णों को चार द्वारा प्रतिस्थापित किया जाता है

3

set_max_length(x)

यह x के मान के लिए "अधिकतम-लंबाई" गुण सेट करता है। (0-65,536)

4

set_text(str)

यह "टेक्स्ट" प्रॉपर्टी के मान को सेट करता है str। में स्ट्रिंगstr प्रविष्टि की वर्तमान सामग्री को बदल देता है।

5

get_text()

यह "पाठ" संपत्ति का मूल्य लौटाता है जो प्रविष्टि की सामग्री से युक्त एक स्ट्रिंग है।

6

set_alignment()

यह "xalign" संपत्ति के मान को सेट करता है xalign। set_alignment () एंट्री फ़ील्ड में सामग्री की क्षैतिज स्थिति को नियंत्रित करता है।

निम्नलिखित संकेत एंट्री विजेट द्वारा उत्सर्जित होते हैं -

सक्रिय यह तब उत्सर्जित होता है जब प्रविष्टि उपयोगकर्ता क्रिया द्वारा या प्रोग्रामेटिक रूप से सक्रिय की जाती है gtk.Widget.activate() तरीका।
बैकस्पेस यह उत्सर्जित होता है जब Backspace कीबोर्ड से कुंजी दर्ज की जाती है।
कॉपी-क्लिपबोर्ड यह तब उत्सर्जित होता है जब प्रविष्टि में चयन पाठ क्लिपबोर्ड पर कॉपी किया जाता है।
कट क्लिपबोर्ड यह उत्सर्जित होता है जब प्रविष्टि में चयन को काटकर क्लिपबोर्ड में रखा जाता है।
पेस्ट-क्लिपबोर्ड यह तब उत्सर्जित होता है जब क्लिपबोर्ड की सामग्री को प्रविष्टि में चिपकाया जाता है।

कंसोल मोड एप्लिकेशन के विपरीत, जिसे क्रमिक तरीके से निष्पादित किया जाता है, एक GUI- आधारित एप्लिकेशन इवेंट संचालित होता है। gtk.main()फ़ंक्शन एक अनंत लूप शुरू करता है। जीयूआई पर होने वाली घटनाओं को उचित कॉलबैक फ़ंक्शन में स्थानांतरित किया जाता है।

प्रत्येक PyGTK विजेट, जो GObject वर्ग से लिया गया है, को उत्सर्जित करने के लिए डिज़ाइन किया गया है ‘signal’एक या अधिक घटनाओं के जवाब में। अपने आप पर संकेत कोई कार्रवाई नहीं करता है। इसके बजाय, यह कॉलबैक फ़ंक्शन के लिए 'कनेक्ट' है।

कुछ सिग्नल विजेट द्वारा विरासत में मिले हैं, जबकि कुछ सिग्नल विजेट विशिष्ट हैं। उदाहरण के लिए, टॉगलबटन विजेट द्वारा "टॉगल" संकेत उत्सर्जित होता है।

एक सिग्नल हैंडलर की स्थापना करके की जाती है connect() gtk.widget वर्ग की विधि।

handler_id = object.connect(name, func, func_data)
  • पहला तर्क, name, एक स्ट्रिंग है जिसमें सिग्नल का नाम है जिसे आप पकड़ना चाहते हैं।

  • दूसरा तर्क, func, कॉल बैक फंक्शन है जिसे आप तब कहते हैं जब इसे पकड़ा जाए।

  • तीसरा तर्क, func_data, डेटा जिसे आप इस फ़ंक्शन में पास करना चाहते हैं।

  • हैंडलर आईडी, जिसे कॉलबैक विधि की विशिष्ट पहचान के लिए उपयोग किया जाता है।

उदाहरण के लिए, जब एक बटन क्लिक किया जाता है, तो onClicked () फ़ंक्शन को लागू करने के लिए, निम्नलिखित सिंटैक्स का उपयोग करें -

btn.connect("clicked",onClicked,None)

OnClicked () फ़ंक्शन के रूप में परिभाषित किया गया है -

def onClicked(widget, data=None):

यदि कॉलबैक विधि एक ऑब्जेक्ट विधि है, तो यह एक अतिरिक्त तर्क के रूप में स्वयं प्राप्त करता है -

def onClicked(self, widget, data=None):

उदाहरण

निम्नलिखित उदाहरण में, gtk.Window में एक बटन जोड़ा जाता है। बटन पर क्लिक करने पर "हैलो वर्ल्ड" संदेश प्रिंट होता है।

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("clicked",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):
      print "hello",self.entry.get_text()
PyApp()
gtk.main()

उपरोक्त कोड को पायथन प्रॉम्प्ट से चलाएं। निम्न आउटपुट प्रदर्शित किया जाएगा -

जब बटन दबाया जाता है, तो निम्न आउटपुट कंसोल पर प्रदर्शित होता है -

Hello TutorialsPoint

सिग्नल तंत्र के अलावा, विंडो सिस्टम ईवेंट्स को कॉलबैक फ़ंक्शन से भी जोड़ा जा सकता है। विंडो रीसाइज़िंग, की प्रेस, स्क्रॉल इवेंट आदि कुछ सामान्य विंडो सिस्टम ईवेंट हैं। इन घटनाओं को एप्लिकेशन के मुख्य लूप में सूचित किया जाता है। वहां से, उन्हें कॉलबैक फ़ंक्शन के संकेतों के माध्यम से पारित किया जाता है।

सिस्टम घटनाओं में से कुछ नीचे सूचीबद्ध हैं -

  • 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)

यहाँ, नाम उस स्ट्रिंग के लिए है जिसका नाम इवेंट के नाम से है जिसे कैप्चर किया जाना है। तथा,function का नाम है callbackवह कार्य जो किसी घटना के घटित होने पर कहा जाता है। डेटा कॉलबैक फ़ंक्शन पर पारित होने का तर्क है।

इसलिए, निम्न कोड एक बटन विजेट जोड़ता है और बटन_प्रेस घटना को कैप्चर करता है -

self.btn.connect("button_press_event", self.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

PyGTK लाइब्रेरी एक विंडो के अंदर विजेट्स के प्लेसमेंट को नियंत्रित करने के लिए विभिन्न कंटेनर कक्षाएं प्रदान करती है। सबसे आसान तरीका है एक का उपयोग करेंfixed container class और पिक्सेल में मापा अपने पूर्ण निर्देशांक निर्दिष्ट करके इसके अंदर एक विजेट रखें।

आइये अब हम इन चरणों का पालन करते हैं -

Step 1 - की एक वस्तु की घोषणा fixed class

fixed = gtk.Fixed()

Step 2 - एक बटन विजेट बनाएं और इसका उपयोग करके निर्धारित कंटेनर में जोड़ें put()विधि जो x और y निर्देशांक की आवश्यकता है। यहां, बटन को (100,100) स्थिति पर रखा जाएगा।

btn = gtk.Button("Hello")
fixed.put(btn, 100,100)

Step 3- आप निर्धारित कंटेनर में कई नियंत्रण रख सकते हैं। और, इसे शीर्ष-स्तरीय विंडो में जोड़ें और आह्वान करेंshow_all() तरीका

self.add(fixed)
self.show_all()

यह निरपेक्ष लेआउट, हालांकि, निम्नलिखित कारणों से उपयुक्त नहीं है -

  • विंडो के आकार बदलने पर भी विजेट की स्थिति नहीं बदलती है।
  • अलग-अलग रिज़ॉल्यूशन वाले विभिन्न डिस्प्ले डिवाइस पर उपस्थिति एक समान नहीं हो सकती है।
  • लेआउट में संशोधन कठिन है क्योंकि इसमें पूरे फॉर्म को फिर से डिज़ाइन करने की आवश्यकता हो सकती है।

निम्नलिखित है original window -

निम्नलिखित है resized window -

बटन की स्थिति यहां अपरिवर्तित है।

PyGTK API कंटेनर के अंदर विजेट्स की स्थिति को बढ़ाने के लिए कंटेनर क्लासेस प्रदान करता है। पूर्ण स्थिति पर लेआउट प्रबंधकों के फायदे हैं -

  • विंडो के अंदर विजेट स्वचालित रूप से आकार परिवर्तन कर रहे हैं।
  • विभिन्न प्रस्तावों के साथ प्रदर्शन उपकरणों पर एक समान उपस्थिति सुनिश्चित करता है।
  • रीडायरेक्ट किए बिना विजेट को गतिशील रूप से जोड़ना या हटाना संभव है।

gtk.Container निम्नलिखित वर्गों के लिए आधार वर्ग के रूप में कार्य करता है -

  • gtk.ButtonBox
  • gtk.Box
  • gtk.Alignment
  • gtk.EventBox
  • gtk.Table

Gtk.Box वर्ग एक कंटेनर की कार्यक्षमता को परिभाषित करने वाला एक अमूर्त वर्ग है जिसमें विगेट्स को एक आयताकार क्षेत्र में रखा जाता है। gtk.HBox और gtk.VBox विगेट्स इससे व्युत्पन्न हैं।

Gtk.Hbox में चाइल्ड विजेट को एक ही पंक्ति में क्षैतिज रूप से व्यवस्थित किया गया है। दूसरी ओर, gtk.VBox के चाइल्ड विजेट एक ही कॉलम में लंबवत व्यवस्थित हैं।

gtk.Box क्लास में निम्न कंस्ट्रक्टर का उपयोग किया जाता है -

gtk.Box(homogenous = True, spacing = 0)

समरूप गुण डिफ़ॉल्ट रूप से True पर सेट होता है। नतीजतन, सभी बच्चे विजेट को समान आवंटन दिया जाता है।

gtk.Box किसी विशेष स्थिति के संदर्भ में बाल विगेट्स को रखने के लिए पैकिंग तंत्र का उपयोग करता है, या तो शुरुआत या अंत के संदर्भ में। pack_start () विधि विजेट को शुरू से अंत तक रखती है। इसके विपरीत, pack_end () विधि विगेट्स को शुरू से अंत तक रखती है। वैकल्पिक रूप से, आप ऐड () विधि का उपयोग कर सकते हैं जो pack_start () के समान है।

निम्नलिखित तरीके gtk.HBox के साथ-साथ gtk.VBox के लिए उपलब्ध हैं -

  • gtk_box_pack_start ()

  • gtk_box_pack_end ()

gtk_box_pack_start ()

यह तरीका जोड़ता है child बॉक्स, बॉक्स की शुरुआत के संदर्भ में पैक किया गया -

pack_start(child, expand = True, fill = True, padding = 0)

निम्नलिखित पैरामीटर हैं -

  • child - यह बॉक्स में जोड़े जाने वाली विजेट ऑब्जेक्ट है

  • expand- यह सही पर सेट है अगर बच्चे को बॉक्स में अतिरिक्त जगह दी जानी है। अतिरिक्त जगह सभी बच्चों के बीच विभाजित हैwidgets

  • fill- अगर सही है, तो बच्चे को अतिरिक्त स्थान आवंटित किया जाएगा। अन्यथा, यह पैरामीटर पैडिंग के रूप में उपयोग किया जाता है।

  • padding - यह बॉक्स में विजेट्स के बीच पिक्सल में जगह है।

gtk_box_pack_end ()

यह बॉक्स के अंत में संदर्भ के साथ पैक बॉक्स में बच्चे को जोड़ता है।

pack_end (child, expand = True, fill = True, padding = 0)

निम्नलिखित पैरामीटर हैं -

  • child - यह जोड़ा जाने वाला विजेट ऑब्जेक्ट है

  • expand- यह सही पर सेट है अगर बच्चे को बॉक्स में अतिरिक्त जगह दी जानी है। यह अतिरिक्त स्थान सभी चाइल्ड विजेट के बीच विभाजित है।

  • fill - यदि सही है, तो अतिरिक्त स्थान बच्चे को आवंटित किया जाएगा अन्यथा पैडिंग के रूप में उपयोग किया जाता है।

  • padding - यह बॉक्स में विजेट्स के बीच पिक्सल में जगह है।

set_spacing (spacing) वह कार्य है जो बॉक्स के बच्चों के बीच रखने के लिए पिक्सेल की संख्या निर्धारित करता है।

प्रक्रिया add (widget)gtk.Container वर्ग से विरासत में मिला है। यह कंटेनर में विजेट जोड़ता है। इस विधि का उपयोग pack_start () विधि के बजाय किया जा सकता है।

उदाहरण

नीचे दिए गए उदाहरण में, टॉपवेल विंडो में एक ऊर्ध्वाधर बॉक्स (gtk.VBox ऑब्जेक्ट बॉक्स) है। बदले में इसमें VBox ऑब्जेक्ट vb और HBox ऑब्जेक्ट hb है। ऊपरी बॉक्स में, एक लेबल, एक प्रविष्टि विजेट और एक बटन लंबवत रखा गया है। निचले बॉक्स में, लेबल, प्रविष्टि और बटन का एक और सेट लंबवत रखा गया है।

निम्नलिखित कोड देखें -

import gtk
class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
         self.set_title("Box demo")
		
      box = gtk.VBox()
      vb = gtk.VBox()
      lbl = gtk.Label("Enter name")
		
      vb.pack_start(lbl, expand = True, fill = True, padding = 10)
      text = gtk.Entry()
		
      vb.pack_start(text, expand = True, fill = True, padding = 10)
      btn = gtk.Button(stock = gtk.STOCK_OK)
		
      vb.pack_start(btn, expand = True, fill = True, padding = 10)
      hb = gtk.HBox()
		
      lbl1 = gtk.Label("Enter marks")
      hb.pack_start(lbl1, expand = True, fill = True, padding = 5)
      text1 = gtk.Entry()
		
      hb.pack_start(text1, expand = True, fill = True, padding = 5)
      btn1 = gtk.Button(stock = gtk.STOCK_SAVE)
		
      hb.pack_start(btn1, expand = True, fill = True, padding = 5)
      box.add(vb)
      box.add(hb)
      self.add(box)
      self.show_all()
PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -

Gtk एपीआई में बटनबॉक्स वर्ग कंटेनर के लिए एक आधार वर्ग के रूप में कई बटन रखने के लिए क्षैतिज या लंबवत रूप से कार्य करता है। दो सबक्लास HButtonBox और VButtonBox बटनबॉक्स क्लास से ली गई हैं, जो खुद gtk.Box क्लास का सब-क्लास है।

एक बटन बॉक्स का उपयोग पूरे एप्लिकेशन के लिए एक सुसंगत लेआउट प्रदान करने के लिए किया जाता है। यह एक डिफ़ॉल्ट लेआउट और एक डिफ़ॉल्ट रिक्ति मूल्य प्रदान करता है जो सभी विगेट्स पर लगातार बना रहता है।

set_spacing() gtk.Box क्लास की विधि का उपयोग बटन बॉक्स में बटन के बीच डिफ़ॉल्ट रिक्ति को बदलने के लिए किया जा सकता है।

बटन के डिफ़ॉल्ट लेआउट को इसके द्वारा बदला जा सकता है set_default()तरीका। बटन लेआउट के संभावित मूल्य हैं -

  • gtk.BUTTONBOX_SPREAD

  • gtk.BUTTONBOX_EDGE

  • gtk.BUTTONBOX_START

  • gtk.BUTTONBOX_END.

उदाहरण

निम्नलिखित उदाहरण में, आंतरिक विंडो के अंदर एक VBox ऑब्जेक्ट में आंतरिक रूप से एक VButtonBox ऑब्जेक्ट और एक HButtonBox ऑब्जेक्ट होता है, जिसमें से प्रत्येक में दो बटन होते हैं, जो क्रमशः लंबवत और क्षैतिज रूप से व्यवस्थित होते हैं।

कोड को ध्यान से देखें -

import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      
	  self.set_title("Button Box demo")
      self.set_size_request(200,100)
      self.set_position(gtk.WIN_POS_CENTER)
	  vb = gtk.VBox()
      box1 = gtk.VButtonBox()
      btn1 = gtk.Button(stock = gtk.STOCK_OK)
      btn2 = gtk.Button(stock = gtk.STOCK_CANCEL)
		
      box1.pack_start(btn1, True, True, 0)
      box1.pack_start(btn2, True, True, 0)
      box1.set_border_width(5)
		
      vb.add(box1)
      box2 = gtk.HButtonBox()
      btn3 = gtk.Button(stock = gtk.STOCK_OK)
      btn4 = gtk.Button(stock = gtk.STOCK_CANCEL)
		
      ent = gtk.Entry()
      box2.pack_start(btn3, True, True, 0)
      box2.pack_start(btn4, True, True, 0)
      box1.set_border_width(5)
		
      vb.add(box2)
      self.add(vb)
      self.show_all()

PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करता है -

यह विजेट अपने बच्चे के विगेट्स के संरेखण और आकार को नियंत्रित करने में उपयोगी साबित होता है। इसमें xalign, yalign, xscale और yscale नामक चार गुण हैं। स्केल गुण निर्दिष्ट करते हैं कि चाइल्ड विजेट द्वारा कितनी खाली जगह का उपयोग किया जाएगा। संरेखित गुण उपलब्ध क्षेत्र के भीतर बच्चे के विजेट को रखने के लिए उपयोग किए जाते हैं।

सभी चार गुण 0 और 1.0 के बीच एक फ्लोट मान लेते हैं। यदि xscale और yscale की संपत्ति 0 पर सेट है, तो इसका मतलब है कि विजेट किसी भी खाली स्थान को अवशोषित नहीं करता है और यदि 1 पर सेट होता है, तो विजेट क्रमशः अधिकतम मुक्त स्थान को क्षैतिज या लंबवत रूप से अवशोषित करता है।

Xalign और yalign प्रॉपर्टी यदि 0 पर सेट है, तो इसका मतलब है कि बाईं या ऊपर विजेट के लिए कोई खाली जगह नहीं होगी। यदि 1 पर सेट किया जाता है, तो विजेट के ऊपर या ऊपर बाईं ओर अधिकतम खाली स्थान होगा।

Gtk.alignment वर्ग में निम्न रचनाकार हैं -

gtk.alignment(xalign = 0.0, yalign = 0.0, xscale = 0.0, yscale = 0.0)

कहाँ पे,

  • xalign - बच्चे के विजेट के बाईं ओर क्षैतिज मुक्त स्थान का अंश है।

  • yalign - बाल विजेट के ऊपर ऊर्ध्वाधर मुक्त स्थान का अंश है।

  • xscale - क्षैतिज मुक्त स्थान का वह अंश है जिसे बच्चा विजेट अवशोषित करता है।

  • yscale - वर्टिकल फ्री स्पेस का वह अंश है जिसे चाइल्ड विजेट अवशोषित करता है।

उदाहरण

निम्न कोड gtk.alignment विजेट के उपयोग को दर्शाता है। टॉपवेल विंडो में एक Vbox में ऊपरी Vbox और निचले Hbox को रखा गया है। ऊपरी ऊर्ध्वाधर बॉक्स में, एक लेबल और एक एंट्री विजेट ऐसे रखा जाता है कि बाईं ओर 50% स्थान खाली रखा जाता है और इसमें से 25% से अधिक 0.5 xignign और 0.25 yalign गुणों को असाइन करके कब्जा कर लिया जाता है।

निचले HBox में, सभी उपलब्ध खाली स्थान बाईं ओर है। यह 1 से xalign प्रॉपर्टी असाइन करके हासिल किया जाता है। इसलिए, क्षैतिज बॉक्स में दो बटन सही संरेखित दिखाई देते हैं।

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Alignment demo")
      self.set_size_request(400,200)
      self.set_position(gtk.WIN_POS_CENTER)
		
      vbox = gtk.VBox(False, 5)
      vb = gtk.VBox()
      hbox = gtk.HBox(True, 3)
      valign = gtk.Alignment(0.5,0.25, 0, 0)
		
      lbl = gtk.Label("Name of student")
      vb.pack_start(lbl, True, True, 10)
      text = gtk.Entry()
		
      vb.pack_start(text, True, True, 10)
      valign.add(vb)
      vbox.pack_start(valign)
		
      ok = gtk.Button("OK")
      ok.set_size_request(70, 30)
		
      close = gtk.Button("Close")
      hbox.add(ok)
      hbox.add(close)
		
      halign = gtk.Alignment(1, 0, 0, 0)
      halign.add(hbox)
		
      vbox.pack_start(halign, False, False, 3)
		
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

PyGTK टूल किट में कुछ विजेट्स की अपनी विंडो नहीं है। इस तरह के विंडोलेस विजेट से इवेंट सिग्नल नहीं मिल सकते हैं। इस तरह के विगेट्स, उदाहरण के लिए एक लेबल, अगर एक इवेंटबॉक्स के अंदर रखा जाए तो सिग्नल प्राप्त हो सकते हैं।

EventBox एक अदृश्य कंटेनर है जो विंडो को विंडो रहित विजेट प्रदान करता है। इसमें बिना किसी तर्क के एक सरल रचनाकार है -

gtk.EventBox()

उदाहरण

निम्न उदाहरण में, gtk.EventBox के दो विजेट टॉपवेल विंडो में रखे गए हैं। प्रत्येक ईवेंटबॉक्स के अंदर, एक लेबल जोड़ा जाता है। इवेंटबॉक्स अब उस पर button_press_event को संसाधित करने के लिए कॉलबैक फ़ंक्शन से जुड़ा है। जैसा कि इवेंटबॉक्स स्वयं अदृश्य है, प्रभावी रूप से घटना एम्बेडेड लेबल पर होती है। इसलिए, जब हम किसी भी लेबल पर क्लिक करते हैं, तो संबंधित कॉलबैक फ़ंक्शन को लागू किया जाता है।

कोड को ध्यान से देखें -

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("EventBox demo")
      self.set_size_request(200,100)
      self.set_position(gtk.WIN_POS_CENTER)
      fixed = gtk.Fixed()
      
      event1 = gtk.EventBox()
      label1 = gtk.Label("Label 1")
      event1.add(label1)
      fixed.put(event1, 80,20)
      
      event1.connect("button_press_event",self.hello1)
      event2 = gtk.EventBox()
      label2 = gtk.Label("Label 2")
      event2.add(label2)
      event2.connect("button_press_event",self.hello2)
      fixed.put(event2, 80,70)
      
      self.add(fixed)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
		
   def hello1(self, widget, event):
      print "clicked label 1"
		
   def hello2(self, widget, event):
      print "clicked label 2"

PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करता है -

जब लेबल 1 कंसोल पर क्लिक किया जाता है, तो संदेश "क्लिक किया गया लेबल 1" प्रिंट हो जाता है। इसी तरह, जब लेबल 2 पर क्लिक किया जाता है, तो "क्लिक किया गया लेबल 2" संदेश मुद्रित होता है।

Gtk.Layout gtk.Fixed के समान एक कंटेनर विजेट है। विजेट्स को पूर्ण निर्देशांक निर्दिष्ट करके लेआउट विजेट में रखा जाता है। हालाँकि, लेआउट निम्नलिखित तरीकों से निश्चित विजेट से अलग है -

  • लेआउट विजेट में अनंत चौड़ाई और ऊंचाई हो सकती है। चौड़ाई और ऊंचाई का अधिकतम मूल्य अहस्ताक्षरित पूर्णांक के आकार द्वारा सीमित है।

  • एक gtk.DrawingArea विजेट एक लेआउट कंटेनर में संलग्न किया जा सकता है। ड्रॉइंगएरिया एक कैनवास है जिस पर 2 डी तत्वों जैसे लाइन, आयत आदि को खींचा जा सकता है।

  • लेआउट कंटेनर को कम आयामों की सबसे अच्छी खिड़की में रखने के लिए, इसे स्क्रॉलबार के साथ जोड़ा जा सकता है या इसे स्क्रॉलडाइंडो में रखा जा सकता है।

Gtk.Layout वर्ग में निम्नलिखित निर्माता हैं -

gtk.Layout(hadjustment = None, vadjustment = None)

hadjustment तथा vadjustment प्रॉपर्टीज एक समायोज्य बाउंड वैल्यू वाले ऑब्जेक्ट का प्रतिनिधित्व करती है।

निम्न तालिका लेआउट के अक्सर उपयोग किए जाने वाले तरीकों की सूची देती है -

डाल (विजेट, एक्स, वाई) निर्दिष्ट निर्देशांक पर एक बाल विजेट रखें
set_size (डब्ल्यू, एच) लेआउट कंटेनर का आकार निर्दिष्ट चौड़ाई और ऊंचाई पर सेट करता है

लेआउट ऑब्जेक्ट set_scroll_adjustment सिग्नल का उत्सर्जन करता है जब इसके साथ जुड़े समायोजन बदले जाते हैं।

उदाहरण

निम्न उदाहरण में, एक लेआउट लेआउट कंटेनर के केंद्र में एक लेबल लगा हुआ है, जिसे बदले में छोटे आकार की एक छोटी खिड़की में रखा जाना है। इसलिए, इसे पहली बार एक स्क्रॉलडॉन्ड में जोड़ा जाता है और फिर स्क्रॉलडाइंडो को मुख्य विंडो में जोड़ा जाता है।

कोड को ध्यान से देखें -

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("layout")
      self.set_size_request(300,200)
      self.set_position(gtk.WIN_POS_CENTER)
      sc = gtk.ScrolledWindow()
      lo = gtk.Layout()
      lo.set_size(400,400)
      button = gtk.Button("Press Me")
      lo.put(button, 125,200)
      sc.add(lo)
      self.add(sc)
      self.connect("destroy", gtk.main_quit)
      self.show_all()

PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

ComboBox किसी भी GUI टूलकिट में एक शक्तिशाली और लोकप्रिय विजेट है। यह उन मदों की एक ड्रॉपडाउन सूची प्रदान करता है जिनसे उपयोगकर्ता चुन सकता है। Gtk.ComboBox विजेट सेललैट इंटरफ़ेस को लागू करता है और वस्तुओं के प्रदर्शन को प्रबंधित करने के लिए कई तरीके प्रदान करता है।

Gtk.ComboBox क्लास का ऑब्जेक्ट लिस्टसोर के साथ जुड़ा हुआ है, जो एक सूची मॉडल है जिसका उपयोग विगेट्स के साथ किया जा सकता है जो आइटम का संग्रह प्रदर्शित करते हैं। आइटम्स को परिशिष्ट () पद्धति से सूची में जोड़ा जाता है। इसके अलावा, एक CellRendererText ऑब्जेक्ट को कॉम्बोक्स में बनाया और पैक किया जाता है।

एक कॉम्बोक्स स्थापित करने के लिए इन चरणों का पालन करें।

combobox = gtk.ComboBox()
store = gtk.ListStore(gobject.TYPE_STRING)
cell = gtk.CellRendererText()
combobox.pack_start(cell)
combobox.add_attribute(cell, 'text', 0)

PyGTK एक सुविधा विधि प्रदान करता है - gtk.combo_box_new_text()एक सूची स्टोर का उपयोग करने के बजाय एक कॉम्बो बॉक्स बनाने के लिए। एसोसिएटेड सुविधा विधियों append_text (), prepend_text (), insert_text () और remove_text () का उपयोग कॉम्बो बॉक्सकंटेंट्स को प्रबंधित करने के लिए किया जाता है।

gtk.ComboBox क्लास के निम्नलिखित तरीके हैं -

S.NO तरीके और विवरण
1

set_wrap_width()

पॉपअप टेबल लेआउट में प्रदर्शित होने वाले कॉलम की संख्या निर्धारित करता है

2

get_active()

"सक्रिय" संपत्ति का मूल्य लौटाता है जो वर्तमान में सक्रिय आइटम के मॉडल में सूचकांक है

3

set_active()

निर्दिष्ट मॉडल सूचकांक के साथ आइटम को combo_box के सक्रिय आइटम सेट करता है

4

set_model()

कॉम्बो बॉक्स द्वारा उपयोग किए जाने वाले मॉडल को सेट करता है

5

append_text()

कॉम्बो बॉक्स सूची की दुकान में संग्रहीत तार की सूची के लिए पाठ द्वारा निर्दिष्ट स्ट्रिंग को लागू करता है

6

Insert_text()

स्थिति द्वारा निर्दिष्ट सूचकांक में कॉम्बो बॉक्स gtk.ListStore में पाठ द्वारा निर्दिष्ट स्ट्रिंग सम्मिलित करता है

7

prepend_text()

पाठ द्वारा निर्दिष्ट स्ट्रिंग को सूची स्टोर में संग्रहीत स्ट्रिंग्स की सूची में प्रस्तुत करता है

8

remove_text()

संबंधित सूची में स्थिति द्वारा निर्दिष्ट सूचकांक में स्ट्रिंग को हटाता है

9

get_active_text()

वर्तमान में सक्रिय स्ट्रिंग लौटाता है

ComboBox विजेट निम्नलिखित संकेतों का उत्सर्जन करता है -

बदला हुआ यह तब उत्सर्जित होता है जब कॉम्बो बॉक्स में एक नया आइटम चुना जाता है
move_active यह एक कीबाइंडिंग संकेत है जो सक्रिय चयन को स्थानांतरित करने के लिए उत्सर्जित होता है।
अचानक गायब हो जाना यह एक कीबाइंडिंग संकेत है जो कॉम्बो बॉक्स सूची को पॉपडाउन करने के लिए उत्सर्जित होता है। इस सिग्नल के लिए डिफ़ॉल्ट बाइंडिंग Alt + Up और एस्केप हैं
पॉप अप यह एक कीबाइंडिंग संकेत है जो कॉम्बो बॉक्स सूची को पॉपअप करने के लिए उत्सर्जित होता है। इस सिग्नल के लिए डिफ़ॉल्ट बाइंडिंग Alt + Down हैं।

कॉम्बोबॉक्स के प्रदर्शन के लिए दो उदाहरण कोड नीचे दिए गए हैं।

उदाहरण 1

इस उदाहरण में, एक ListStore लोकप्रिय Python GUI टूलकिट्स के नाम से आबाद है और यह एक कॉम्बो बॉक्स विजेट के साथ जुड़ा हुआ है। जैसा कि एक उपयोगकर्ता एक विकल्प बनाता है, परिवर्तित संकेत उत्सर्जित होता है। यह उपयोगकर्ता की पसंद को प्रदर्शित करने के लिए कॉलबैक फ़ंक्शन से जुड़ा है।

import pygtk
pygtk.require('2.0')
import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("ComboBox with ListStore")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      
      combobox = gtk.ComboBox()
      store = gtk.ListStore(str)
      cell = gtk.CellRendererText()
      combobox.pack_start(cell)
      combobox.add_attribute(cell, 'text', 0)
      fixed = gtk.Fixed()
      lbl = gtk.Label("select a GUI toolkit")
      fixed.put(lbl, 25,75)
      fixed.put(combobox, 125,75)
      lbl2 = gtk.Label("Your choice is:")
      fixed.put(lbl2, 25,125)
      self.label = gtk.Label("")
      fixed.put(self.label, 125,125)
      self.add(fixed)
      
      store.append (["PyQt"])
      store.append (["Tkinter"])
      store.append (["WxPython"])
      store.append (["PyGTK"])
      store.append (["PySide"])
      combobox.set_model(store)
      combobox.connect('changed', self.on_changed)
      combobox.set_active(0)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
      return
   
   def on_changed(self, widget):
      self.label.set_label(widget.get_active_text())
      return
      
if __name__ == '__main__':
PyApp()
gtk.main()

निष्पादन के बाद, कार्यक्रम निम्नलिखित आउटपुट प्रदर्शित करता है -

उदाहरण 2

कार्यक्रम का दूसरा संस्करण सुविधा विधि का उपयोग करता है combo_box_new_text()इसमें तार जोड़ने के लिए कॉम्बो बॉक्स और append_text () फ़ंक्शन बनाने के लिए। दोनों कार्यक्रमों में,get_active_text() विधि का उपयोग उपयोगकर्ता के चयन को प्राप्त करने और खिड़की पर एक लेबल पर प्रदर्शित करने के लिए किया जाता है।

import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Simple ComboBox")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      
      cb = gtk.combo_box_new_text()
      cb.connect("changed", self.on_changed)
      cb.append_text('PyQt')
      cb.append_text('Tkinter')
      cb.append_text('WxPython')
      cb.append_text('PyGTK')
      cb.append_text('PySide')
      
      fixed = gtk.Fixed()
      lbl = gtk.Label("select a GUI toolkit")
      fixed.put(lbl, 25,75)
      
      fixed.put(cb, 125,75)
      lbl2 = gtk.Label("Your choice is:")
      fixed.put(lbl2, 25,125)
      
      self.label = gtk.Label("")
      fixed.put(self.label, 125,125)
      self.add(fixed)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
   
   def on_changed(self, widget):
      self.label.set_label(widget.get_active_text())
if __name__ == '__main__':
   PyApp()
   gtk.main()

इस कार्यक्रम का आउटपुट पिछले प्रोग्राम के समान है।

ToggleButton विजेट दो राज्यों के साथ gtk.Button है - a pressed or active (या पर) राज्य और ए normal or inactive (or off)राज्य। जब भी बटन दबाया जाता है, राज्य वैकल्पिक होता है। ToggleButton की स्थिति को set_active () विधि द्वारा प्रोग्रामेटिक रूप से बदला जा सकता है। बटन की स्थिति को बदलने के लिए, टॉगल () विधि भी उपलब्ध है।

Gtk.ToggleButton वर्ग में निम्नलिखित निर्माता हैं -

gtk.ToggleButton(label = None, use_underline = True)

यहां, लेबल बटन पर प्रदर्शित होने वाली परीक्षा है। Use_underline प्रॉपर्टी, यदि सही है, तो पाठ में एक अंडरस्कोर इंगित करता है कि अगले वर्ण को रेखांकित किया जाना चाहिए और इसका उपयोग मेम्नेनिक त्वरक के लिए किया जाना चाहिए।

Gtk.ToggleButton वर्ग के कुछ महत्वपूर्ण तरीके निम्नलिखित तालिका में दिए गए हैं -

सक्रिय नियत करें() यह सेट करता है active के मूल्य पर संपत्ति True (सक्रिय या दबाया या पर) या False (निष्क्रिय या सामान्य या बंद)
सक्रिय बनो() यह बटन की स्थिति को पुनः प्राप्त करता है
चालू किए जाने () यह टॉगलबटन पर "टॉगल" सिग्नल का उत्सर्जन करता है।

ToggleButton विजेट निम्नलिखित सिग्नल का उत्सर्जन करता है -

टॉगल यह तब उत्सर्जित होता है जब टॉगलबटन स्थिति या तो प्रोग्रामेटिक रूप से या उपयोगकर्ता क्रिया द्वारा बदल जाती है।

नीचे दिया गया कोड ToggleButton विगेट्स के उपयोग को दर्शाता है।

दो ToggleButtons और लेबल विजेट VBox कंटेनर में रखे गए हैं। Button1 द्वारा उत्सर्जित टॉगल सिग्नल on_toggled () के कॉलबैक फ़ंक्शन से जुड़ा है। इस फ़ंक्शन में, Button2 की स्थिति True पर सेट होती है यदि Button1 की स्थिति गलत और इसके विपरीत है।

if self.btn1.get_active() == True:
   self.btn2.set_active(False)
else:
   self.btn2.set_active(True)

यह लेबल पर बटन की तात्कालिक स्थिति प्रदर्शित करता है।

उदाहरण

निम्नलिखित कोड देखें -

import gtk

 PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Toggle Button")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      
      vbox = gtk.VBox()
      self.btn1 = gtk.ToggleButton("Button 1")
      self.btn1.connect("toggled", self.on_toggled)
      self.btn2 = gtk.ToggleButton("Button 2")
      self.lbl = gtk.Label()
      
      vbox.add(self.btn1)
      vbox.add(self.btn2)
      vbox.add(self.lbl)
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
   
   def on_toggled(self, widget, data = None):
      if self.btn1.get_active() == True:
         self.btn2.set_active(False)
      else:
         self.btn2.set_active(True)
         state = "Button1 : "+str(self.btn1.get_active())+" 
         Button2 : "+str(self.btn2.get_active())
         self.lbl.set_text(state)
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करता है -

एक चेकबटन विजेट कुछ भी नहीं है बल्कि एक चेकबॉक्स और एक लेबल के रूप में स्टाइल किया गया टॉगलबटन है। यह ToggleButton वर्ग के सभी गुणों और विधियों को विरासत में मिला है। ToggleButton के विपरीत जहां कैप्शन बटन के चेहरे पर होता है, एक CheckButton एक छोटा सा वर्ग प्रदर्शित करता है जो जांचने योग्य होता है और इसके दाईं ओर एक लेबल होता है।

Gtk.CheckButton से जुड़े कंस्ट्रक्टर, तरीके और सिग्नल बिल्कुल gtk.ToggleButton जैसे ही हैं।

उदाहरण

निम्न उदाहरण चेकबटन विजेट के उपयोग को दर्शाता है। दो चेकबटन और एक लेबल को एक VBox में रखा गया है। पहले चेकबटन का टॉगल सिग्नल on_checked () विधि से जुड़ा है जो कि दूसरे बटन की स्थिति को True पर सेट करता है यदि पहला गलत है और इसके विपरीत है।

कोड को ध्यान से देखें -

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Check Button")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)

      vbox = gtk.VBox()
      self.btn1 = gtk.CheckButton("Button 1")
      self.btn1.connect("toggled", self.on_checked)
      self.btn2 = gtk.CheckButton("Button 2")
      self.btn2.connect("toggled", self.on_checked)
      self.lbl = gtk.Label()
		
      vbox.add(self.btn1)
      vbox.add(self.btn2)
      vbox.add(self.lbl)
		
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
		
   def on_checked(self, widget, data = None):
      state = "Button1 : "+str(self.btn1.get_active())+" 
         Button2 : "+str(self.btn2.get_active())
      self.lbl.set_text(state)
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

एक एकल रेडियोबटन विजेट चेकबटन के समान कार्यक्षमता प्रदान करता है। हालांकि, जब एक से अधिक रेडियो बटन एक ही कंटेनर में मौजूद होते हैं, तो उपयोगकर्ता के लिए एक पारस्परिक रूप से अनन्य विकल्प उपलब्ध विकल्पों में से किसी एक को चुनने के लिए उपलब्ध होता है। यदि कंटेनर में प्रत्येक रेडियो बटन एक ही समूह का है, तो जैसा कि एक का चयन किया जाता है, दूसरों को स्वचालित रूप से हटा दिया जाता है।

निम्नलिखित gtk.RadioButton वर्ग का एक निर्माता है -

gtk.RadioButton(group = None, Label = None, unerline = None)

बटन समूह बनाने के लिए, प्रदान करें group=None पहले रेडियो बटन के लिए, और बाद के विकल्पों के लिए, समूह के रूप में पहले बटन की वस्तु प्रदान करें।

जैसे कि टॉगलबटन और चेकबटन के मामले में, रेडियोबटन भी निकलता है the toggled signal। नीचे दिए गए उदाहरण में, gtk.RadioButton विजेट की तीन वस्तुओं को एक VBox में रखा गया है। उन सभी को toggled सिग्नल को संसाधित करने के लिए on_selected () पर कॉलबैक फ़ंक्शन से जोड़ा जाता है।

कॉलबैक फ़ंक्शन स्रोत RadioButton विजेट के लेबल की पहचान करता है और इसे VBox में डाले गए लेबल पर प्रदर्शित करता है।

उदाहरण

निम्नलिखित कोड देखें -

import gtk

class PyApp(gtk.Window):

   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Radio Button")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      vbox = gtk.VBox()
      
      btn1 = gtk.RadioButton(None, "Button 1")
      btn1.connect("toggled", self.on_selected)
      btn2 = gtk.RadioButton(btn1,"Button 2")
      btn2.connect("toggled", self.on_selected)
      btn3 = gtk.RadioButton(btn1,"Button 3")
      btn3.connect("toggled", self.on_selected)
      
      self.lbl = gtk.Label()
      vbox.add(btn1)
      vbox.add(btn2)
      vbox.add(btn3)
      vbox.add(self.lbl)
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
   
   def on_selected(self, widget, data=None):
      self.lbl.set_text(widget.get_label()+" is selected")
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

एक शीर्ष स्तर पट्टी के ठीक नीचे एक क्षैतिज पट्टी gtk.Window मेनू की श्रृंखला प्रदर्शित करने के लिए आरक्षित है। यह PyGTK API में gtk.MenuBar क्लास का ऑब्जेक्ट है।

मेनू बार में gtk.Menu क्लास का ऑब्जेक्ट जोड़ा जाता है। इसका उपयोग संदर्भ मेनू और पॉपअप मेनू बनाने के लिए भी किया जाता है। प्रत्येक मेनू में एक या अधिक gtk.MenuItem विजेट हो सकते हैं। उनमें से कुछ एक सबमेनू हो सकते हैं। और मेस्कैम बटन को कैस्केड किया है।

Gtk.MenuBar को gtk.MenuShell वर्ग से उप-वर्गित किया गया है। इसका एक सरल डिफ़ॉल्ट निर्माता है -

gtk.MenuBar()

MenuBar में मेनू जोड़ने के लिए, MenuBar वर्ग के एपेंड () विधि का उपयोग किया जाता है।

मेनू का निर्माण करने के लिए, एक मेनू के साथ मेनूइमेट विजेट बनाएं जो मेनू बार में दिखाई देने के लिए वांछित है और इसे सबमेनू के रूप में सेट करें।

उदाहरण के लिए, फ़ाइल मेनू सेट करने के लिए निम्न कोड का उपयोग किया जाता है -

menu1 = gtk.Menu()
file = gtk.MenuItem("_File")
file.set_submenu(menu1)

अब, MenuItem वर्ग के एक या एक से अधिक विजेट मेनू में जोड़े जा सकते हैं।

item1 = gtk.MenuItem("New")
item2 = gtk.MenuItem("Open")

ये MenuItems मेनू विजेट में जोड़े जाते हैं और बदले में मेनू ऑब्जेक्ट को मेनू बार में जोड़ा जाता है।

menu1.append(item1)
menu1.append(item2)
mb.append(menu1)

PyGTK टूलकिट कई प्रकार के MenuItem विजेट प्रदान करता है। एक ImageMenuItem एक मेनू आइटम है जिसके साथ एक छवि जुड़ी हुई है। आप स्टॉक आईडी पैरामीटर का उपयोग करके किसी भी स्टॉक इमेज का उपयोग कर सकते हैं या किसी अन्य छवि को set_image () विधि द्वारा असाइन कर सकते हैं।

उदाहरण के लिए, 'नई' मेनू आइटम वाली छवि निम्न प्रकार से बनाई गई है -

new = gtk.ImageMenuItem(gtk.STOCK_NEW)
menu1.append(new)

इसी तरह, निम्नलिखित कोड का उपयोग करके CheckMenuItem जोड़ना भी संभव है -

chk = gtk.CheckMenuItem("Checkable")
menu1.append(chk)

इस कोड का उपयोग करके रेडियो आइटम का एक समूह भी जोड़ा जा सकता है -

radio1 = gtk.RadioMenuItem(None,"Radio1")
radio2 = gtk.RadioMenuItem(radio1, "Radio2")
menu1.append(radio1)
menu1.append(radio2)

कभी-कभी, आप मेनू आइटम के बीच एक सेपरेटर लाइन जोड़ना चाह सकते हैं। उस उद्देश्य के लिए,SeparatorMenuItem भी उपलब्ध है।

sep = gtk.SeparatorMenuItem()
menu1.append(sep)

आप मेनू आइटम के लिए कीबोर्ड शॉर्टकट भी असाइन कर सकते हैं। PyGTK में एक्सेलेरेटर हैं। एक त्वरक समूह बनाकर शुरू करें और इसे टॉपप्ले विंडो में संलग्न करें।

acgroup = gtk.AccelGroup()
self.add_accel_group(acgroup)

शॉर्टकट असाइन करने के लिए, का उपयोग करें add_accelerator() निम्नलिखित प्रोटोटाइप के साथ कार्य -

Item1.add_accelerator(signal, group, key, modifier, flags)

निम्नलिखित कुछ पूर्वनिर्धारित संशोधक हैं -

  • SHIFT_MASK
  • LOCK_MASK
  • CONTROL_MASK
  • BUTTON1_MASK
  • BUTTON1_MASK

नए मेनू आइटम में Ctrl + N शॉर्टकट असाइन करने के लिए, निम्नलिखित सिंटैक्स का उपयोग करें -

new = gtk.ImageMenuItem(gtk.STOCK_NEW,acgroup)
new.add_accelerator("activate", acgroup, ord('N'), 
   gtk.gdk.CONTROL_MASK, gtk.ACCEL_VISIBLE)

उदाहरण

निम्न उदाहरण ऊपर चर्चा की गई विशेषताओं को प्रदर्शित करता है -

import gtk

class PyApp(gtk.Window):
   def __init__(self):
      
      super(PyApp, self).__init__()
      self.set_title("Menu Demo")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      
      mb = gtk.MenuBar()
      
	  menu1 = gtk.Menu()
      file = gtk.MenuItem("_File")
      file.set_submenu(menu1)
      acgroup = gtk.AccelGroup()
      self.add_accel_group(acgroup)
      new = gtk.ImageMenuItem(gtk.STOCK_NEW,acgroup)
      new.add_accelerator("activate", acgroup, ord('N'), 
         gtk.gdk.CONTROL_MASK, gtk.ACCEL_VISIBLE)
      
      menu1.append(new)
      open = gtk.ImageMenuItem(gtk.STOCK_OPEN)
      
      menu1.append(open)
      chk = gtk.CheckMenuItem("Checkable")
      
      menu1.append(chk)
      radio1 = gtk.RadioMenuItem(None,"Radio1")
      radio2 = gtk.RadioMenuItem(radio1, "Radio2")
      
      menu1.append(radio1)
      menu1.append(radio2)
      sep = gtk.SeparatorMenuItem()
      
      menu1.append(sep)
      exit = gtk.ImageMenuItem(gtk.STOCK_QUIT)
      
      menu1.append(exit)
      menu2 = gtk.Menu()
      edit = gtk.MenuItem("_Edit")
      edit.set_submenu(menu2)
      copy = gtk.ImageMenuItem(gtk.STOCK_COPY)
      
      menu2.append(copy)
      cut = gtk.ImageMenuItem(gtk.STOCK_CUT)
      
      menu2.append(cut)
      paste = gtk.ImageMenuItem(gtk.STOCK_PASTE)
      
      menu2.append(paste)
      mb.append(file)
      mb.append(edit)
      vbox = gtk.VBox(False, 2)
      vbox.pack_start(mb, False, False, 0)
      
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -

टूलबार वर्ग gtk.Container वर्ग से विरासत में मिला है। यह बटन और अन्य विजेट का एक सेट रखता है और उसका प्रबंधन करता है। बटन के एक या अधिक क्षैतिज स्ट्रिप्स आमतौर पर शीर्ष स्तर की विंडो में मेनू बार के ठीक नीचे देखे जाते हैं। टूलबार को हैंडलबॉक्स नामक वियोज्य विंडो में भी रखा जा सकता है। डिफ़ॉल्ट रूप से, gtk.Toolbar विजेट में बटन क्षैतिज रूप से रखे गए हैं। वर्टिकल टूलबार को ओरिएंटेशन प्रॉपर्टी को सेट करके सेट किया जा सकता हैgtk.ORIENTATION_VERTICAL

टूलबार को आइकन, टेक्स्ट या दोनों के साथ बटन दिखाने के लिए कॉन्फ़िगर किया जा सकता है। शैली प्रगणक हैं -

gtk.TOOLBAR_ICONS ये बटन टूलबार में केवल आइकन प्रदर्शित करते हैं।
gtk.TOOLBAR_TEXT ये बटन टूलबार में केवल टेक्स्ट लेबल प्रदर्शित करते हैं।
gtk.TOOLBAR_BOTH ये बटन टूलबार में टेक्स्ट और आइकन प्रदर्शित करते हैं।
gtk.TOOLBAR_BOTH_HORIZ ये बटन वर्टिकल स्टैक्ड की बजाय एक दूसरे के साथ आइकन और टेक्स्ट प्रदर्शित करते हैं।

टूलबार विजेट निम्नलिखित कंस्ट्रक्टर का उपयोग करके सेट किया गया है -

bar = gtk.Toolbar()

टूलबार के घटक gtk.ToolItem के उदाहरण हैं। आइटम टूलबटन, RadioToolButton, ToggleToolButton, या सेपरेटर टूलटेम हो सकते हैं। टूलआइटम ऑब्जेक्ट को आइकन असाइन करने के लिए, पूर्वनिर्धारित स्टॉक_आईडी वाली छवियों का उपयोग किया जा सकता है या सेट_इमेज () विधि द्वारा एक कस्टम छवि को सौंपा जा सकता है।

निम्नलिखित उदाहरण दिखाते हैं कि विभिन्न टूलटाइम्स का निर्माण कैसे किया जाता है -

ToolButton

newbtn = gtk.ToolButton(gtk.STOCK_NEW)

RadioToolButton

rb1 = gtk.RadioToolButton(None,gtk.STOCK_JUSTIFY_LEFT) 
rb2 = gtk.RadioToolButton(rb1,gtk.STOCK_JUSTIFY_RIGHT)

ध्यान दें कि एक ही समूह में कई रेडियो बटन लगाए जाते हैं।

SeparatorToolItem

sep = gtk.SeparatorToolItem()

इन मदों को टूलबार में कॉल करके रखा जाता है insert तरीका।

gtk.Toolbar.insert(item, index)

उदाहरण के लिए,

bar.insert(new,0)

आप set_tooltip_text () nethod का उपयोग करके टूलबटन को टूलटिप भी असाइन कर सकते हैं। उदाहरण के लिए,New टूलटिप को नए टूलबटन को सौंपा गया है।

newbtn.set_tooltip_text("New")

उदाहरण

निम्न कोड सामान्य टूल आइटम, रेडियो आइटम और एक विभाजक आइटम शामिल करने के लिए सेट अप टूलप्ले विंडो को दिखाता है।

import gtk

class PyApp(gtk.Window):

   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Toolbar Demo")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      
      toolbar = gtk.Toolbar()
      toolbar.set_style(gtk.TOOLBAR_ICONS)
      toolbar.set_orientation(gtk.ORIENTATION_HORIZONTAL)
      
      newbtn = gtk.ToolButton(gtk.STOCK_NEW)
      newbtn.set_tooltip_text("New")
      openbtn = gtk.ToolButton(gtk.STOCK_OPEN)
      savebtn = gtk.ToolButton(gtk.STOCK_SAVE)
      sep = gtk.SeparatorToolItem()
      
      rb1 = gtk.RadioToolButton(None,gtk.STOCK_JUSTIFY_LEFT)
      53
      rb2 = gtk.RadioToolButton(rb1,gtk.STOCK_JUSTIFY_RIGHT)
      
      prv = gtk.ToggleToolButton(gtk.STOCK_PRINT_PREVIEW)
      quitbtn = gtk.ToolButton(gtk.STOCK_QUIT)
      
      toolbar.insert(newbtn, 0)
      toolbar.insert(openbtn, 1)
      toolbar.insert(savebtn, 2)
      toolbar.insert(sep, 3)
      toolbar.insert(rb1,4)
      toolbar.insert(rb2,5)
      toolbar.insert(prv,6)
      toolbar.insert(quitbtn, 7)
      
      quitbtn.connect("clicked", gtk.main_quit)
      vbox = gtk.VBox(False, 2)
      vbox.pack_start(toolbar, False, False, 0)
      
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
   
   def on_checked(self, widget, data = None):
      state = "Button1 : "+str(self.btn1.get_active())+" 
         Button2 : "+str(self.btn2.get_active())
      self.lbl.set_text(state)
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

PyGTK टूलकिट में कुछ विजेट ऐसे हैं, जिनके गुणों को उपयोगकर्ता द्वारा माउस या कीबोर्ड का उपयोग करके एक निर्दिष्ट सीमा पर समायोजित किया जा सकता है। व्यूपोर्ट जैसे विजेट का उपयोग बड़े डेटा के कुछ समायोज्य हिस्से को प्रदर्शित करने के लिए किया जाता है, उदाहरण के लिए, टेक्स्ट व्यू नियंत्रण में एक बहु-पाठ पाठ।

PyGTK इस तरह के विगेट्स के साथ जुड़ने के लिए gtk.Adjustment ऑब्जेक्ट का उपयोग करता है ताकि प्रसंस्करण के लिए कुछ कॉलबैक फ़ंक्शन के लिए उपयोगकर्ता समायोजन पास हो। एक समायोजन ऑब्जेक्ट में एक समायोज्य मूल्य के निचले और ऊपरी सीमाएं होती हैं और इसके वेतन वृद्धि के चरण पैरामीटर्स होते हैं। जब समायोजन ऑब्जेक्ट के पैरामीटर बदलते हैं, तो यह परिवर्तित या value_changed संकेतों का उत्सर्जन करता है।

निम्नलिखित gtk.Adjustment वर्ग का निर्माता है -

gtk.Adjustment(value = 0, lower = 0, upper = 0, step_incr = 0, 
   page_incr = 0, page_size = 0)

कंस्ट्रक्टर में प्रत्येक विशेषता का अर्थ इस प्रकार है -

मूल्य प्रारंभिक मूल्य
कम न्यूनतम मूल्य
अपर अधिकतम मूल्य
step_incr कदम बढ़ाना
page_incr पेज वेतन वृद्धि
पृष्ठ आकार पृष्ठ का आकार

निम्नलिखित संकेत समायोजन वस्तु द्वारा उत्सर्जित होते हैं -

बदला हुआ समायोजन विशेषताओं (मूल्य विशेषता को छोड़कर) के एक (या अधिक) बदलने पर यह उत्सर्जित होता है।
मूल्य-बदल समायोजन मान विशेषता बदल जाने पर यह उत्सर्जित होता है।

जैसा कि ऊपर उल्लेख किया गया है, समायोजन ऑब्जेक्ट एक भौतिक विजेट नहीं है। बल्कि, इसका उपयोग अन्य विजेट्स के सहयोग से किया जाता है, जिसके उपयोग से इसकी विशेषताएँ बदल जाती हैं। एडजस्टमेंट ऑब्जेक्ट के साथ रेंज विजेट का उपयोग किया जाता है।

यह वर्ग विजेट के लिए एक आधार वर्ग के रूप में कार्य करता है जो उपयोगकर्ता को निचले और ऊपरी सीमा के बीच एक संख्यात्मक पैरामीटर के मूल्य को समायोजित करने देता है। स्केल विजेट (gtk.Hscale और gtk.Vscale) और स्क्रॉलबार विजेट (gtk.HScrollbar और gtk.VScrollbar) रेंज क्लास से कार्यक्षमता प्राप्त करते हैं। ये रेंज विगेट्स एडजस्टमेंट ऑब्जेक्ट के साथ मिलकर काम करते हैं।

Gtk.Range वर्ग के निम्नलिखित महत्वपूर्ण कार्य स्केल और स्क्रॉलबार विजेट द्वारा कार्यान्वित किए जाते हैं -

  • set_update_policy()- यह "अपडेट-पॉलिसी" प्रॉपर्टी को वैल्यू पर सेट करता है। नीति के निम्नलिखित मूल्य हैं -

gtk.UPDATE_CONTINUOUS कभी भी रेंज स्लाइडर ले जाया जाता है, रेंज मान बदल जाएगा और "value_changed" सिग्नल उत्सर्जित हो जाएगा।
gtk.UPDATE_DELAYED मान एक संक्षिप्त समय के बाद अपडेट किया जाएगा जहां कोई स्लाइडर गति नहीं होती है, इसलिए मूल्य परिवर्तन लगातार अपडेट होने के बजाय थोड़ा विलंबित होते हैं।
gtk.UPDATE_DISCONTINUOUS मूल्य केवल तभी अपडेट किया जाएगा जब उपयोगकर्ता बटन जारी करेगा और स्लाइडर ड्रैग ऑपरेशन को समाप्त करेगा।
  • set_adjustment()- यह "समायोजन" संपत्ति सेट करता है। समायोजन ऑब्जेक्ट का उपयोग रेंज ऑब्जेक्ट के लिए मॉडल के रूप में किया जाता है।

  • set_increments() - यह सीमा के लिए चरण और पृष्ठ आकार सेट करता है।

  • set_range() - यह रेंज विजेट के लिए न्यूनतम और अधिकतम स्वीकार्य मूल्य निर्धारित करता है

  • set_value() - यह सीमा के वर्तमान मूल्य को निर्दिष्ट मान पर सेट करता है।

स्केल विजेट क्लासेस - (HScale और VScale) gtk.Range क्लास से ली गई हैं।

यह वर्ग HScale और VScale विजेट के लिए एक सार आधार वर्ग के रूप में कार्य करता है। ये विगेट्स एक स्लाइडर नियंत्रण के रूप में काम करते हैं और एक संख्यात्मक मान का चयन करते हैं।

इस सार वर्ग के निम्नलिखित तरीके HScale वर्ग और VScale वर्ग द्वारा कार्यान्वित किए गए हैं -

  • set_digits() - यह विजेट के तात्कालिक मूल्य प्रदर्शित करने के लिए उपयोग किए जाने वाले दशमलव स्थानों की संख्या निर्धारित करता है।

  • set_draw_value() - सही पर सेट करें, वर्तमान मूल्य स्लाइडर के बगल में प्रदर्शित किया जाएगा।

  • set_value_pos()- यह वह स्थिति है जिस पर मान खींचे जाते हैं। यह या तो gtk.POS_LEFT, gtk.POS_RIGHT, gtk.POS_TOP या gtk.POS_BOTTOM हो सकता है।

Gtk.HScale क्लास का ऑब्जेक्ट क्षैतिज स्लाइडर प्रदान करता है, जबकि gtk.VScale क्लास का ऑब्जेक्ट ऊर्ध्वाधर स्लाइडर प्रदान करता है। दोनों वर्गों में समान निर्माता हैं -

gtk.HScale(Adjustment = None)
gtk.VScale(Adjustment = None)

समायोजन ऑब्जेक्ट में कई विशेषताएं हैं जो मूल्य और सीमा तक पहुंच प्रदान करती हैं।

यह वर्ग gtk.Hscrollbar और gtk.Vscrollbar विजेट के लिए एक सार आधार वर्ग है। दोनों एक समायोजन वस्तु के साथ जुड़े हुए हैं। स्क्रॉलबार के अंगूठे की स्थिति को स्क्रॉल समायोजन द्वारा नियंत्रित किया जाता है। समायोजन वस्तु की विशेषताओं का उपयोग निम्नानुसार किया जाता है -

कम स्क्रॉल क्षेत्र का न्यूनतम मूल्य
अपर स्क्रॉल क्षेत्र का अधिकतम मूल्य
मूल्य स्क्रॉलबार की स्थिति का प्रतिनिधित्व करता है, जो निचले और ऊपरी के बीच होना चाहिए
पृष्ठ आकार दृश्यमान स्क्रॉल योग्य क्षेत्र के आकार का प्रतिनिधित्व करता है
step_increment छोटे स्टेपर तीर क्लिक करने पर स्क्रॉल करने की दूरी
page_increment स्क्रॉल करने के लिए दूरी जब Page Up या Page Down कुंजी दबाया

निम्न कार्यक्रम एक एचएसकेले और एक एचएसक्रोलबार विजेट को वोकल विंडो में जोड़े गए वीबॉक्स में रखा गया दिखाता है। उनमें से प्रत्येक एक समायोजन वस्तु के साथ जुड़ा हुआ है।

adj1 = gtk.Adjustment(0, 0, 101, 0.1, 1, 1)
self.adj2 = gtk.Adjustment(10,0,101,5,1,1)

एक gtk.HScale विजेट एक स्लाइडर नियंत्रण है जो adj1 के साथ जुड़ा हुआ है। इसकी अद्यतन नीति, संख्या और ड्राइंग मान की स्थिति निम्नानुसार है -

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 एक क्षैतिज स्क्रॉलबार प्रदान करता है। यह adj2 ऑब्जेक्ट के साथ जुड़ा हुआ है। इसकी अद्यतन नीति भी CONTINUOUS पर सेट है।

self.bar1 = gtk.HScrollbar(self.adj2)
self.bar1.set_update_policy(gtk.UPDATE_CONTINUOUS)

स्क्रॉलबार के तात्कालिक मूल्य को प्रदर्शित करने के लिए, 'मूल्य-परिवर्तित' संकेत the adjustment object — adj2 कॉलबैक फ़ंक्शन से जुड़ा है on_scrolled()। फ़ंक्शन समायोजन ऑब्जेक्ट की मान गुण को पुनर्प्राप्त करता है और स्क्रॉलबार के नीचे एक लेबल पर प्रदर्शित करता है।

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)))

उदाहरण

निम्नलिखित कोड देखें -

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()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

एक डायलॉग विजेट आमतौर पर एक मूल विंडो के शीर्ष पर पॉप-अप विंडो के रूप में उपयोग किया जाता है। एक संवाद का उद्देश्य उपयोगकर्ता से कुछ डेटा एकत्र करना और इसे मूल विंडो पर भेजना है। डायलॉग मोडल हो सकता है (जहां यह मूल फ्रेम को ब्लॉक करता है) या मॉडलस (डायलॉग फ्रेम को बायपास किया जा सकता है)।

PyGTK लाइब्रेरी का डायलॉग विजेट लंबवत रूप से एक विंडो विभाजन है। इसके शीर्ष भाग में, एक gtk.VBox है जिसमें लेबल या प्रविष्टि विजेट भरे हुए हैं। नीचे के खंड को एक्शन_एरिया कहा जाता है जिसमें एक या अधिक बटन रखे जाते हैं। Gtk.HSeparator द्वारा दो क्षेत्रों को अलग किया जाता है।

gtk.Dialog क्लास में निम्न कंस्ट्रक्टर हैं -

dlg = gtk.Dialog (Title = None, parent = None, flags = 0, buttons = None)

कहाँ पे,

  • Title - क्या डायलॉग विजेट के शीर्षक बार में दिखाई देने वाला पाठ है।

  • Parent - टॉपप्ले विंडो का संदर्भ है जिसमें से डायलॉग पॉप अप होता है।

  • Flag- डायलॉग के संचालन को नियंत्रित करने वाले स्थिरांक को परिभाषित करता है। परिभाषित स्थिरांक हैं -

gtk.DIALOG_MODAL यदि सेट किया जाता है, तो संवाद सभी कीबोर्ड घटनाओं को पकड़ लेता है
gtk.DIALOG_DESTROY_WITH_PARENT यदि सेट किया जाता है, तो संवाद तब नष्ट हो जाता है जब उसका मूल है।
gtk.DIALOG_NO_SEPARATOR यदि सेट किया गया है, तो बटन के ऊपर कोई विभाजक पट्टी नहीं है।

एक बटन क्या है?

एक बटन एक tuple ऑब्जेक्ट है जिसमें एक शेयर आईडी (या पाठ) और उसकी प्रतिक्रिया आईडी के साथ gtk.Button के जोड़े हैं।

प्रतिक्रिया आईडी किसी भी संख्या या पूर्वनिर्धारित प्रतिक्रिया आईडी स्थिरांक में से एक हो सकती है -

  • gtk.RESPONSE_NONE
  • gtk.RESPONSE_REJECT
  • gtk.RESPONSE_ACCEPT
  • gtk.RESPONSE_DELETE_EVENT
  • gtk.RESPONSE_OK
  • gtk.RESPONSE_CANCEL
  • gtk.RESPONSE_CLOSE
  • gtk.RESPONSE_YES
  • gtk.RESPONSE_NO
  • gtk.RESPONSE_APPLY
  • gtk.RESPONSE_HELP

Gtk.Dialog क्लास के महत्वपूर्ण तरीके नीचे दिए गए हैं -

  • add_button() - द्वारा निर्दिष्ट पाठ के साथ एक बटन जोड़ता है button_text (या एक स्टॉक बटन, अगर बटन_टेक्स्ट एक स्टॉक आईडी है) कार्रवाई में_रिया।

  • response() - response_id में निर्दिष्ट मान के साथ "प्रतिक्रिया" संकेत का उत्सर्जन करता है

  • run() - डायलॉग प्रदर्शित करता है और जब delete_event उत्सर्जित हो जाता है, तब response_id लौटाता है।

  • set_default_response() - निर्दिष्ट के साथ संवाद के एक्शन क्षेत्र में अंतिम विजेट सेट करता है response_id संवाद के लिए डिफ़ॉल्ट विजेट के रूप में।

gtk.Dialog विजेट निम्नलिखित संकेतों का उत्सर्जन करता है -

बंद करे संवाद बंद होने पर यह उत्सर्जित होता है।
प्रतिक्रिया यह तब उत्सर्जित होता है जब एक क्रिया_कार्य विजेट सक्रिय हो जाता है (बटन "क्लिक किया गया"), संवाद एक डिलीट_वेंट प्राप्त करता है या एप्लिकेशन प्रतिक्रिया () विधि को कॉल करता है।

डायलॉग विजेट के एक्शन_अर में दो बटन स्टॉक आईडी gtk.STOCK.CANCEL और gtk.STOCK_OK का उपयोग करते हैं। वे प्रतिक्रिया आईडी gtk से जुड़े हैं। RESPONSE_REJECT और gtk। क्रमशः RESPONSE_ACCEPT। किसी भी बटन को दबाने पर डायलॉग बंद हो जाता है। रन () विधियां संबंधित प्रतिक्रिया आईडी लौटाती हैं जो आगे की प्रक्रिया के लिए उपयोग की जा सकती हैं।

निम्न कोड प्रदर्शित करता है एक शीर्ष स्तर gtk। इसमें एक बटन के साथ। जब बटन पर क्लिक किया जाता है, तो एक डायलॉग एक लेबल और दो बटन के साथ दिखाई देता है।

उदाहरण

निम्नलिखित कोड देखें -

import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Dialog Demo")
      self.set_default_size(250, 200)
      fixed = gtk.Fixed()
      btn = gtk.Button("Show")
      btn.connect("clicked",self.show_sialog)
      fixed.put(btn,100,100)
      self.add(fixed)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
      
   def show_sialog(self, widget, data=None):
      dialog = gtk.Dialog("My dialog",
         self,
         gtk.DIALOG_MODAL | gtk.DIALOG_DESTROY_WITH_PARENT,
         (gtk.STOCK_CANCEL, gtk.RESPONSE_REJECT,
         gtk.STOCK_OK, gtk.RESPONSE_ACCEPT))
      label = gtk.Label("Simple dialog")
      dialog.vbox.add(label)
      label.show()
      res = dialog.run()
      print res
      dialog.destroy()
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

पूर्वनिर्धारित संवाद विजेट

PyGTK एपीआई में कई पूर्व-संवाद डायलॉग विजेट हैं -

  • MessageDialog
  • AboutDialog
  • ColorSelectionDialog
  • FontSelectionDialog
  • FileChooserDialog

PyGTK में उपरोक्त मानक संवाद के कामकाज को प्रदर्शित करने के लिए, मेनू आइटम के साथ एक मेनू जिसमें प्रत्येक आइटम पर क्लिक करते समय एक डायलॉग का आह्वान किया जाता है, को निम्न कार्यक्रम में एक gtk.Window में डाला जाता है। कॉलबैक फ़ंक्शन प्रत्येक मेनू आइटम के सिग्नल को सक्रिय करने के लिए सूचीबद्ध है। आप प्रत्येक प्रकार के संवाद विजेट के लिए दिए गए स्पष्टीकरण को भी समझ सकते हैं।

उदाहरण

निम्नलिखित कोड देखें -

import gtk, pango

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Dialog Boxes")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      
      mb = gtk.MenuBar()
      menu1 = gtk.Menu()
      file = gtk.MenuItem("_File")
      file.set_submenu(menu1)
      msg = gtk.MenuItem("MessageDialog")
      
      menu1.append(msg)
      abt = gtk.MenuItem("AboutDialog")
      menu1.append(abt)
      colo = gtk.MenuItem("colorDialog")
      menu1.append(colo)
      font = gtk.MenuItem("FontSelectionDialog")
      menu1.append(font)
      fl = gtk.MenuItem("FileChooserDialog")
      menu1.append(fl)
      mb.append(file)
      
      vbox = gtk.VBox(False, 2)
      vbox.pack_start(mb, False, False, 0)
      self.add(vbox)
      self.text = gtk.Label("TutorialsPoint")
      vbox.pack_start(self.text, True, True, 0)
      msg.connect("activate",self.on_msgdlg)
      abt.connect("activate",self.on_abtdlg)
      font.connect("activate",self.on_fntdlg)
      colo.connect("activate",self.on_color)
      
      fl.connect("activate", self.on_file)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
   def on_msgdlg(self, widget):
      #MessageDialog usage code
   def on_abtdlg(self, widget):
      #AboutDialog usage code
   def on_fntdlg(self,widget):
      #FontSelectionDialog usage code
   def on_color(self, widget):
      #ColorChooserDialog usage cde
   Def on_file(self, widget):
      #FileChooserDialog usage code
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

एक मेसेडेडियलॉग विजेट एक डायलॉग विंडो है जो एक छवि को प्रदर्शित करने के लिए कॉन्फ़िगर किया गया है, जो संदेश के प्रकार, अर्थात, त्रुटि, प्रश्न, या कुछ सूचना पाठ का प्रतिनिधित्व करता है। MessageDialog ऑब्जेक्ट को निम्न कंस्ट्रक्टर का उपयोग करके घोषित किया जाता है -

gtk.MessageDialog(parent = None, flags = 0, type = gtk.MESSAGE_INFO, 
   buttons = gtk.BUTTONS_NONE, message_format = None)

निम्न पूर्वनिर्धारित संदेश प्रकार का उपयोग संदेश संवाद को कॉन्फ़िगर करने के लिए किया जाता है -

gtk.MESSAGE_INFO यह एक सूचनाप्रद संदेश है
gtk.MESSAGE_WARNING यह एक गैर-घातक चेतावनी संदेश है
gtk.MESSAGE_QUESTION इस प्रश्न के लिए एक विकल्प की आवश्यकता है
gtk.MESSAGE_ERROR यह एक घातक त्रुटि संदेश है

उपयोग के लिए पूर्वनिर्धारित बटन सेट का एक सेट भी उपलब्ध है।

gtk.BUTTONS_NONE कोई बटन नहीं
gtk.BUTTONS_OK यह एक ओके बटन है
gtk.BUTTONS_CLOSE यह क्लोज बटन है
gtk.BUTTONS_CANCEL यह एक रद्द करें बटन है
gtk.BUTTONS_YES_NO ये यस और नो बटन हैं
gtk.BUTTONS_OK_CANCEL ये ओके और कैंसल बटन हैं

जब MessageBox मेनू आइटम सक्रिय होता है, तो निम्न कॉलबैक फ़ंक्शन को कॉल किया जाता है और एक संदेश बॉक्स आउटपुट के रूप में पॉप अप होता है।

def on_msgdlg(self, widget):
   md = gtk.MessageDialog(self,
      gtk.DIALOG_DESTROY_WITH_PARENT, gtk.MESSAGE_ERROR,
      gtk.BUTTONS_CLOSE, "Error message")
   md.run()

उपरोक्त फ़ंक्शन निम्न आउटपुट उत्पन्न करेगा -

अपने लोगो, नाम, कॉपीराइट, वेबसाइट और लाइसेंस जैसे कार्यक्रम के बारे में जानकारी प्रदर्शित करने का एक सरल तरीका gtk.AboutDogog विजेट द्वारा पेश किया गया है। उपयोगकर्ता के चयन के समय संवाद के बारे में आमतौर पर खोला जाता हैAbout से विकल्प Helpमेन्यू। संवाद के सभी भाग वैकल्पिक हैं।

About Dialogइसमें URL और ईमेल पते हो सकते हैं। जब उपयोगकर्ता URL और ईमेल आईडी पर क्लिक करता है तो gtk.AboutDialog वैश्विक हुक प्रदान करता है

निम्नलिखित gtk.AboutDialog वर्ग का एक निर्माता है -

dlg = gtk.AboutDialog()

को कॉन्फ़िगर करने के लिए निम्न विधियों का उपयोग किया जाता है About Dialog

  • set_program_name() - यह नाम प्रदर्शित करने के लिए सेट करता है About Dialog। डिफॉल्ट में application_name ()।

  • set_version() - यह "संस्करण" संपत्ति सेट करता है

  • set_copyright()- यह "कॉपीराइट" सेट करता है। अगरNone, कॉपीराइट नोटिस छिपा हुआ है।

  • set_license()- यह "लाइसेंस" सेट करता है। अगरNone, लाइसेंस बटन छिपा हुआ है।

  • set_website() - यह "वेबसाइट" संपत्ति को स्ट्रिंग पर सेट करता है जो एक मान्य URL होना चाहिए।

  • set_author() - यह "लेखकों" की संपत्ति को माध्यमिक क्रेडिट संवाद के लेखक टैब में प्रदर्शित लेखक नामों की सूची में सेट करता है।

  • set_logo()- यह पिक्सबॉफ ऑब्जेक्ट के लिए "लोगो" प्रॉपर्टी सेट करता है। यदि कोई नहीं है, तो डिफ़ॉल्ट विंडो आइकन सेट का उपयोग किया जाएगा।

जब AboutDialog मेनू बटन क्लिक किया जाता है, तो निम्न कॉलबैक फ़ंक्शन कहा जाता है। इस समारोह के बारे में संवाद उत्पन्न करता है -

def on_abtdlg(self, widget):
   
   about = gtk.AboutDialog()
   about.set_program_name("PyGTK Dialog")
   about.set_version("0.1")
   about.set_authors("M.V.Lathkar")
   about.set_copyright("(c) TutorialsPoint")
   about.set_comments("About Dialog example")
   about.set_website("http://www.tutorialspoint.com")
   
   about.run()
   about.destroy()

उपरोक्त फ़ंक्शन निम्न आउटपुट उत्पन्न करता है -

Gtk.FontSelection विजेट उपयोगकर्ताओं को किसी विशेष नाम, आकार और शैली के फ़ॉन्ट को चुनने और लागू करने की अनुमति देता है। संवाद में एक पूर्वावलोकन बॉक्स है जिसमें कुछ टेक्स्ट हैं जो चयनित फ़ॉन्ट विवरण और दो बटन CANCEL और OK में प्रदर्शित होंगे।

PyGTK API में एक Pango मॉड्यूल होता है जो उच्च गुणवत्ता वाले अंतर्राष्ट्रीयकृत पाठ को रेंडर करने के लिए आवश्यक कक्षाओं और कार्यक्षमता को परिभाषित करता है। Gtk में फ़ॉन्ट और टेक्स्ट हैंडलिंग Pango द्वारा समर्थित है। Pango.Font ऑब्जेक्ट सिस्टम स्वतंत्र रूप से एक फ़ॉन्ट का प्रतिनिधित्व करता है। Pango.FontDescription ऑब्जेक्ट में एक फ़ॉन्ट की विशेषताएं समाहित हैं।

gtk.FontSelectionDialog एक pango.Font ऑब्जेक्ट देता है। चयनित फ़ॉन्ट को लागू करने के लिए, फांटमेट्रिक्स को pango.FontDescription ऑब्जेक्ट से प्राप्त करके प्राप्त किया जाता है।

निम्नलिखित FontSelectionDialog वर्ग का एक निर्माता है -

dlg = gtk.FontSelectionDialog(title)

इस वर्ग की कुछ अक्सर इस्तेमाल की जाने वाली विधियाँ हैं -

  • get_font_name() - यह एक स्ट्रिंग देता है जिसमें वर्तमान में चयनित फ़ॉन्ट नाम या कोई नहीं अगर कोई फ़ॉन्ट नाम चयनित नहीं है।

  • set_font_name() - यह वर्तमान फ़ॉन्ट सेट करता है

  • set_preview_text() - यह टेक्स्ट को प्रीव्यू एरिया एंट्री में सेट करता है

चयनित फॉन्ट को संशोधित_फोंट () विधि का उपयोग करके विजेट में पाठ पर लागू किया जाता है।

जब FontSelectionDialog मेनू आइटम सक्रिय होता है, तो निम्न कॉलबैक फ़ंक्शन को आमंत्रित किया जाता है -

def on_abtdlg(self, widget):
   about = gtk.AboutDialog()
   about.set_program_name("PyGTK Dialog")
   about.set_version("0.1")
   about.set_authors("M.V.Lathkar")
   about.set_copyright("(c) TutorialsPoint")
   about.set_comments("About Dialog example")
   about.set_website("http://www.tutorialspoint.com")
   about.run()
   about.destroy()

चयनित फ़ॉन्ट को tovelvel विंडो पर रखे गए लेबल के पाठ पर लागू किया जाता है।

निम्नलिखित उत्पादन है -

यह PyGTK एपीआई में एक प्री-कॉन्फ़िगर किया गया डायलॉग है जो उपयोगकर्ता को रंग का चयन करने और लागू करने की अनुमति देता है। यह आंतरिक रूप से एक gtk.ColorSelection विजेट एम्बेड करता है।

Gtk.ColorScelection विजेट एक colow व्हील, और HSV और RGB जैसे रंग मापदंडों के लिए प्रवेश बॉक्स प्रस्तुत करता है। रंग पहिया में हेरफेर या रंग मापदंडों में प्रवेश करके नए रंग का चयन किया जा सकता है। इसका get_current_color आगे की प्रक्रिया के लिए उपयोगी है।

निम्नलिखित gtk.ColorSelectionDialog वर्ग के निर्माता का प्रोटोटाइप है -

dlg = gtk.ColorSelectionDialog(title)

वर्तमान चयनित रंग को Colorel विशेषता से प्राप्त किया जाता है। चयनित रंग को संशोधित_फग () या संशोधित_बग () विधियों का उपयोग करके एक विजेट पर लागू किया जाता है।

जब ColorDialog मेनू बटन सक्रिय होता है, तो निम्नलिखित कॉलबैक फ़ंक्शन निष्पादित होता है -

def on_color(self, widget):
   dlg = gtk.ColorSelectionDialog("Select color")
   col = dlg.run()
   sel = dlg.colorsel.get_current_color()
   self.text.modify_fg(gtk.STATE_NORMAL, sel)

चुना हुआ रंग खिड़की पर एक लेबल विजेट में पाठ पर लागू होता है -

निम्नलिखित उत्पादन है -

यह संवाद उपयोगकर्ता को स्थान और फ़ाइल के नाम का चयन करने के लिए उपयोगी है जिसे खोलने या सहेजने की आवश्यकता है। यह FileChooserWidget को एम्बेड करता है और Action_area में OK और CANCEL बटन प्रदान करता है।

निम्नलिखित gtk.FileChooserDialog वर्ग का एक निर्माता है -

Dlg=gtk.FileChooserDialog (title = None, parent = None, 
   action = gtk.FILE_CHOOSER_ACTION_OPEN,  buttons = None, backend = None)

पैरामीटर हैं -

शीर्षक यह संवाद का शीर्षक है
माता-पिता संवाद के क्षणिक जनक, या कोई नहीं
कार्य डायलॉग के लिए ओपन या सेव मोड
बटन यह एक टपल है जिसमें बटन लेबल-प्रतिक्रिया आईडी जोड़े या कोई नहीं है
बैकएंड विशिष्ट फ़ाइल सिस्टम का नाम उपयोग करने के लिए बैकएंड करता है।

एक्शन मोड निम्नलिखित हैं -

  • gtk.FILE_CHOOSER_ACTION_OPEN
  • gtk.FILE_CHOOSER_ACTION_SAVE
  • gtk.FILE_CHOOSER_ACTION_SELECT_FOLDER
  • gtk.FILE_CHOOSER_ACTION_CREATE_FOLDER

यदि यह प्रदर्शित करने के लिए उपलब्ध फ़ाइलों के प्रकार को प्रतिबंधित करना चाहता है, तो gtk.FileFilter का एक ऑब्जेक्ट add_filter () विधि का उपयोग करके लागू किया जा सकता है।

यदि FileChooserDialog मेनू बटन क्लिक किया जाता है, तो निम्न कॉलबैक फ़ंक्शन चलाया जाता है।

def on_file(self, widget):
   dlg = gtk.FileChooserDialog("Open..", None, gtk.FILE_CHOOSER_ACTION_OPEN,
      (gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL, gtk.STOCK_OPEN, gtk.RESPONSE_OK))
   response = dlg.run()
   self.text.set_text(dlg.get_filename())
   dlg.destroy()

फ़ाइल संवाद से चुनी गई है -

चयनित फ़ाइल टॉपलेवल gtk.Window पर लेबल पर प्रदर्शित होती है -

नोटबुक विजेट एक वर्जित कंटेनर है। इस कंटेनर में प्रत्येक टैब एक अलग पेज रखता है और पेज ओवरलैप्ड तरीके से देखे जाते हैं। टैब के लेबल पर क्लिक करके किसी भी वांछित पृष्ठ को दृश्यमान बनाया जाता है। लेबल को ऊपर या नीचे या बाईं या दाईं ओर प्रदर्शित होने के लिए कॉन्फ़िगर किया जा सकता है। एक कंटेनर विजेट अन्य विजेट के साथ रखा गया है या एक विजेट प्रत्येक पृष्ठ के नीचे रखा गया है।

यदि प्रदर्शित किया जाने वाला डेटा एक दृश्य में बहुत बड़ा है, तो इसे अलग-अलग पृष्ठों में समूहीकृत किया जाता है, प्रत्येक को नोटबुक विजेट के एक टैब के नीचे रखा जाता है। इस प्रकार का नियंत्रण बहुत व्यापक रूप से उपयोग किया जाता है। उदाहरण के लिए इंटरनेट ब्राउजर, विभिन्न टैब में अलग-अलग पेज रेंडर करने के लिए इस टैब्ड डिस्प्ले का उपयोग करता है।

निम्नलिखित gtk.Notebook वर्ग का एक निर्माता है -

gtk.Notebook()

Gtk.Notebook वर्ग के अक्सर उपयोग किए जाने वाले तरीके निम्नलिखित हैं -

  • append_page(child, label)- यह टैब पर लेबल के रूप में tab_label द्वारा निर्दिष्ट विजेट वाले नोटबुक में एक पृष्ठ जोड़ता है। यदि tab_label डिफ़ॉल्ट लेबल का उपयोग करने के लिए कोई नहीं हो सकता है।

  • insert_page(child, label, position) - यह स्थिति द्वारा निर्दिष्ट स्थान पर नोटबुक में एक पृष्ठ सम्मिलित करता है।

  • remove_page(index) - यह निर्दिष्ट इंडेक्स पर एक पेज निकालता है।

  • get_current_page() - यह वर्तमान पृष्ठ का पेज इंडेक्स लौटाता है।

  • set_current_page(index) - यह सूचकांक द्वारा निर्दिष्ट पृष्ठ संख्या पर स्विच करता है।

  • set_show_tabs()- यदि गलत है, तो टैब दिखाई नहीं देंगे। यह डिफ़ॉल्ट रूप से सही है।

  • set_tab_pos(pos)- यह उस किनारे को सेट करता है जिस पर नोटबुक में पृष्ठों को स्विच करने के लिए टैब खींचे जाते हैं। पूर्वनिर्धारित स्थिरांक हैं -

    • gtk.POS_LEFT

    • gtk.POS_RIGHT

    • gtk.POS_TOP

    • gtk.POS_BOTTOM

  • set_tab_label_text(child, text) - यह निर्दिष्ट पाठ के साथ एक नया लेबल बनाता है और इसे पृष्ठ वाले बच्चे के लिए टैब लेबल के रूप में सेट करता है।

Gtk.Notebook विजेट निम्नलिखित सिग्नल का उत्सर्जन करता है -

परिवर्तन वर्तमान-पेज जब पृष्ठ आगे या पृष्ठ पिछड़े अनुरोध जारी किया जाता है तो यह उत्सर्जित होता है
फोकस-टैब इसे तब केंद्रित किया जाता है जब टैबिंग द्वारा फ़ोकस को बदला जाता है।
पेज-योजित यह तब उत्सर्जित होता है जब किसी पृष्ठ को नोटबुक में जोड़ा जाता है।
पेज-हटाया नोटबुक से पृष्ठ हटाने के बाद यह उत्सर्जित होता है।
चयन-पेज नया चाइल्ड पेज चयनित होने पर यह उत्सर्जित होता है।
स्विच-पेज नोटबुक पृष्ठ बदलने पर यह उत्सर्जित होता है।

उदाहरण

निम्नलिखित उदाहरण में, तीन पृष्ठों वाला एक gtk.Notebook, एक gtvel.Wkow में एक निचे रखा गया है। पहला पेज एक VBox रखता है जिसमें एक लेबल और एंट्री फ़ील्ड पैक किया जाता है। 'योग्यता' लेबल वाले दूसरे पृष्ठ में एक HButtonBox है जिसमें तीन परस्पर अनन्य रेडियोबटन विजेट जोड़े गए हैं। तीसरे पृष्ठ में एक TextView ऑब्जेक्ट है। पृष्ठ लेबल शीर्ष पर प्रदर्शित होते हैं।

कोड को ध्यान से देखें -

import gtk
class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Notebook Demo")
      self.set_default_size(250, 200)
		
      nb = gtk.Notebook()
      nb.set_tab_pos(gtk.POS_TOP)
      vbox = gtk.VBox(False, 5)
		
      vb = gtk.VBox()
      hbox = gtk.HBox(True, 3)
		
      valign = gtk.Alignment(0.5,0.25, 0, 0)
      lbl = gtk.Label("Name of student")
		
      vb.pack_start(lbl, True, True, 10)
      text = gtk.Entry()
		
      vb.pack_start(text, True, True, 10)
      valign.add(vb)
		
      vbox.pack_start(valign)
      nb.append_page(vbox)
      nb.set_tab_label_text(vbox, "Name")
      hb = gtk.HButtonBox()
		
      btn1 = gtk.RadioButton(None,"Degree")
      hb.add(btn1)
		
      btn2 = gtk.RadioButton(btn1,"P.G.")
      hb.add(btn2)
		
      btn3 = gtk.RadioButton(btn1,"Doctorate")
      hb.add(btn3)
		
      nb.append_page(hb)
      nb.set_tab_label_text(hb, "Qualification")
		
      tv = gtk.TextView()
      nb.append_page(tv)
      nb.set_tab_label_text(tv, "about")
		
      self.add(nb)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
if __name__ == '__main__':
   PyApp()
   gtk.main()

निष्पादन पर, उपरोक्त कोड तीन पृष्ठों के साथ एक नोटबुक प्रदर्शित करता है -

फ़्रेम वर्ग gtk.Bin वर्ग का एक उपवर्ग है। इसमें रखी गई बाल विजेट के चारों ओर एक सजावटी सीमा है। फ़्रेम में एक लेबल हो सकता है जिसकी स्थिति अनुकूलित की जा सकती है।

निम्न निर्माणकर्ता की सहायता से एक gtk.Frame ऑब्जेक्ट का निर्माण किया जाता है -

frame = gtk.Frame(label = None)

निम्नलिखित gtk.Frame () वर्ग के तरीके हैं -

  • set_label(text) - यह द्वारा निर्दिष्ट के रूप में लेबल सेट करता है text। अगरNoneवर्तमान लेबल हटा दिया गया है।

  • set_label_widget() - यह फ्रेम के लिए लेबल के रूप में gtk.Label के अलावा एक विजेट सेट करता है।

  • set_label_align(x, y) - यह फ्रेम के लेबल विजेट और सजावट के अलाइनमेंट को सेट करता है (डिफॉल्ट्स 0.0 और 0.5 हैं)

  • set_shadow_type() - यह फ्रेम के शैडो टाइप को सेट करता है।

संभावित मूल्य हैं -

  • gtk.SHADOW_NONE
  • gtk.SHADOW_IN
  • gtk.SHADOW_OUT
  • gtk.SHADOW_ETCHED_IN
  • tk.SHADOW_ETCHED_OUT

निम्न कोड फ़्रेम विजेट के कामकाज को दर्शाता है। Gtk.RadioButton की तीन वस्तुओं का एक समूह HButtonBox में रखा गया है।

btn1 = gtk.RadioButton(None,"Degree")
btn2 = gtk.RadioButton(btn1,"P.G.")
btn3 = gtk.RadioButton(btn1,"Doctorate")
hb = gtk.HButtonBox()
hb.add(btn1)
hb.add(btn2)
hb.add(btn3)

बॉक्स के चारों ओर सीमा खींचने के लिए, इसे फ़्रेम विजेट में रखा गया है, और इसे tovelvel विंडो में जोड़ा गया है।

frm = gtk.Frame()
frm.add(hb)
self.add(frm)

उदाहरण

निम्नलिखित कोड देखें -

import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Frame Demo")
      self.set_default_size(250, 200)
      self.set_border_width(5)
      frm = gtk.Frame()
      hb = gtk.HButtonBox()
      btn1 = gtk.RadioButton(None,"Degree")
      hb.add(btn1)
      btn2 = gtk.RadioButton(btn1,"P.G.")
      hb.add(btn2)
      btn3 = gtk.RadioButton(btn1,"Doctorate")
      hb.add(btn3)
      frm.add(hb)
      frm.set_label("Qualifications")
      self.add(frm)
      self.connect("destroy", gtk.main_quit)
      self.show_all()

if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

gtk.AspectFrame वर्ग फ़्रेम वर्ग का एक उपवर्ग है। इस फ्रेम में चाइल्ड विजेट हमेशा अपने पहलू अनुपात (चौड़ाई और ऊँचाई) को बरकरार रखता है, भले ही मुख्य विंडो आकार में हो।

Gtk.AspectFrame विजेट का अनुपात गुण विजेट चौड़ाई: ऊंचाई अनुपात निर्धारित करता है। 0.5 के एक पहलू अनुपात का मतलब है कि चौड़ाई एक आधा ऊंचाई है; 2.0 के एक पहलू अनुपात का अर्थ है कि चौड़ाई दोगुनी है। "अनुपात" संपत्ति के लिए डिफ़ॉल्ट मान 1.0 है।

निम्न वाक्य रचना का उपयोग gtk.AspectFrame वर्ग के निर्माता के लिए किया जाता है -

gtk.AspectFrame (label = None, xalign = 0.5, yalign = 0.5, ratio = 1.0, obey_child = True)

xalignसंपत्ति बच्चे के बाईं ओर क्षैतिज मुक्त स्थान का अंश निर्धारित करती है । 0.0 का मतलब बाईं ओर कोई खाली जगह नहीं है , 1.0 का मतलब बाईं तरफ का सभी खाली स्थान है।

yalignसंपत्ति बच्चे के ऊपर ऊर्ध्वाधर मुक्त स्थान का अंश निर्धारित करती है । 0.0 का मतलब ऊपर की खाली जगह नहीं है, 1.0 का मतलब उपरोक्त सभी खाली जगह है।

यदि फ्रेम की ऊंचाई की चौड़ाई का अनुपात बनाए रखा जाता है obey_child संपत्ति झूठी है।

यदि अनुपात को अनदेखा किया जाना है, तो obey_child संपत्ति निर्धारित करती है। डिफ़ॉल्ट सत्य है।

निम्न कोड फ़्रेम वर्ग के लिए उपयोग किए जाने वाले के समान है। अंतर केवल इतना है कि बुटनबॉक्स को एस्पेक्टफ्रैम विजेट में रखा गया है।

frm = gtk.AspectFrame(label = None, xalign = 0.5, yalign = 0.5, 
   ratio = 5.0, obey_child = False)

Note - obey_child संपत्ति को गलत पर सेट किया गया है क्योंकि विंडो के आकार बदलने पर भी पहलू अनुपात को बनाए रखना वांछित है।

उदाहरण

निम्नलिखित कोड देखें -

import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Aspect Frame Demo")
      self.set_default_size(250, 200)
      self.set_border_width(5)
      frm = gtk.AspectFrame(label = None, xalign = 0.5, yalign = 0.5, 
         ratio = 5.0, obey_child = False)
      hb = gtk.HButtonBox()
      btn1 = gtk.RadioButton(None,"Degree")
      hb.add(btn1)
      btn2 = gtk.RadioButton(btn1,"P.G.")
      hb.add(btn2)
      btn3 = gtk.RadioButton(btn1,"Doctorate")
      hb.add(btn3)
      frm.add(hb)
      frm.set_label("Qualifications")
      self.add(frm)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
      
if __name__ == '__main__':
   PyApp()
   gtk.main()

उपर्युक्त कोड निम्नलिखित मूल और आकारबद्ध विंडो का उत्पादन करेगा -

Original Window

Resized Window

ट्रीव्यू विजेट gtk.TreeModel इंटरफ़ेस को लागू करने वाले एक मॉडल की सामग्री को प्रदर्शित करता है। PyGTK निम्नलिखित प्रकार के मॉडल प्रदान करता है -

  • gtk.ListStore
  • gtk.TreeStore
  • gtk.TreeModelSort

लिस्टस्टोर एक सूची मॉडल है। जब gtk.TreeView विजेट के साथ संबद्ध किया जाता है, तो यह सूची बॉक्स का उत्पादन करता है जिसमें से चयनित आइटम हैं। वाक्य रचना के साथ एक gtk.ListStore ऑब्जेक्ट घोषित किया जाता है -

store = gtk.ListStore(column_type)

एक सूची में कई कॉलम हो सकते हैं, पूर्वनिर्धारित प्रकार स्थिरांक हैं -

  • gobject.TYPE_BOOLEAN
  • gobject.TYPE_BOXED
  • gobject.TYPE_CHAR
  • gobject.TYPE_DOUBLE
  • gobject.TYPE_ENUM
  • gobject.TYPE_FLOAT
  • gobject.TYPE_INT
  • gobject.TYPE_LONG
  • gobject.TYPE_NONE
  • gobject.TYPE_OBJECT
  • gobject.TYPE_STRING
  • gobject.TYPE_UCHAR
  • gobject.TYPE_UINT
  • gobject.TYPE_ULONG
  • gtk.gdk.pixbuf आदि।

उदाहरण के लिए, स्ट्रिंग आइटम को संग्रहीत करने के लिए एक सूचीस्टोर ऑब्जेक्ट के रूप में घोषित किया जाता है -

store = gtk.ListStore(gobject.TYPE_STRING

स्टोर में आइटम जोड़ने के लिए, एपेंड () विधियों का उपयोग किया जाता है -

store.append (["item 1"])

TreeStore मल्टी-कॉलम ट्री विजेट के लिए एक मॉडल है। उदाहरण के लिए, निम्न कथन एक आइटम बनाता है जिसमें स्ट्रिंग आइटम होता है।

Store = gtk.TreeStore(gobject.TYPE_STRING)

ट्रीस्टोर में आइटम जोड़ने के लिए, एपेंड () विधि का उपयोग करें। परिशिष्ट () विधि में दो पैरामीटर हैं, अभिभावक और पंक्ति। टॉपलेवल आइटम जोड़ने के लिए, माता-पिता कोई नहीं है।

row1 = store.append(None, ['row1'])

कई पंक्तियों को जोड़ने के लिए आपको इस कथन को दोहराना होगा।

चाइल्ड रो को जोड़ने के लिए, एपलेंड () विधि के लिए मुख्य पैरामीटर को पैरेंट पैरामीटर के रूप में पास करें -

childrow = store.append(row1, ['child1'])

कई चाइल्ड रो को जोड़ने के लिए आपको इस कथन को दोहराना होगा।

अब, एक TreeView विजेट बनाएँ और मॉडल के रूप में उपरोक्त TreeStore ऑब्जेक्ट का उपयोग करें।

treeview = gtk.TreeView(store)

अब हमें स्टोर डेटा प्रदर्शित करने के लिए TreeViewColumn बनाना होगा। Gtk.TreeViewColumn का उद्देश्य हेडर और gtk.CelRenderer का उपयोग कर कोशिकाओं का प्रबंधन करता है। ट्री व्यूकोल्यूमेंट ऑब्जेक्ट निम्नलिखित कंस्ट्रक्टर का उपयोग करके बनाया गया है -

gtk.TreeViewColumn(title, cell_renderer,…)

शीर्षक और रेंडरर के अलावा, यह निर्दिष्ट करने के लिए शून्य या अधिक विशेषता = कॉलम जोड़े लेता है कि किस ट्री मॉडल कॉलम से विशेषता का मान पुनर्प्राप्त किया जाना है। ये पैरामीटर नीचे दिए गए TreeViewColumn क्लास के तरीकों का उपयोग करके भी सेट किए जा सकते हैं।

एक gtk.CellRenderer विभिन्न प्रकार के डेटा प्रदान करने के लिए वस्तुओं के एक समूह के लिए एक आधार वर्ग है। व्युत्पन्न वर्ग CellRendererText, CellRendererPixBuf और CellRendererToggle हैं।

TreeViewColumn क्लास के निम्नलिखित तरीकों का उपयोग इसकी वस्तु को कॉन्फ़िगर करने के लिए किया जाता है -

  • TreeViewColumn.pack_start (सेल, एक्सपेंड = ट्रू) - यह विधि सेलरेंडर ऑब्जेक्ट को शुरुआती कॉलम में पैक करती है। यदि विस्तार पैरामीटर सही पर सेट है, तो पूरे आवंटित स्थान को कॉलम सेल को सौंपा गया है।

  • TreeViewColumn.add_attribute (सेल, विशेषता, कॉलम) - यह विधि ट्री कॉलम में सूची में एक विशेषता मैपिंग जोड़ती है। column ट्री मॉडल का कॉलम है।

  • TreeViewColumn.set_attributes () - इस विधि के विशेषता स्थानों को सेट करता है renderer का उपयोग करते हुए attribute = column जोड़े

  • TreeViewColumn.set_v अदृश्य () - यदि True, ट्रीव्यू कॉलम दिखाई देता है

  • TreeViewColumn.set_title () - यह विधि निर्दिष्ट मान के लिए "शीर्षक" गुण सेट करती है।

  • TreeViewColumn.set_lickable () - यदि सही पर सेट है, तो हेडर कीबोर्ड फ़ोकस ले सकता है, और क्लिक किया जा सकता है।

  • TreeViewColumn.set_alignment (xalign) - यह विधि "मान" गुण को मान के लिए सेट करती है xalign

"क्लिक किया गया" सिग्नल तब उत्सर्जित किया जाता है जब उपयोगकर्ता ट्रीव्यूकैल्यूमेड हैडर बटन पर क्लिक करता है ।

TreeViewColumn ऑब्जेक्ट को कॉन्फ़िगर करने के बाद, इसे append_column () विधि का उपयोग करके TreeView विजेट में जोड़ा जाता है।

ट्रीव्यू क्लास के महत्वपूर्ण तरीके निम्नलिखित हैं -

  • TreevVew.set_model () - यह ट्रीव्यू के लिए "मॉडल" गुण सेट करता है। यदि ट्रीव्यू में पहले से ही एक मॉडल सेट है, तो यह विधि नए मॉडल को सेट करने से पहले हटा देगी। अगरmodel है None, यह पुराने मॉडल को परेशान करेगा।

  • TreeView.set_header_clickable () - यदि सही पर सेट है, तो कॉलम शीर्षक बटन पर क्लिक किया जा सकता है।

  • TreeView.append_column () - यह निर्दिष्ट करता है TreeViewColumn स्तंभों की सूची

  • TreeView.remove_column () - यह ट्रीव्यू से निर्दिष्ट कॉलम को हटाता है।

  • TreeView.insert_column () - यह निर्दिष्ट को सम्मिलित करता है column द्वारा निर्दिष्ट स्थान पर ट्रीव्यू में position

ट्रीव्यू विजेट निम्नलिखित संकेतों का उत्सर्जन करता है -

कर्सर-बदल कर्सर के चलने या सेट होने पर यह उत्सर्जित होता है।
विस्तार पतन-कर्सर पंक्ति यह उत्सर्जित होता है जब कर्सर पर पंक्ति को विस्तारित या ढहने की आवश्यकता होती है।
पंक्ति सक्रिय जब उपयोगकर्ता डबल क्लिक करता है तो यह उत्सर्जित होता है treeview पंक्ति
पंक्ति-ढह यह तब उत्सर्जित होता है जब कोई पंक्ति उपयोगकर्ता या प्रोग्रामेटिक कार्रवाई द्वारा ढह जाती है।
पंक्ति-विस्तार यह तब उत्सर्जित होता है जब उपयोगकर्ता या प्रोग्रामेटिक एक्शन के माध्यम से एक पंक्ति का विस्तार किया जाता है।

ट्री व्यू विजेट के दो उदाहरण नीचे दिए गए हैं। पहला उदाहरण एक साधारण सूची दृश्य का निर्माण करने के लिए एक सूचीस्टोर का उपयोग करता है।

यहां एक ListStore ऑब्जेक्ट बनाया जाता है और स्ट्रिंग आइटम इसमें जोड़े जाते हैं। यह ListStore ऑब्जेक्ट ट्री व्यू ऑब्जेक्ट के मॉडल के रूप में उपयोग किया जाता है -

store = gtk.ListStore(str)

treeView = gtk.TreeView()
treeView.set_model(store)

तब एक CellRendererText एक TreeViewColumn ऑब्जेक्ट में जोड़ा जाता है और उसी को TreeView में जोड़ा जाता है।

rendererText = gtk.CellRendererText()
column = gtk.TreeViewColumn("Name", rendererText, text = 0)
treeView.append_column(column)

ट्रीव्यू ऑब्जेक्ट को एक स्थिर कंटेनर में जोड़कर सबसे ऊपर की खिड़की पर रखा गया है।

उदाहरण 1

निम्नलिखित कोड देखें -

import pygtk
pygtk.require('2.0')
import gtk

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("TreeView with ListStore")
      self.set_default_size(250, 200)
      self.set_position(gtk.WIN_POS_CENTER)
		
      store = gtk.ListStore(str)
      store.append (["PyQt"])
      store.append (["Tkinter"])
      store.append (["WxPython"])
      store.append (["PyGTK"])
      store.append (["PySide"])
      
      treeView = gtk.TreeView()
      treeView.set_model(store)
		
      rendererText = gtk.CellRendererText()
      column = gtk.TreeViewColumn("Python GUI Libraries", rendererText, text=0)
      treeView.append_column(column)
      
      fixed = gtk.Fixed()
      lbl = gtk.Label("select a GUI toolkit")
      fixed.put(lbl, 25,75)
      fixed.put(treeView, 125,15)
		
      lbl2 = gtk.Label("Your choice is:")
      fixed.put(lbl2, 25,175)
      self.label = gtk.Label("")
		
      fixed.put(self.label, 125,175)
      self.add(fixed)
      
      treeView.connect("row-activated", self.on_activated)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
		
   def on_activated(self, widget, row, col):
      
	  model = widget.get_model()
      text = model[row][0]
      self.label.set_text(text)
		
def main():
   gtk.main()
   return

if __name__ == "__main__":
   bcb = PyApp()
   main()

उपयोगकर्ता द्वारा चयनित आइटम को विंडो में एक लेबल पर प्रदर्शित किया जाता है on_activated callback फ़ंक्शन को लागू किया जाता है।

उदाहरण 2

दूसरा उदाहरण एक ट्रीस्टोर से एक पदानुक्रमित ट्री व्यू बनाता है। यह कार्यक्रम स्टोर के निर्माण के उसी क्रम का अनुसरण करता है, जो ट्रीव्यू के लिए मॉडल के रूप में सेट करता है, ट्री व्यू व्यू को डिजाइन करता है और ट्री व्यू में जोड़ता है।

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      
	  self.set_title("TreeView with TreeStore")
      self.set_size_request(400,200)
      self.set_position(gtk.WIN_POS_CENTER)
      vbox = gtk.VBox(False, 5)
      
      # create a TreeStore with one string column to use as the model
      store = gtk.TreeStore(str)
      
      # add row
      row1 = store.append(None, ['JAVA'])
      
      #add child rows
      store.append(row1,['AWT'])
      store.append(row1,['Swing'])
      store.append(row1,['JSF'])
      
      # add another row
      row2 = store.append(None, ['Python'])
      store.append(row2,['PyQt'])
      store.append(row2,['WxPython'])
      store.append(row2,['PyGTK'])
      
      # create the TreeView using treestore
      treeview = gtk.TreeView(store)
      tvcolumn = gtk.TreeViewColumn('GUI Toolkits')
      treeview.append_column(tvcolumn)
		
      cell = gtk.CellRendererText()
      tvcolumn.pack_start(cell, True)
      tvcolumn.add_attribute(cell, 'text', 0)
      vbox.add(treeview)
		
      self.add(vbox)
      
	  self.connect("destroy", gtk.main_quit)
      self.show_all()

PyApp()
gtk.main()

निम्नलिखित TreeView एक उत्पादन के रूप में प्रदर्शित किया जाता है -

पैनड क्लास विगेट्स के लिए बेस क्लास है जो दो समायोज्य पैन को क्षैतिज रूप से प्रदर्शित कर सकता है (gtk.Hpaned) या लंबवत (gtk.Vpaned)। Pan1 में चाइल्ड विजेट्स को pack1 () और pack2 () विधियों का उपयोग करके जोड़ा जाता है।

पैनड विजेट दो पैन के बीच एक विभाजक स्लाइडर खींचता है और उनके सापेक्ष चौड़ाई / ऊंचाई को समायोजित करने के लिए एक हैंडल प्रदान करता है। यदि फलक के अंदर चाइल्ड विजेट की रिसाइज़ प्रॉपर्टी ट्रू पर सेट है, तो यह पैन के आकार के अनुसार आकार देगा।

निम्नलिखित तरीके HPaned के साथ-साथ VPaned वर्ग के लिए उपलब्ध हैं -

  • Paned.add1 (बच्चा) - यह निर्दिष्ट विजेट को जोड़ता है child ऊपर या बाएँ फलक पर

  • Paned.add2 (बच्चा) - यह द्वारा निर्दिष्ट विजेट जोड़ता है child नीचे या दाएँ फलक में।

  • Paned.pack1 (बच्चा, आकार, छोटा करें) - इसके द्वारा निर्दिष्ट विजेट जोड़ता है childमापदंडों के साथ शीर्ष या बाएँ फलक पर। अगरresize है True, childपैन किए गए विजेट का आकार बदलने पर आकार बदलना चाहिए। अगरshrink है True, child अपने न्यूनतम आकार के अनुरोध से छोटा किया जा सकता है।

  • Paned.pack2 (बच्चा, आकार, सिकुड़ना) - यह दो पैन के बीच विभक्त की स्थिति निर्धारित करता है।

दोनों प्रकार के पैनड विगेट्स निम्नलिखित संकेतों का उत्सर्जन करते हैं -

स्वीकार स्थिति यह कब उत्सर्जित होता है paned फोकस के कारण चाइल्ड विजेट सक्रिय होने पर फोकस होता है।
रद्द स्थिति यह उत्सर्जित होता है जब Esc कुंजी दबाया जाता है, जबकि paned ध्यान केंद्रित किया है।
कदम-संभाल यह कब उत्सर्जित होता है paned फोकस और विभाजक को स्थानांतरित कर दिया गया है।

उदाहरण

निम्न उदाहरण gtk.Hpaned विजेट का उपयोग करता है। बाएँ फलक में, एक TreeView विजेट जोड़ा गया है, और दाएँ फलक में, एक TextView विजेट है। जब ट्री व्यू में कोई भी पंक्ति चुनी जाती है, तो यह row_activated सिग्नल का उत्सर्जन करेगा जो कॉलबैक फ़ंक्शन से जुड़ा होता है। on_activated()function पंक्ति के पाठ को पुनः प्राप्त करता है और पाठ दृश्य पैनल में प्रदर्शित करता है।

कोड को ध्यान से देखें -

import gtk, gobject

class PyApp(gtk.Window):
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("HPaned widget Demo")
      self.set_default_size(250, 200)
      vp = gtk.HPaned()
      sw = gtk.ScrolledWindow()
      sw.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC) 
		
      tree = gtk.TreeView()
      languages = gtk.TreeViewColumn()
      languages.set_title("GUI Toolkits")
      cell = gtk.CellRendererText()
      languages.pack_start(cell, True)
      languages.add_attribute(cell, "text", 0)
      treestore = gtk.TreeStore(str)
      it = treestore.append(None, ["Python"])
		
      treestore.append(it, ["PyQt"])
      treestore.append(it, ["wxPython"])
      treestore.append(it, ["PyGTK"])
      treestore.append(it, ["Pydide"])
		
      it = treestore.append(None, ["Java"])
      treestore.append(it, ["AWT"])
      treestore.append(it, ["Swing"])
      treestore.append(it, ["JSF"])
      treestore.append(it, ["SWT"])
		
      tree.append_column(languages)
      tree.set_model(treestore)
		
      vp.add1(tree)
      self.tv = gtk.TextView()
      vp.add2(self.tv)
      vp.set_position(100)
      self.add(vp)
		
      tree.connect("row-activated", self.on_activated)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
		
   def on_activated(self, widget, row, col):
      model = widget.get_model()
      text = model[row][0]
      print text
		
      buffer = gtk.TextBuffer()
      buffer.set_text(text+" is selected")
      self.tv.set_buffer(buffer)

if __name__ == '__main__':
   PyApp()
   gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

एक अधिसूचना क्षेत्र, आमतौर पर एक खिड़की के नीचे स्थित स्थिति बार कहा जाता है। किसी भी प्रकार की स्थिति परिवर्तन संदेश स्थिति पट्टी पर प्रदर्शित किया जा सकता है। इसकी एक पकड़ भी है जिसका उपयोग करके इसे आकार दिया जा सकता है।

Gtk.Statusbar विजेट संदेशों के ढेर को बनाए रखता है। इसलिए, वर्तमान संदेश के शीर्ष पर नया संदेश प्रदर्शित होता है। यदि यह पॉप अप होता है, तो पहले वाला संदेश फिर से दिखाई देगा। संदेश का स्रोत इसे विशिष्ट रूप से पहचानने के लिए reference_id द्वारा पहचाना जाना चाहिए।

निम्नलिखित gtk.Statusbar विजेट का निर्माता है -

bar = gtk.Statusbar()

Gtk.Statusbar वर्ग के तरीके निम्नलिखित हैं -

  • Statusbar.push(context_id, text) - यह एक स्टेटसबार के स्टैक पर एक नया संदेश देता है।

  • Statusbar.pop(context_id) - यह निर्दिष्ट के साथ शीर्ष संदेश को हटा देता है context_id स्टेटसबार के ढेर से।

निम्न संकेतों को स्थिति पट्टी विजेट द्वारा उत्सर्जित किया जाता है -

पाठ पॉपअप यह तब उत्सर्जित होता है जब किसी संदेश को स्टेटसबार संदेश स्टैक से हटा दिया जाता है।
पाठ धक्का दिया यह तब उत्सर्जित होता है जब किसी संदेश को स्टेटसबार संदेश स्टैक में जोड़ा जाता है।

निम्न उदाहरण स्थिति पट्टी के कामकाज को प्रदर्शित करता है। टॉपलेवल विंडो में दो पंक्तियों के साथ एक VBox होता है। ऊपरी पंक्ति में एक निश्चित विजेट होता है जिसमें एक लेबल, एक एंट्री विजेट और एक बटन लगा होता है। जबकि, निचली पंक्ति में, एक gtk.Statusbar विजेट जोड़ा जाता है।

संदेश को स्टेटस बार में भेजने के लिए, इसके संदर्भ_ की आवश्यकता है।

id1 = self.bar.get_context_id("Statusbar")

बटन ऑब्जेक्ट का 'क्लिक किया गया' सिग्नल एक कॉलबैक फ़ंक्शन से जुड़ा है, जिसके माध्यम से एक संदेश स्थिति पट्टी में धकेल दिया जाता है। और, एंट्री विजेट के अंदर एंटर की दबाए जाने पर 'एक्टिवेट' सिग्नल उत्सर्जित होता है। यह विजेट दूसरे कॉलबैक से जुड़ा है।

btn.connect("clicked", self.on_clicked, id1)
txt.connect("activate", self.on_entered, id1)

दोनों कॉलबैक का उपयोग करते हैं push() अधिसूचना क्षेत्र में संदेश को फ्लैश करने की विधि।

उदाहरण

निम्नलिखित कोड देखें -

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Statusbar demo")
      self.set_size_request(400,200)
      self.set_position(gtk.WIN_POS_CENTER)
		
      vbox = gtk.VBox()
      fix = gtk.Fixed()
      lbl = gtk.Label("Enter name")
		
      fix.put(lbl, 175, 50)
      txt = gtk.Entry()
      fix.put(txt, 150, 100)
		
      btn = gtk.Button("ok")
      fix.put(btn, 200,150)
		
      vbox.add(fix)
      self.bar = gtk.Statusbar()
      vbox.pack_start(self.bar, True, False, 0)
		
      id1 = self.bar.get_context_id("Statusbar")
      btn.connect("clicked", self.on_clicked, id1)
      txt.connect("activate", self.on_entered, id1)
		
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
		
      def on_clicked(self, widget, data=None):
         self.bar.push(data, "Button clicked
		
      def on_entered(self, widget, data):
         self.bar.push(data, "text entered")

PyApp()
gtk.main()

निष्पादन के बाद, उपरोक्त कोड निम्नलिखित आउटपुट प्रदर्शित करेगा -

टेक्स्ट बॉक्स में टाइप करने की कोशिश करें और स्टेटस बार में 'टेक्स्ट एंटर' संदेश देखने के लिए एंटर दबाएं।

प्रगति पट्टियों का उपयोग उपयोगकर्ता को एक लंबी चलने वाली प्रक्रिया के दृश्य संकेत देने के लिए किया जाता है। Gtk.ProgressBar विजेट को दो मोडों - प्रतिशत मोड और गतिविधि मोड में उपयोग किया जा सकता है।

जब यह सटीक रूप से अनुमान लगाना संभव हो जाए कि कितना काम पूरा होने के लिए लंबित है, तो प्रगति बार का उपयोग प्रतिशत मोड में किया जा सकता है, और उपयोगकर्ता एक वृद्धिशील बार देखता है जो पूर्ण कार्य का प्रतिशत दिखाता है। यदि दूसरी ओर, पूरा होने वाले काम की मात्रा को सटीक रूप से निर्धारित किया जा सकता है, तो प्रगति बार का उपयोग गतिविधि मोड में किया जाता है, जिसमें बार आगे और पीछे एक ब्लॉक प्रदर्शित करके गतिविधि को दिखाता है।

निम्नलिखित कंस्ट्रक्टर gtk.ProgressBar वर्ग के विजेट को आरंभीकृत करता है -

pb = gtk.ProgressBar()

gtk.ProgressBar कार्यक्षमता को प्रबंधित करने के लिए निम्न विधियों का उपयोग करता है -

  • ProgressBar.pulse()- यह प्रगति करने वाले को इंगित करता है कि कुछ प्रगति हुई है, लेकिन आप नहीं जानते कि कितना। यह विधि प्रगति बार मोड को "गतिविधि मोड" में भी बदलती है, जहां एक ब्लॉक आगे और पीछे उछलता है।

  • ProgressBar.set_fraction(fraction) - इसके द्वारा निर्दिष्ट बार के हिस्से को "भरने" के लिए प्रगति बार का कारण बनता है fraction। का मूल्यfraction 0.0 और 1.0 के बीच होना चाहिए।

  • ProgressBar.set_pulse_setup() - यह भाग (द्वारा निर्दिष्ट) सेट करता है fractionप्रत्येक कॉल के लिए शेख़ी ब्लॉक को स्थानांतरित करने के लिए कुल प्रगति बार लंबाई की) pulse() तरीका।

  • ProgressBar.set_orientation()- यह प्रगति बार के उन्मुखीकरण को निर्धारित करता है। इसे निम्नलिखित स्थिरांक में से एक में सेट किया जा सकता है:

    • gtk.PROGRESS_LEFT_TO_RIGHT

    • gtk.PROGRESS_RIGHT_TO_LEFT

    • gtk.PROGRESS_BOTTOM_TO_TOP

    • gtk.PROGRESS_TOP_TO_BOTTOM

निम्न प्रोग्राम में, gtk.ProgressBar विजेट का उपयोग गतिविधि मोड में किया जाता है। इसलिए, प्रगति की प्रारंभिक स्थिति 0.0 से निर्धारित हैset_fraction() तरीका।

self.pb = gtk.ProgressBar()
self.pb.set_text("Progress")
self.pb.set_fraction(0.0)

100 मिलीसेकंड के बाद प्रगति को 1 प्रतिशत बढ़ाने के लिए, एक टाइमर ऑब्जेक्ट घोषित किया जाता है और प्रत्येक 100 एमएस के बाद कॉलबैक फ़ंक्शन को सेट किया जाता है ताकि प्रगति बार अपडेट हो।

self.timer = gobject.timeout_add (100, progress_timeout, self)

यहाँ, progress_timeout()कॉलबैक फ़ंक्शन है। यह के पैरामीटर को बढ़ाता हैset_fraction() 1 प्रतिशत की विधि और पूर्णता का प्रतिशत दिखाने के लिए प्रगति बार में टेक्स्ट को अपडेट करता है।

def progress_timeout(pbobj):
   new_val = pbobj.pb.get_fraction() + 0.01
   pbobj.pb.set_fraction(new_val)
   pbobj.pb.set_text(str(new_val*100)+" % completed")
   return True

उदाहरण

निम्नलिखित कोड देखें -

import gtk, gobject
   
def progress_timeout(pbobj):
   new_val = pbobj.pb.get_fraction() + 0.01
   pbobj.pb.set_fraction(new_val)
   pbobj.pb.set_text(str(new_val*100)+" % completed")
   return True

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Progressbar demo")
      self.set_size_request(300,200)
      self.set_position(gtk.WIN_POS_CENTER)
		
      fix = gtk.Fixed()
      self.pb = gtk.ProgressBar()
      self.pb.set_text("Progress")
      self.pb.set_fraction(0.0)
		
      fix.put(self.pb,80,100)
      self.add(fix)
      self.timer = gobject.timeout_add (100, progress_timeout, self)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

गतिविधि मोड में प्रगति बार का उपयोग करने के लिए, कॉलबैक फ़ंक्शन को निम्न और रन में बदलें -

def progress_timeout(pbobj):
   pbobj.pb.pulse()
   return True

प्रगति पट्टी के अंदर एक ब्लॉक के आगे और पीछे की गतिविधि गतिविधि की प्रगति को दिखाएगी।

यदि किसी विजेट का टॉपलेवल विंडो से बड़ा क्षेत्र होता है, तो वह व्यूपोर्ट कंटेनर से जुड़ा होता है। एक gtk.Viewport विजेट स्क्रॉलडाइंडो में उपयोग की जाने वाली समायोजन क्षमता प्रदान करता है। उदाहरण के लिए एक लेबल विजेट, कोई समायोजन नहीं है। इसलिए इसे व्यूपोर्ट की जरूरत है। कुछ विगेट्स में एक देशी स्क्रॉलिंग सपोर्ट है। लेकिन एक लेबल या एक gtk.Table विजेट में एक अंतर्निहित स्क्रॉल समर्थन नहीं है। इसलिए उन्हें व्यूपोर्ट का उपयोग करना चाहिए।

व्यूपोर्ट वर्ग में निम्नलिखित निर्माता हैं -

gtk.Viewport(hadj, vadj)

यहाँ, hadj तथा vadj व्यूपोर्ट के साथ समायोजन ऑब्जेक्ट जुड़े हुए हैं।

gtk.ViewPort वर्ग निम्नलिखित विधियों का उपयोग करता है -

  • Viewport.set_hadjustment() - यह "हेसिडमेंट" संपत्ति सेट करता है

  • Viewport.set_vadjustment() - यह "vadjustment" संपत्ति सेट करता है

  • Viewport.set_shadow_type() - यह "छाया-प्रकार" संपत्ति के मूल्य को निर्धारित करता है type। का मूल्यtype इनमें से एक होना चाहिए -

    • gtk.SHADOW_NONE

    • gtk.SHADOW_IN

    • gtk.SHADOW_OUT

    • gtk.SHADOW_ETCHED_IN

    • gtk.SHADOW_ETCHED_OUT

Gtk.Viewport ऑब्जेक्ट क्षैतिज और ऊर्ध्वाधर gtk.Adjustment ऑब्जेक्ट में से एक या दोनों को बदलने पर सेट-स्क्रॉल-एडजस्टमेंट सिग्नल का उत्सर्जन करता है।

स्क्रॉल विंडो को पैरेंट विंडो से बड़े क्षेत्र के अन्य विजेट तक पहुंचने के लिए बनाया गया है। स्क्रॉलिंग के लिए कुछ विजेट जैसे ट्रीव्यू और टेक्स्टवेज़ देशी समर्थन के हैं। दूसरों के लिए जैसे लेबल या तालिका, एक व्यूपोर्ट प्रदान किया जाना चाहिए।

निम्नलिखित सिंटैक्स का उपयोग gtk.ScrolledWindow वर्ग के निर्माता के लिए किया जाता है -

sw = gtk.ScrolledWindow(hadj, vadj)

निम्नलिखित gtk.ScrolledWindow वर्ग की विधियाँ हैं -

  • ScrolledWindow.set_hadjustment() - यह एक gtk.Adjustment ऑब्जेक्ट के लिए क्षैतिज समायोजन सेट करता है

  • ScrolledWindow.set_vadjustment() - यह एक gtk.Adjustment ऑब्जेक्ट के लिए ऊर्ध्वाधर समायोजन सेट करता है

  • ScrolledWindow.set_Policy (hpolicy, vpolicy)- यह "hscrollbar_policy" और "vscrollbar_policy" गुण सेट करता है। निम्नलिखित में से एक पूर्वनिर्धारित स्थिरांक का उपयोग किया जाता है -

    • gtk.POLICY_ALWAYS - स्क्रॉलबार हमेशा मौजूद होता है

    • gtk.POLICY_AUTOMATIC - स्क्रॉलबार तब ही मौजूद होता है, जब जरूरत होती है यानी सामग्री विंडो से अधिक बड़ी होती है

    • gtk.POLICY_NEVER - स्क्रॉलबार कभी मौजूद नहीं होता है

  • ScrolledWindow.add_with_viewport(child) - इस पद्धति का उपयोग स्क्रॉल किए गए विंडो में देशी स्क्रॉलिंग क्षमताओं के बिना एक विजेट (बच्चे द्वारा निर्दिष्ट) को जोड़ने के लिए किया जाता है। यह एक सुविधा फ़ंक्शन है जो जोड़ने के बराबर हैchild को gtk.Viewport, तो स्क्रॉल किए गए विंडो में व्यूपोर्ट को जोड़ना।

निम्न कोड में gtk.Table ऑब्जेक्ट के चारों ओर एक स्क्रॉल विंडो को 10 आयामों के साथ जोड़ा जाता है। चूंकि टेबल ऑब्जेक्ट स्वचालित रूप से समायोजन का समर्थन नहीं करता है, इसलिए इसे व्यूपोर्ट में जोड़ा जाता है।

sw = gtk.ScrolledWindow()
table = gtk.Table(10,10)

दो नेस्टेड छोरों का उपयोग प्रत्येक 10 कॉलम की 10 पंक्तियों को जोड़ने के लिए किया जाता है। प्रत्येक सेल में एक gtk.Button विजेट रखा गया है।

for i in range(1,11):
   for j in range(1,11):
      caption = "Btn"+str(j)+str(i)
      btn = gtk.Button(caption)
      table.attach(btn, i, i+1, j, j+1)

इस बड़ी पर्याप्त तालिका को अब स्क्रॉलपोर्ट विंडो में व्यूपोर्ट के साथ जोड़ा गया है।

sw.add_with_viewport(table)

उदाहरण

निम्नलिखित कोड देखें -

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      
	  self.set_title("ScrolledWindow and Viewport")
      self.set_size_request(400,300)
      self.set_position(gtk.WIN_POS_CENTER)
      sw = gtk.ScrolledWindow()
      table = gtk.Table(10,10)
      table.set_row_spacings(10)
      table.set_col_spacings(10)
      for i in range(1,11):
         for j in range(1,11):
            caption = "Btn"+str(j)+str(i)
            btn = gtk.Button(caption)
            table.attach(btn, i, i+1, j, j+1)
      sw.add_with_viewport(table)
      self.add(sw)
      
	  self.connect("destroy", gtk.main_quit)
      self.show_all()

PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

Gtk.Arrow ऑब्जेक्ट का उपयोग चार कार्डिनल दिशाओं की ओर इंगित करने वाले सरल तीर को खींचने के लिए किया जाता है। यह वर्ग विरासत में मिला हैgtk.Misc क्लास और ऑब्जेक्ट किसी भी स्थान को आवंटित करेगा, उदाहरण के लिए, एक लेबल या बटन विजेट।

आमतौर पर, एरो ऑब्जेक्ट निम्नलिखित कंस्ट्रक्टर का उपयोग करके बनाया जाता है -

Arr = gtk.Arrow(arrow_type, shadow_type)

पूर्वनिर्धारित arrow_type स्थिरांक हैं -

  • gtk.ARROW_UP
  • gtk.ARROW_DOWN
  • gtk.ARROW_LEFT
  • gtk.ARROW_RIGHT

पूर्वनिर्धारित शैडो_टाइप स्थिरांक निम्न तालिका में सूचीबद्ध हैं -

gtk.SHADOW_NONE कोई रूपरेखा नहीं।
gtk.SHADOW_IN रूपरेखा अंदर की ओर झुकी हुई है।
gtk.SHADOW_OUT रूपरेखा एक बटन की तरह बाहर की ओर उभरी हुई है।
gtk.SHADOW_ETCHED_IN रूपरेखा स्वयं एक आवक बेवल है, लेकिन फ़्रेम बाहर की ओर बेवल है।
gtk.SHADOW_ETCHED_OUT रूपरेखा एक बाहरी बेवल है, फ्रेम बेवल इनवर्ड।

उदाहरण

निम्नलिखित उदाहरण में, चार बटन विजेट एक एचबॉक्स में जोड़े जाते हैं। प्रत्येक बटन के ऊपर, एक gtk.Arrow ऑब्जेक्ट जो क्रमशः UP, DOWN, LEFT और RIGHT को दर्शाता है। एचबीओएक्स कंटेनर को एलाइनमेंट कंटेनर की मदद से टॉपवेल विंडो के नीचे रखा गया है।

कोड को ध्यान से देखें -

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Arrow Demo")
      self.set_size_request(300, 200)
      self.set_position(gtk.WIN_POS_CENTER)
		
      vbox = gtk.VBox(False, 5)
      hbox = gtk.HBox(True, 3)
      valign = gtk.Alignment(0, 1, 0, 0)
      vbox.pack_start(valign)
		
      arr1 = gtk.Arrow(gtk.ARROW_UP, gtk.SHADOW_NONE)
      arr2 = gtk.Arrow(gtk.ARROW_DOWN, gtk.SHADOW_NONE)
      arr3 = gtk.Arrow(gtk.ARROW_LEFT, gtk.SHADOW_NONE)
      arr4 = gtk.Arrow(gtk.ARROW_RIGHT, gtk.SHADOW_NONE)
		
      btn1 = gtk.Button()
      btn1.add(arr1)
      btn2 = gtk.Button()
      btn2.add(arr2)
      btn3 = gtk.Button()
      btn3.add(arr3)
      btn4 = gtk.Button()
      btn4.add(arr4)
		
      hbox.add(btn1)
      hbox.add(btn2)
      hbox.add(btn3)
      hbox.add(btn4)
		
      halign = gtk.Alignment(0.5, 0.5, 0, 0)
      halign.add(hbox)
		
      vbox.pack_start(halign, False, True, 10)
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()

PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

यह वर्ग भी gtk.Misc वर्ग से विरासत में मिला है। Gtk.Image क्लास का ऑब्जेक्ट एक छवि प्रदर्शित करता है। आमतौर पर, छवि को एक पिक्सेल बफर में फ़ाइल से लोड किया जाना है, जो कि gtk.gdk.Pixbuf वर्ग का प्रतिनिधित्व करता है। एक सुविधा समारोह के बजायset_from_file() सामान्यतः gk.Image विजेट में फ़ाइल से छवि डेटा प्रदर्शित करने के लिए उपयोग किया जाता है।

Gtk.Image ऑब्जेक्ट बनाने का सबसे आसान तरीका निम्नलिखित निर्माता का उपयोग करना है -

img = gtk.Image()

निम्नलिखित gtk.Image वर्ग के तरीके हैं -

  • Image.set_from_file() - यह फ़ाइल की सामग्री से छवि डेटा सेट करता है।

  • Image.set_from_pixbuf() - यह से छवि डेटा सेट करता है pixmap जिसमें ऑफस्क्रीन हेरफेर के लिए छवि डेटा लोड किया गया है।

  • Image.set_from_pixbuf() - यह छवि डेटा का उपयोग कर सेट करता है pixbuf वह वस्तु है जिसमें डेटा होता है जो क्लाइंट साइड संसाधनों का उपयोग करके एक छवि का वर्णन करता है।

  • Image.set_from_stock() - यह द्वारा पहचाने गए स्टॉक आइटम से छवि डेटा सेट करता है stock_id

  • Image.clear() - यह करंट इमेज को हटाता है।

  • Image.set_from_image()- यह क्लाइंट डेटा की छवि डेटा को वर्तमान डिस्प्ले के पिक्सेल प्रारूप में बफर से सेट करता है। अगर छवि हैNone, वर्तमान छवि डेटा हटा दिया जाएगा।

उदाहरण

निम्न प्रोग्राम में, gtk.Image ऑब्जेक्ट एक छवि फ़ाइल से प्राप्त की जाती है। यह आगे की खिड़की में जोड़ा गया है।

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      
	  self.set_title("PyGtk Image demo")
      self.set_size_request(300, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      
	  image1 = gtk.Image()
      image1.set_from_file("python.png")
      self.add(image1)
      
	  self.connect("destroy", gtk.main_quit)
      self.show_all()

PyApp()
gtk.main()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

ड्रॉइंगअरे विजेट एक खाली कैनवास प्रस्तुत करता है, जिसमें एक gtk.gdk.Window होता है, जिस पर रेखा, आयत, चाप, आदि जैसी वस्तुएँ खींची जा सकती हैं।

PyGTK ऐसे ड्राइंग ऑपरेशंस के लिए काहिरा लाइब्रेरी का उपयोग करता है। काहिरा एक लोकप्रिय 2D वेक्टर ग्राफिक्स लाइब्रेरी है। यह सी में लिखा गया है, हालांकि, इसकी अधिकांश भाषाओं जैसे कि C ++, Java, Python, PHP आदि में बाइंडिंग है। विभिन्न ऑपरेटिंग सिस्टम में मानक आउटपुट डिवाइसों को खींचने के लिए काहिरा लाइब्रेरी का उपयोग किया जा सकता है। इसका उपयोग पीडीएफ, एसवीजी और पोस्ट-स्क्रिप्ट फ़ाइलों को बनाने के लिए भी किया जा सकता है।

अलग-अलग ड्राइंग ऑपरेशन करने के लिए, हमें डिवाइस को लक्ष्य आउटपुट ऑब्जेक्ट के टेक्स्ट पर लाना होगा। इस मामले में, चूंकि ड्राइंग gtk.DrawingArea विजेट पर दिखाई दे रही है, इसलिए इसके अंदर निहित gdk.Window का डिवाइस संदर्भ प्राप्त किया जाता है। इस वर्ग में एcairo-create() विधि जो डिवाइस संदर्भ देता है।

area = gtk.DrawingArea()
dc = area.window.cairo_create()

DrawingArea विजेट को इसके द्वारा उत्सर्जित निम्न संकेतों के आधार पर कॉलबैक से जोड़ा जा सकता है -

एहसास जब किसी विशेष प्रदर्शन पर विजेट को तत्काल किया जाता है तो कोई आवश्यक कार्रवाई करने के लिए।
configure_event विजेट के आकार में परिवर्तन होने पर कोई आवश्यक कार्यवाही करने के लिए।
expose_event विजेट की सामग्री को फिर से व्यवस्थित करने के लिए जब एक ड्राइंग क्षेत्र पहली बार स्क्रीन पर आता है, या जब यह किसी अन्य विंडो द्वारा कवर किया जाता है और तब खुला (उजागर) होता है।

माउस और कीबोर्ड ईवेंट का उपयोग कॉलबैक को लागू करने के लिए भी किया जा सकता है add_events() method का gtk.Widget class

विशेष रूप से रुचि एक्सपोज़-ईवेंट सिग्नल है, जो कि ड्रॉइंगआरे कैनवास पहली बार आने पर उत्सर्जित होता है। 2D ऑब्जेक्ट्स को खींचने के लिए अलग-अलग तरीके, जो काहिरा पुस्तकालय में परिभाषित किए गए हैं, इस कॉलबैक से एक्सपोज़-इवेंट सिग्नल से जुड़े हैं। ये विधियाँ कैरो डिवाइस के संदर्भ में संबंधित वस्तुओं को आकर्षित करती हैं।

निम्नलिखित उपलब्ध ड्राइंग विधियाँ हैं -

  • dc.rectangle (x, y, w, h) - यह निर्दिष्ट शीर्ष बाएँ समन्वय पर एक आयत खींचता है और जिसमें givwn चौड़ाई और ऊँचाई होती है।

  • dc.arc (x, y, r, a, a2) - यह दिए गए त्रिज्या और दो कोणों के साथ एक गोलाकार चाप खींचता है।

  • dc.line (X1, y1, x2, y2) - यह निर्देशांक के दो जोड़ों के बीच एक रेखा खींचता है।

  • dc.line_to (x, y) - यह वर्तमान स्थिति से (x, y) तक एक रेखा खींचती है

  • dc.show_text (str) - वर्तमान कर्सर स्थिति पर स्ट्रिंग खींचता है

  • dststroke () - रूपरेखा तैयार करता है

  • dffill () - वर्तमान रंग के साथ आकार भरता है

  • dc.set_color_rgb (आर, जी, बी) - 0.0 से 1.0 के बीच आर, जी और बी मानों की रूपरेखा तैयार करने और भरने के लिए रंग सेट करता है।

उदाहरण

निम्नलिखित स्क्रिप्ट काहिरा विधियों का उपयोग करके विभिन्न आकार और परीक्षण आकर्षित करती है।

import gtk
import math

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      
	  self.set_title("Basic shapes using Cairo")
      self.set_size_request(400, 250)
      self.set_position(gtk.WIN_POS_CENTER)
      
	  self.connect("destroy", gtk.main_quit)
		
      darea = gtk.DrawingArea()
      darea.connect("expose-event", self.expose)
		
      self.add(darea)
      self.show_all()
		
      def expose(self, widget, event):
      cr = widget.window.cairo_create()
		
      cr.set_line_width(2)
      cr.set_source_rgb(0,0,1)
      cr.rectangle(10,10,100,100)
      cr.stroke()
		
      cr.set_source_rgb(1,0,0)
      cr.rectangle(10,125,100,100)
      cr.stroke()
		
      cr.set_source_rgb(0,1,0)
      cr.rectangle(125,10,100,100)
      cr.fill()
		
      cr.set_source_rgb(0.5,0.6,0.7)
      cr.rectangle(125,125,100,100)
      cr.fill()
		
      cr.arc(300, 50, 50,0, 2*math.pi)
      cr.set_source_rgb(0.2,0.2,0.2)
      cr.fill()
		
      cr.arc(300, 200, 50, math.pi,0)
      cr.set_source_rgb(0.1,0.1,0.1)
      cr.stroke()
		
      cr.move_to(50,240)
      cr.show_text("Hello PyGTK")
      cr.move_to(150,240)
      cr.line_to(400,240)
      cr.stroke()

PyApp()
gtk.main()

उपरोक्त स्क्रिप्ट निम्नलिखित आउटपुट उत्पन्न करेगा -

SpinnButton विजेट, जिसे अक्सर स्पिनर कहा जाता है, अपने दाईं ओर ऊपर और नीचे तीर के साथ एक gtk.Entry विजेट है। एक उपयोगकर्ता सीधे इसमें एक संख्यात्मक मान टाइप कर सकता है या ऊपर और नीचे तीर का उपयोग करके वेतन वृद्धि या गिरावट कर सकता है। Gtk.SpinButton वर्ग gtk.Entry वर्ग से विरासत में मिला है। यह एक gtk.Adjustment ऑब्जेक्ट का उपयोग करता है जिसके साथ स्पिनर में संख्यात्मक मान की सीमा और चरण को प्रतिबंधित किया जा सकता है।

SpinButton विजेट निम्नलिखित कंस्ट्रक्टर का उपयोग करके बनाया गया है -

sp = gtk.SpinButton(adj, climb_rate, digits)

यहाँ, adj प्रतिनिधित्व करता है gtk.Adjustment object controlling range, climb_rate एक त्वरण कारक और अंकों द्वारा निर्दिष्ट दशमलव की संख्या है।

Gtk.SpinButton वर्ग के निम्नलिखित तरीके हैं -

  • SpinButton.set_adjustment () - यह "समायोजन" गुण सेट करता है।

  • स्पिनबटन द्वारा प्रदर्शित की जाने वाली दशमलव स्थानों की संख्या निर्धारित करने के लिए स्पिनबूटन.सेट_डिट्स () - यह "अंकों" की संपत्ति को मूल्य निर्धारित करता है।

  • SpinButton.set_increments (चरण, पृष्ठ) - यह चरण मान सेट करता है जिसमें प्रत्येक बाईं माउसबटन प्रेस और पृष्ठ मान के लिए लागू वेतन वृद्धि होती है जो प्रत्येक मध्य माउसबटन प्रेस के लिए लागू वेतन वृद्धि है।

  • SpinButton.set_range () - यह स्पिनबटन के लिए न्यूनतम और अधिकतम स्वीकार्य मान सेट करता है।

  • SpinButton.set_value () - यह स्पिन बटन को प्रोग्रामेटिक रूप से एक नए मान पर सेट करता है।

  • SpinButton.update_policy () - मान्य मान gtk.UPDATE_ALWAYS और gtk.UPDATE_VALID हैं

  • स्पिनबटन.स्पिन (दिशा, वृद्धि = 1) - यह वेतन वृद्धि या निर्दिष्ट दिशा में स्पिनर के मूल्य को घटाता है।

पूर्वनिर्धारित दिशा स्थिरांक निम्नलिखित हैं -

gtk.SPIN_STEP_FORWARD step_increment द्वारा आगे
gtk.SPIN_STEP_BACKWARD step_increment द्वारा पिछड़ा हुआ
gtk.SPIN_PAGE_FORWARD step_increment द्वारा आगे
gtk.SPIN_PAGE_BACKWARD step_increment द्वारा पिछड़ा हुआ
gtk.SPIN_HOME न्यूनतम मूल्य पर जाएं
gtk.SPIN_END अधिकतम मूल्य पर जाएं
gtk.SPIN_USER_DEFINED मूल्य में वृद्धि जोड़ें
  • SpinButton.set_wrap () - यदि रैप सही है, तो रेंज के ऊपरी या निचले सीमा से अधिक होने पर स्पिन बटन मान विपरीत सीमा के आसपास लपेटता है।

Gtk.SpinButton विजेट निम्नलिखित संकेतों का उत्सर्जन करता है -

बदलते सिद्धांत बदलते मूल्य, बदलती कीमत यह तब उत्सर्जित होता है जब कीबोर्ड क्रिया द्वारा स्पिनबटन मूल्य को बदल दिया जाता है
इनपुट यह तब बदला जाता है जब मूल्य बदल जाता है।
उत्पादन स्पिनबटन डिस्प्ले वैल्यू में बदलाव होने पर यह उत्सर्जित होता है। रिटर्नTrue यदि हैंडलर पाठ को सफलतापूर्वक सेट करता है और आगे की प्रक्रिया की आवश्यकता नहीं है।
मूल्य-बदल यह तब उत्सर्जित होता है जब स्पिनबटन के प्रदर्शन को बदलने वाली किसी भी सेटिंग को बदल दिया जाता है।
लपेटा हुआ स्पिनबटन के अधिकतम से न्यूनतम मूल्य या इसके विपरीत तक लपेटने के बाद यह सही उत्सर्जित होता है।

उदाहरण

निम्नलिखित उदाहरण एक सरल निर्माण करता है Date Selectorतीन स्पिनबटन विजेट का उपयोग करके। डे चयनकर्ता को 1-31 के बीच मूल्य को प्रतिबंधित करने के लिए एक समायोजन ऑब्जेक्ट लागू किया जाता है। दूसरा चयनकर्ता महीने की संख्या 1-12 के लिए है। तीसरे चयनकर्ता वर्ष रेंज 2000-2020 का चयन करता है।

कोड को ध्यान से देखें -

import gtk

class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("SpinButton Demo")
      self.set_size_request(300, 200)
      self.set_position(gtk.WIN_POS_CENTER)
      self.set_border_width(20)
		
      vbox = gtk.VBox(False, 5)
      hbox = gtk.HBox(True, 3)
      lbl1 = gtk.Label("Date")
      hbox.add(lbl1)
		
      adj1 = gtk.Adjustment(1.0, 1.0, 31.0, 1.0, 5.0, 0.0)
      spin1 = gtk.SpinButton(adj1, 0, 0)
      spin1.set_wrap(True)
		
      hbox.add(spin1)
      lbl2 = gtk.Label("Month")
      hbox.add(lbl2)
		
      adj2 = gtk.Adjustment(1.0, 1.0, 12.0, 1.0, 5.0, 0.0)
      spin2 = gtk.SpinButton(adj2, 0, 0)
      spin2.set_wrap(True)
		
      hbox.add(spin2)
      lbl3 = gtk.Label("Year")
      hbox.add(lbl3)
		
      adj3 = gtk.Adjustment(1.0, 2000.0, 2020.0, 1.0, 5.0, 0.0)
      spin3 = gtk.SpinButton(adj3, 0, 0)
      spin3.set_wrap(True)
      hbox.add(spin3)
		
      frame = gtk.Frame()
      frame.add(hbox)
      frame.set_label("Date of Birth")
		
      vbox.add(frame)
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()
PyApp()
gtk.main()

निष्पादन के बाद, उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -

PyGTK टूलकिट में कैलेंडर विजेट एक समय में एक महीने के दृश्य के साथ एक सरल कैलेंडर प्रदर्शित करता है। माह और वर्ष बदलने के लिए नेविगेशन नियंत्रण डिफ़ॉल्ट रूप से प्रदर्शित किए जाते हैं। प्रदर्शन विकल्प उपयुक्त रूप से कॉन्फ़िगर किए जा सकते हैं।

महीने की संपत्ति का मूल्य 0 से 11 के बीच है, और तारीख की संपत्ति 1 से 31 के बीच है।

Gtk.Calendar ऑब्जेक्ट बनाने के लिए एक सरल कंस्ट्रक्टर है -

cal = gtk.Calendar()

डिफ़ॉल्ट प्रदर्शन शैली वर्तमान माह और वर्ष के साथ-साथ दिनों के नामों को भी दिखाती है।

Gtk.Calendar वर्ग के निम्नलिखित तरीके हैं -

  • Calendar.select_month (mm, yy) - यह कैलेंडर डिस्प्ले को निर्दिष्ट में बदलता है mm तथा yy

  • Calendar.select_day (dd) - यह निर्दिष्ट का चयन करता है dd कैलेंडर पर जब इसका मान 1 और 31 के बीच होता है dd 0 है तो वर्तमान दिन का चयन हटा दिया जाता है।

  • Calendar.display_options () - यह निर्दिष्ट द्वारा मूल्य के लिए कैलेंडर प्रदर्शन विकल्प सेट करता है flags। संभावित प्रदर्शन विकल्प निम्नलिखित का एक संयोजन हैं:

gtk.CALENDAR_SHOW_HEADING निर्दिष्ट करता है कि महीने और वर्ष को प्रदर्शित किया जाना चाहिए।
gtk.CALENDAR_SHOW_DAY_NAMES निर्दिष्ट करता है कि तीन पत्र दिन विवरण मौजूद होना चाहिए।
gtk.CALENDAR_NO_MONTH_CHANGE कैलेंडर के साथ महीनों को बदलने से उपयोगकर्ता को रोकता है।
gtk.CALENDAR_SHOW_WEEK_NUMBERS कैलेंडर के बाईं ओर नीचे वर्तमान वर्ष के प्रत्येक सप्ताह की संख्या प्रदर्शित करता है।
gtk.CALENDAR_WEEK_START_MONDAY डिफ़ॉल्ट रविवार के बजाय सोमवार को कैलेंडर सप्ताह शुरू होता है।
  • Calendar.get_date () - यह कैलेंडर का वर्तमान वर्ष, माह और चयनित दिन संख्याओं को एक टपल (वर्ष, माह, दिन) के रूप में प्राप्त करता है।

Gtk.Calendar विजेट निम्नलिखित संकेतों का उत्सर्जन करता है -

दिन-चयनित यह तब उत्सर्जित होता है जब एक दिन उपयोगकर्ता द्वारा या प्रोग्रामेटिक रूप से चुना जाता है।
माह-बदल यह उत्सर्जित होता है जब कैलेंडर माह को प्रोग्रामेटिक रूप से या उपयोगकर्ता द्वारा बदल दिया जाता है।
अगले महीने यह तब उत्सर्जित होता है जब उपयोगकर्ता कैलेंडर हेडर में "अगले महीने" नेविगेशन नियंत्रण पर क्लिक करता है।
अगले साल यह तब उत्सर्जित होता है जब उपयोगकर्ता कैलेंडर हेडर में "अगले वर्ष" नेविगेशन नियंत्रण पर क्लिक करता है।
पिछला महीने यह तब उत्सर्जित होता है जब उपयोगकर्ता कैलेंडर हेडर में "प्रचलित-माह" नेविगेशन नियंत्रण पर क्लिक करता है।
पिछला साल यह तब उत्सर्जित होता है जब उपयोगकर्ता कैलेंडर हेडर में "प्रचलित-वर्ष" नेविगेशन नियंत्रण पर क्लिक करता है।

निम्नलिखित उदाहरण में, एक gtk.Calendar नियंत्रण और चार बटन toplevel विंडो में रखे गए हैं।

जब 'शीर्षक' बटन पर क्लिक किया जाता है, तो कैलेंडर के प्रदर्शन विकल्प SHOW_HEADING पर सेट किए जाते हैं -

def heading(self, widget):
   self.cal.set_display_options(gtk.CALENDAR_SHOW_HEADING)

जब उपयोगकर्ता 'दिन का नाम' बटन पर क्लिक करता है, तो कॉलबैक SHOW_DAY_NAMES के लिए प्रदर्शन विकल्प सेट करता है -

def dayname(self, widget):
self.cal.set_display_options(gtk.CALENDAR_SHOW_DAY_NAMES)

'दोनों' बटन दबाए जाने पर दोनों प्रदर्शन विकल्प सक्षम होते हैं। शुरुआत करने के लिए, प्रदर्शन विकल्पों के सभी झंडे को 0 पर सेट करके हटा दिया जाता है।

self.cal.set_display_options(0)

'सेट' बटन एक संदेश बॉक्स को दिखाता है जो वर्तमान में चिह्नित तिथि को प्रदर्शित करता है।

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()

उदाहरण

निम्नलिखित कोड देखें -

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()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

एक क्लिपबोर्ड ऑब्जेक्ट दो प्रक्रियाओं या एक ही एप्लिकेशन के दो विजेट्स के बीच साझा डेटा रखता है। Gtk.Clipboard gtk.SelectionData वर्ग के लिए एक उच्च स्तरीय इंटरफ़ेस है।

निम्नलिखित gtk.Clipboard निर्माता का एक प्रोटोटाइप है -

gtk.Clipboard(display,selction)

यहां, प्रदर्शन पैरामीटर gtk.gdk.Display ऑब्जेक्ट से मेल खाता है, जिसके लिए क्लिपबोर्ड बनाया या पुनर्प्राप्त किया जाना है। डिफ़ॉल्ट रूप से, यह मानक आउटपुट डिवाइस है। चयन पैरामीटर CLIPBOARD के लिए चूक, एक प्रशिक्षु स्ट्रिंग का प्रतिनिधित्व करने वाली वस्तु।

PyGTK चूक के साथ क्लिपबोर्ड ऑब्जेक्ट बनाने के लिए एक सुविधा फ़ंक्शन प्रदान करता है।

gtk.clipboard.get()

gtk.Clipboard वर्ग में निम्न विधियाँ हैं -

  • Clipboard.store () - यह वर्तमान क्लिपबोर्ड डेटा को कहीं संग्रहीत करता है ताकि आवेदन छोड़ने के बाद भी यह इधर-उधर रहे।

  • Clipboard.clear () - यह क्लिपबोर्ड की सामग्री को हटा देता है।

  • क्लिपबोर्ड.सेट_टेक्स्ट (पाठ) - यह क्लिपबोर्ड की सामग्री को स्ट्रिंग में सेट करता है।

  • Clipboard.request_text () - यह क्लिपबोर्ड की सामग्री को पाठ के रूप में अनुरोध करता है। जब पाठ बाद में प्राप्त होता है,callback द्वारा निर्दिष्ट डेटा के साथ बुलाया जाएगा user_data। के हस्ताक्षरcallback है:

    • def कॉलबैक (क्लिपबोर्ड, पाठ, डेटा) - पाठ में शामिल होगा text क्लिपबोर्ड से पुनर्प्राप्त किया गया।

क्लिपबोर्ड के प्रदर्शन के रूप में, निम्न कोड दो टेक्स्ट व्यू और दो बटन का उपयोग करता है एक toplevel gtk.Window पर। 'सेट' बटन कॉल करता हैon_set() फ़ंक्शन जो क्लिपबोर्ड पर पहले textView से पाठ डालता है।

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()

जब दूसरा बटन ('पुनः प्राप्त') दबाया जाता है, क्लिपबोर्ड से डेटा request_text द्वारा लाया जाता है ()

self.clipboard.request_text(self.readclipboard,        user_data = None)

की सामग्री user_data कॉलबैक विधि पर जाता है readclipboard() जो इसे दूसरे टेक्स्टव्यू पर प्रदर्शित करता है।

def readclipboard(self, clipboard, text, data):
   buffer = gtk.TextBuffer()
   buffer.set_text(text)
   self.tv2.set_buffer(buffer)

उदाहरण

क्लिपबोर्ड ऑपरेशन के लिए पूरा कोड निम्नलिखित है -

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()

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

यह क्षैतिज (gtk.Hruler) और ऊर्ध्वाधर (gtk.Vruler) शासकों के लिए एक आधार वर्ग है जो विंडो में माउस पॉइंटर की स्थिति दिखाने के लिए उपयोगी हैं। शासक में एक छोटा त्रिकोण सूचक के स्थान को इंगित करता है।

शासक वस्तुएं अपने संबंधित निर्माणकर्ताओं के साथ बनाई जाती हैं -

hrule = gtk.Hruler()
vrule = gtk.Vruler()

निम्न gtk.Ruler वर्ग विधियाँ दोनों व्युत्पन्न वर्गों के लिए उपलब्ध हैं -

  • Ruler.set_metric () - यह माप इकाई सेट करता है। पूर्वनिर्धारित मीट्रिक स्थिरांक हैं: gtk.PIXels (डिफ़ॉल्ट), gtk.INCHES और gtk.CENTIMETERS

  • Ruler.set_range () - यह शासक के निचले और ऊपरी सीमा, स्थिति और अधिकतम आकार सेट करता है।

नीचे दिए गए उदाहरण में, क्षैतिज और ऊर्ध्वाधर शासकों को ऊपर और एक gtk.TextView विजेट के बाईं ओर रखा गया है।

क्षैतिज शासक की माप पिक्सल में होती है। इसके न्यूनतम और अधिकतम मूल्य क्रमशः 0 और 400 हैं। इसे एक gtk.VBox की ऊपरी पंक्ति में रखा गया है।

hrule = gtk.HRuler()
hrule.set_metric(gtk.PIXELS)
hrule.set_range(0, 4,0,0.5)
vbox.pack_start(hrule)

Vbox की निचली पंक्ति में एक HBox होता है। एक ऊर्ध्वाधर शासक और एक टेक्स्ट व्यू विजेट, जिसमें एक बहु-पंक्ति पाठ दर्ज किया जा सकता है, पैक किया जाता है।

vrule=gtk.VRuler()
vrule.set_metric(gtk.PIXELS)
vrule.set_range(0, 4, 10, 0.5)
hbox.pack_start(vrule)

उदाहरण

निम्नलिखित कोड देखें -

import gtk
class PyApp(gtk.Window):
   
   def __init__(self):
      super(PyApp, self).__init__()
      
	  self.set_title("Ruler demo")
      self.set_size_request(400,400)
      self.set_position(gtk.WIN_POS_CENTER)
		
      vbox = gtk.VBox()
      tv = gtk.TextView()
      tv.set_size_request(350,350)
		
      hrule = gtk.HRuler()
      hrule.set_metric(gtk.PIXELS)
      hrule.set_range(0, 4,0,0.5)
		
      vbox.pack_start(hrule)
      hbox = gtk.HBox()
      vrule = gtk.VRuler()
		
      vrule.set_metric(gtk.PIXELS)
      vrule.set_range(0, 4, 10, 0.5)
		
      hbox.pack_start(vrule)
      halign = gtk.Alignment(0.5, 0.5, 0, 0)
      halign.add(tv)
		
      hbox.pack_start(halign, False, True, 10)
      vbox.add(hbox)
		
      self.add(vbox)
      self.connect("destroy", gtk.main_quit)
      self.show_all()

PyApp()
gtk.main()

उपरोक्त कार्यक्रम द्वारा उत्पन्न आउटपुट एक एमएस वर्ड दस्तावेज़ जैसा दिखता है -

PyGTK एपीआई के गोबजेक्ट मॉड्यूल में टाइमआउट फ़ंक्शन बनाने के लिए एक उपयोगी फ़ंक्शन है जिसे समय-समय पर कहा जाएगा।

source_id = gobject.timeout_add(interval, function, …)

दूसरा तर्क कॉलबैक फ़ंक्शन है जिसे आप प्रत्येक मिलीसेकंड के बाद कॉल करना चाहते हैं जो पहले तर्क का मूल्य है - अंतराल। फ़ंक्शन डेटा के रूप में कॉलबैक पर अतिरिक्त तर्क दिए जा सकते हैं।

इस फ़ंक्शन का रिटर्न मान है source_id। इसका उपयोग करके कॉलबैक फ़ंक्शन को कॉल करने से रोक दिया जाता है।

gobject.source_remove(source_id)

कॉलबैक फ़ंक्शन को दोहराते रहने के लिए सही लौटना चाहिए। इसलिए फाल्स वापस करके इसे रोका जा सकता है।

निम्नलिखित कार्यक्रम में दो बटन और दो लेबल एक खिड़की पर रखे गए हैं। एक लेबल एक वृद्धि संख्या प्रदर्शित करता है। Btn1 कॉल करता हैon_click जो 1000 ms (1 सेकंड) के अंतराल के साथ टाइमआउट फ़ंक्शन सेट करता है।

btn1.connect("clicked", self.on_click)

def on_click(self, widget):
   self.source_id = gobject.timeout_add(1000, counter, self)

टाइमआउट फ़ंक्शन को नाम दिया गया है counter()। यह हर 1 सेकंड के बाद एक लेबल पर संख्या बढ़ाता है।

def counter(timer):
   c=timer.count+1
   print c
   timer.count=c
   timer.lbl.set_label(str(c))
   return True

दूसरे बटन पर कॉलबैक टाइमआउट फ़ंक्शन को हटा देता है।

btn2.connect("clicked", self.on_stop)
def on_stop(self, widget):
gobject.source_remove(self.source_id)

उदाहरण

टाइमआउट उदाहरण के लिए पूरा कोड निम्नलिखित है -

import gtk, gobject

def counter(timer):
      c = timer.count+1
      print c
      timer.count = c
      timer.lbl.set_label(str(c))
      return True
      class PyApp(gtk.Window):
		
   def __init__(self):
      super(PyApp, self).__init__()
      self.set_title("Timeout Demo")
      self.set_size_request(300, 200)
      self.set_position(gtk.WIN_POS_CENTER)
		
      vbox = gtk.VBox(False, 5)
      hbox = gtk.HBox(True, 3)
		
      hb = gtk.HBox()
      lbl1 = gtk.Label("Counter: ")
		
      hb.add(lbl1)
      self.lbl = gtk.Label("")
      hb.add(self.lbl)
      valign = gtk.Alignment(0.5, 0.5, 0, 0)
      valign.add(hb)
      vbox.pack_start(valign, True, True, 10)
		
      btn1 = gtk.Button("start")
      btn2 = gtk.Button("stop")
		
      self.count = 0
      self.source_id = 0
		
      hbox.add(btn1)
      hbox.add(btn2)
		
      halign = gtk.Alignment(0.5, 0.5, 0, 0)
      halign.add(hbox)
		
      vbox.pack_start(halign, False, True, 10)
      self.add(vbox)
		
      btn1.connect("clicked", self.on_click)
      btn2.connect("clicked", self.on_stop)
		
      self.connect("destroy", gtk.main_quit)
      self.show_all()
		
   def on_click(self, widget):
      self.source_id = gobject.timeout_add(1000, counter, self)
		
   def on_stop(self, widget):
      gobject.source_remove(self.source_id)

PyApp()
gtk.main()

निष्पादित होने पर, विंडो नीचे की ओर दो बटन दिखाती है। लेबल पर संख्या समय-समय पर बढ़ेगी जब स्टार्ट बटन पर क्लिक किया जाएगा और स्टॉप बटन पर क्लिक करने पर यह वृद्धि को रोक देगा।

आउटपुट का निरीक्षण करें -

जुड़े एक्स विंडो वाले विजेट ड्रैग एंड ड्रॉप में सक्षम हैं। कार्यक्रम में, ड्रैग-एंड-ड्रॉप के स्रोत और / या गंतव्य के रूप में एक विजेट को पहले निर्दिष्ट किया जाना चाहिए। स्रोत के रूप में परिभाषित विजेट खींचे गए डेटा को बाहर भेज सकता है। गंतव्य विजेट इसे तब स्वीकार करता है जब उस पर घसीटा गया डेटा गिरा दिया जाता है।

निम्नलिखित कदम एक ड्रैग-एंड-ड्रॉप सक्षम एप्लिकेशन को स्थापित करने में शामिल हैं -

Step 1 - एक स्रोत विजेट की स्थापना।

Step 2 - drag_source_set () विधि एक ड्रैग ऑपरेशन के लिए लक्ष्य प्रकार निर्दिष्ट करती है -

widget.drag_source_set(start_button_mask, targets, info)

Step 3 - start_button_mask तर्क ड्रैग ऑपरेशन शुरू करने वाले बटनों का एक बिटमैप निर्दिष्ट करता है।

Step 4 - लक्ष्य तर्क इस संरचना के tuples की एक सूची है -

(target, flags, info)

लक्ष्य तर्क एक प्रकार है जो ड्रैग प्रकार का प्रतिनिधित्व करता है, उदाहरण के लिए, पाठ / सादा या छवि / x-xpixmap।

Step 6 - निम्नलिखित झंडे पूर्वनिर्धारित हैं -

  • gtk.TARGET_SAME_APP
  • gtk.TARGET_SAME_WIDGET

Step 7 - कोई सीमा नहीं होगी क्योंकि झंडा 0 पर सेट है।

यदि विजेट को स्रोत के रूप में कार्य करने की आवश्यकता नहीं है, तो यह परेशान हो सकता है -

widget.drag_source_unset()

स्रोत संकेत संकेतों का उत्सर्जन करता है। निम्न तालिका संकेतों और उनके कॉलबैक को सूचीबद्ध करती है।

drag_begin def खींचें_begin_cb (विजेट, drag_context, data):
drag_data_get def drag_data_get_cb (विजेट, drag_context, Selection_data, जानकारी, समय, डेटा):
drag_data_delete def drag_data_delete_cb (विजेट, drag_context, data):
drag_end def drag_end_cb (विजेट, drag_context, data):

एक गंतव्य विजेट सेट करना

Drag_dest_set () विधि निर्दिष्ट करती है कि कौन सा विजेट ड्रैग किया गया डेटा प्राप्त कर सकता है।

widget.drag_dest_set(flags, targets, action)

झंडे पैरामीटर निम्नलिखित स्थिरांक में से एक ले सकता है -

gtk.DEST_DEFAULT_MOTION यह जांचता है कि यदि ड्रैग इस विजेट की संभावित लक्ष्यों और कार्यों की सूची से मेल खाता है, तो ड्रैग_स्टैटस () को उपयुक्त कहता है।
gtk.DEST_DEFAULT_HIGHLIGHT यह इस विजेट पर एक आकर्षण बनाता है जब तक कि इस विजेट पर एक ड्रैग खत्म हो जाता है
gtk.DEST_DEFAULT_DROP जब एक बूंद होती है, तो ड्रैग इस विजेट की संभावित लक्ष्यों और कार्यों की सूची से मेल खाता है drag_get_data()विजेट की ओर से। ड्रॉप सफल है या नहीं, कॉल करेंdrag_finish()। यदि कार्रवाई एक चाल थी और ड्रैग सफल था, तो हटाए गए पैरामीटर के लिए TRUE पारित किया जाएगाdrag_finish()
gtk.DEST_DEFAULT_ALL यदि सेट किया गया है, तो निर्दिष्ट करता है कि सभी डिफ़ॉल्ट कार्रवाई की जानी चाहिए।

लक्ष्य टपल्स की एक सूची है जिसमें लक्ष्य जानकारी है। कार्रवाई का तर्क निम्न मानों में से एक या एक से अधिक का एक संयोजन है -

  • gtk.gdk.ACTION_DEFAULT
  • gtk.gdk.ACTION_COPY
  • gtk.gdk.ACTION_MOVE
  • gtk.gdk.ACTION_LINK
  • gtk.gdk.ACTION_PRIVATE
  • gtk.gdk.ACTION_ASK

"ड्रैग-मोशन" हैंडलर को यह निर्धारित करना चाहिए कि क्या ड्रैग डेटा गंतव्य लक्ष्यों को गति के साथ मिलान करके उचित है gtk.gdk.DragContext लक्ष्य और वैकल्पिक रूप से कॉल करके ड्रैग डेटा की जांच करके drag_get_data()तरीका। gtk.gdk.DragContextdrag_status() विधि को अद्यतन करने के लिए बुलाया जाना चाहिए drag_context स्थिति।

"ड्रैग-ड्रॉप" हैंडलर का उपयोग करके मिलान लक्ष्य निर्धारित करना चाहिए drag_dest_find_target() विधि और फिर खींचें डेटा का उपयोग करने के लिए पूछें drag_get_data()तरीका। डेटा "ड्रैग-डेटा-प्राप्त" हैंडलर में उपलब्ध होगा।