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() यह विंडो की स्थिति निर्धारित करता है। पूर्वनिर्धारित स्थिति स्थिरांक हैं -
|
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.DragContext। drag_status() विधि को अद्यतन करने के लिए बुलाया जाना चाहिए drag_context स्थिति।
"ड्रैग-ड्रॉप" हैंडलर का उपयोग करके मिलान लक्ष्य निर्धारित करना चाहिए drag_dest_find_target() विधि और फिर खींचें डेटा का उपयोग करने के लिए पूछें drag_get_data()तरीका। डेटा "ड्रैग-डेटा-प्राप्त" हैंडलर में उपलब्ध होगा।