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

wxPython के लिए एक अजगर आवरण है wxWidgets(जो C ++ में लिखा गया है), एक लोकप्रिय क्रॉस-प्लेटफ़ॉर्म GUI टूलकिट है। रॉबिन डन द्वारा हेर्री पासन के साथ विकसित किए गए, wxPython को पायथन एक्सटेंशन मॉड्यूल के रूप में लागू किया गया है।

WxWidgets की तरह, wxPython भी एक फ्री सॉफ्टवेयर है। इसे आधिकारिक वेबसाइट से डाउनलोड किया जा सकता हैhttp://wxpython.org. कई ऑपरेटिंग सिस्टम प्लेटफॉर्म के लिए बायनेरिज़ और सोर्स कोड इस साइट पर डाउनलोड के लिए उपलब्ध हैं।

WxPython API में मुख्य मॉड्यूल में एक कोर मॉड्यूल शामिल है। यह मिश्रण हैwxObjectवर्ग, जो एपीआई में सभी वर्गों के लिए आधार है। नियंत्रण मॉड्यूल में GUI अनुप्रयोग विकास में उपयोग किए जाने वाले सभी विजेट शामिल हैं। उदाहरण के लिए, wx.Button, wx.StaticText (एक लेबल के अनुरूप), wx.TextCtrl (संपादन योग्य पाठ नियंत्रण), आदि।

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

WxPython की आधिकारिक वेबसाइट भी प्रोजेक्ट फीनिक्स की मेजबानी करती है - Python 3. * के लिए wxPython का एक नया कार्यान्वयन। यह गति में सुधार, स्थिरता और विस्तार क्षमता पर केंद्रित है। परियोजना 2012 में शुरू हुई और अभी भी बीटा स्टेज में है।

खिड़कियाँ

विंडोज ओएस के लिए प्रीबिलीट बायनेरी (32 बिट और 64 बिट दोनों) उपलब्ध हैं http://www.wxpython.org/download.phpपृष्ठ। उपलब्ध इंस्टॉलर के नवीनतम संस्करण हैं - wxPython3.0-win32-3.0.2.0-py27.exe 32-बिट पायथन के लिए 2.7 wxPython3.0-win64-3.0.2.0-py27.exe 64-बिट पायथन 2.7 के लिए

उसी पृष्ठ पर डाउनलोड के लिए wxPython डेमो, नमूने और wxWidgets प्रलेखन भी उपलब्ध है।

wxPython3.0-Win32-डॉक्स-demos.exe

लिनक्स

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

sudo apt-get install python-wxgtk3.0

मैक ओ एस

डिस्क छवियों के रूप में MacOS के लिए प्रीबिलीट बायनेरी आधिकारिक वेबसाइट के डाउनलोड पृष्ठ पर उपलब्ध हैं।

हैलो वर्ल्ड संदेश प्रदर्शित करने वाला एक सरल GUI एप्लिकेशन निम्न चरणों का उपयोग करके बनाया गया है -

  • आयात wx मॉड्यूल।

  • अनुप्रयोग वर्ग की एक वस्तु को परिभाषित करें।

  • Wx.Frame वर्ग के ऑब्जेक्ट के रूप में एक शीर्ष स्तर की विंडो बनाएं। निर्माण में कैप्शन और आकार के पैरामीटर दिए गए हैं।

  • हालाँकि अन्य नियंत्रणों को फ़्रेम ऑब्जेक्ट में जोड़ा जा सकता है, लेकिन उनके लेआउट को प्रबंधित नहीं किया जा सकता है। इसलिए, फ़्रेम में एक पैनल ऑब्जेक्ट डालें।

  • विंडो के अंदर वांछित स्थान पर 'हैलो वर्ल्ड' प्रदर्शित करने के लिए एक StaticText ऑब्जेक्ट जोड़ें।

  • फ़्रेम विंडो को शो () विधि द्वारा सक्रिय करें।

  • एप्लिकेशन ऑब्जेक्ट का मुख्य ईवेंट लूप दर्ज करें।

import wx 
 
app = wx.App() 
window = wx.Frame(None, title = "wxPython Frame", size = (300,200)) 
panel = wx.Panel(window) 
label = wx.StaticText(panel, label = "Hello World", pos = (100,50)) 
window.Show(True) 
app.MainLoop()

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

wxFrame objectसबसे अधिक नियोजित शीर्ष स्तर की खिड़की है। से ली गई हैwxWindow class। एक फ्रेम एक खिड़की है जिसका आकार और स्थिति उपयोगकर्ता द्वारा बदला जा सकता है। इसमें टाइटल बार और कंट्रोल बटन हैं। यदि आवश्यक हो, तो मेनू बार, टूलबार और स्टेटस बार जैसे अन्य घटकों को सक्षम किया जा सकता है। एक wxFrame विंडो में कोई भी फ़्रेम हो सकता है जो संवाद या अन्य फ़्रेम नहीं है।

मैन्युअल कोडिंग द्वारा एक अच्छी दिखने वाली GUI बनाना थकाऊ हो सकता है। एक दृश्य GUI डिजाइनर टूल हमेशा काम आता है। WxPython पर लक्षित कई GUI विकास IDE उपलब्ध हैं। उनमें से कुछ निम्नलिखित हैं -

  • wxFormBuilder
  • wxDesigner
  • wxGlade
  • BoaConstructor
  • gui2py

wxFormBuilderएक खुला स्रोत है, क्रॉस-प्लेटफ़ॉर्म WYSIWYG GUI बिल्डर जो wxWidget GUI डिज़ाइन को C ++, पायथन, PHP या XML प्रारूप में अनुवाद कर सकता है। WxFormBuilder के उपयोग का एक संक्षिप्त परिचय यहां दिया गया है।

सबसे पहले wxFormBuilder के नवीनतम संस्करण को डाउनलोड और इनस्टॉल करना होगा http://sourceforge.net/projects/wxformbuilder/. आवेदन खोलने पर, केंद्र में खाली ग्रे क्षेत्र के साथ एक नई परियोजना दिखाई देती है।

प्रोजेक्ट को उपयुक्त नाम दें और कोड जनरेशन लैंग्वेज के रूप में पायथन चुनें। यह निम्न गुण विंडो में किया गया है जैसा कि निम्नलिखित छवि में दिखाया गया है -

फिर घटकों के पैलेट के 'फॉर्म' टैब से, फ़्रेम चुनें।

'लेआउट' टैब से वर्टिकल wxBoxSizer जोड़ें।

उपयुक्त कैप्शन के साथ बॉक्स में आवश्यक नियंत्रण जोड़ें। यहाँ, एक StaticText (लेबल), दो TextCtrl ऑब्जेक्ट्स (टेक्स्ट बॉक्स) और एक wxButton ऑब्जेक्ट जोड़े जाते हैं। फ्रेम निम्न छवि जैसा दिखता है -

इन तीन नियंत्रणों पर विस्तार और खिंचाव सक्षम करें। WxButton ऑब्जेक्ट के लिए ऑब्जेक्ट प्रॉपर्टीज में, OnButton पर क्लिक करें।

प्रोजेक्ट को सहेजें और विकसित GUI के लिए पायथन कोड जनरेट करने के लिए F8 दबाएँ। बता दें कि जनरेट की गई फाइल को Demo.py नाम दिया गया है

निष्पादन योग्य पायथन लिपि में, डेमोक्रोम आयात करें और FindSquare () फ़ंक्शन को परिभाषित करें। अनुप्रयोग ऑब्जेक्ट की घोषणा करें और एक मुख्य ईवेंट लूप प्रारंभ करें। निम्नलिखित निष्पादन योग्य कोड है -

import wx 
  
#import the newly created GUI file 
import demo  
class CalcFrame(demo.MyFrame1): 
   def __init__(self,parent): 
      demo.MyFrame1.__init__(self,parent)  
		
   def FindSquare(self,event): 
      num = int(self.m_textCtrl1.GetValue()) 
      self.m_textCtrl2.SetValue (str(num*num)) 
        
app = wx.App(False) 
frame = CalcFrame(None) 
frame.Show(True) 
#start the applications 
app.MainLoop()

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

मूल wxWidgets (C ++ में लिखा गया) एक विशाल श्रेणी का पुस्तकालय है। इस लाइब्रेरी से GUI कक्षाएं wxPython मॉड्यूल के साथ पायथन में रखी गई हैं, जो मूल wxWidgets लाइब्रेरी को यथासंभव करीब से देखने की कोशिश करता है। तो, wx में मौजूद वर्ग। WPPython में उसी तरह से काम करता है जैसे कि wxFrame वर्ग अपने ++ संस्करण में।

wxObject अधिकांश वर्गों के लिए आधार है। WxApp की एक वस्तु (wxPython में wx.App) एप्लिकेशन को ही दर्शाती है। GUI को जनरेट करने के बाद, अनुप्रयोग एक इवेंट लूप में MainLoop () विधि से प्रवेश करता है। आरेख के बाद सबसे अधिक इस्तेमाल किए जाने वाले GUI वर्गों के वर्ग पदानुक्रम को wxPython में शामिल करते हैं।

एस.एन. कक्षाएं और विवरण
1 wx.Frame

wx.Frame क्लास में बिना किसी तर्क के एक डिफ़ॉल्ट कंस्ट्रक्टर है।

2 wx.Panel

wx.Panel वर्ग आमतौर पर एक wxFrame ऑब्जेक्ट के अंदर रखा जाता है। यह वर्ग भी wxWindow वर्ग से विरासत में मिला है।

3 wx.StaticText

wx.StaticText क्लास ऑब्जेक्ट इस तरह के रीड-ओनली टेक्स्ट को नियंत्रित करता है। इसे एक निष्क्रिय नियंत्रण के रूप में कहा जा सकता है क्योंकि यह किसी भी घटना का उत्पादन नहीं करता है।

4 TextCtrl

WxPython में, wx.TextCtrl क्लास का एक ऑब्जेक्ट इस उद्देश्य को पूरा करता है। यह एक नियंत्रण है जिसमें पाठ को प्रदर्शित और संपादित किया जा सकता है।

5 RadioButton और RadioBox

प्रत्येक बटन, wx.RadioButton क्लास का एक ऑब्जेक्ट एक गोल बटन के बगल में एक टेक्स्ट लेबल रखता है। wxPython API में wx.RadioBox क्लास भी है। इसकी वस्तु समूह को एक सीमा और लेबल प्रदान करती है।

6 wx.CheckBox

एक चेकबॉक्स एक छोटे लेबल वाले आयताकार बॉक्स को प्रदर्शित करता है। जब क्लिक किया जाता है, तो एक चेकमार्क आयत के अंदर दिखाई देता है कि एक विकल्प बनाया गया है।

7 कॉम्बोबॉक्स और च्वाइस क्लास

एक wx.ComboBox ऑब्जेक्ट से चुनने के लिए आइटम की एक सूची प्रस्तुत करता है। इसे ड्रॉपडाउन सूची या स्थायी प्रदर्शन के साथ कॉन्फ़िगर किया जा सकता है। wxPython API में एक wx.Choice वर्ग है, जिसकी वस्तु भी एक ड्रॉपडाउन सूची है, जो स्थायी रूप से केवल-पढ़ने के लिए है।

8 Wx.Gauge

Wx.Gauge क्लास ऑब्जेक्ट एक वर्टिकल या हॉरिज़ॉन्टल बार दिखाती है, जो ग्राफ़िकल रूप से इंक्रीमेंटिंग मात्रा दिखाती है।

9 wx.Slider

wxPython API में wx.Slider वर्ग है। यह स्क्रॉलबार की तरह ही कार्यक्षमता प्रदान करता है। स्लाइडर विशिष्ट स्लाइडर wx.EVT_SLIDER ईवेंट बाइंडर द्वारा हैंडल को खींचने का एक सुविधाजनक तरीका प्रदान करता है।

10 wx.MenuBar

शीर्ष स्तर विंडो के शीर्षक पट्टी के ठीक नीचे एक क्षैतिज पट्टी मेनू की एक श्रृंखला प्रदर्शित करने के लिए आरक्षित है। यह wxPython API में wx.MenuBar वर्ग की वस्तु है।

1 1 wx.Toolbar

यदि wx.Toolbar ऑब्जेक्ट का स्टाइल पैरामीटर wx.TB_DOCKABLE पर सेट किया जाता है, तो यह डॉकेबल हो जाता है। एक फ्लोटिंग टूलबार भी wxPython के AUIToolBar क्लास का उपयोग करके बनाया जा सकता है।

12 Wx.Dialog

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

13 wx.Notebook

wx.Notebook विजेट टैब्ड कंट्रोल को प्रस्तुत करता है। एक फ्रेम में एक नोटबुक ऑब्जेक्ट में एक या एक से अधिक टैब होते हैं (जिन्हें पेज कहा जाता है), उनमें से प्रत्येक में एक पैनल होता है जो नियंत्रण का लेआउट दिखाता है।

14 wx.SplitterWindow

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

15 HTMLWindow

wxHTML लाइब्रेरी में HTML सामग्री को पार्स और प्रदर्शित करने के लिए कक्षाएं हैं। हालांकि यह एक पूर्ण विशेषताओं वाला ब्राउज़र होने का इरादा नहीं है, wx.HtmlWindow ऑब्जेक्ट एक सामान्य एचटीएमएल दर्शक है।

16 ListBox और ListCtrl

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

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

अनुप्रयोग के रनटाइम के दौरान होने वाली घटना से संबंधित डेटा को उप-उपवर्ग से प्राप्त वस्तु के रूप में संग्रहीत किया जाता है wx.Event। एक डिस्प्ले कंट्रोल (जैसे कि बटन) एक विशेष प्रकार की घटना का स्रोत है और इससे जुड़े इवेंट क्लास का ऑब्जेक्ट बनाता है। उदाहरण के लिए, एक बटन पर क्लिक करने से wx.CommandEvent निकलता है। यह घटना डेटा कार्यक्रम में हैंडलर विधि को भेजने के लिए भेजा जाता है। wxPython में कई पूर्वनिर्धारित ईवेंट बाइंडर हैं। एकEvent binder किसी विशिष्ट विजेट (नियंत्रण), उसके संबद्ध ईवेंट प्रकार और ईवेंट हैंडलर विधि के बीच संबंध को संक्षिप्त करता है।

उदाहरण के लिए, कॉल करने के लिए OnClick() method बटन के क्लिक पर कार्यक्रम के कार्यक्रम, निम्नलिखित कथन की आवश्यकता है -

self.b1.Bind(EVT_BUTTON, OnClick)

Bind() methodwx.EvtHandler वर्ग से सभी प्रदर्शन वस्तुओं द्वारा विरासत में मिला है। EVT_.BUTTON यहां बाइंडर है, जो बटन को ईवेंट को OnClick () विधि पर क्लिक करता है।

उदाहरण

निम्न उदाहरण में, MoveEvent, शीर्ष स्तर की खिड़की को खींचने के कारण होता है - इस मामले में wx.Frame ऑब्जेक्ट: OnMove() methodwx.EVT_MOVE बाइंडर का उपयोग करना। कोड एक विंडो प्रदर्शित करता है। यदि इसे माउस का उपयोग करके स्थानांतरित किया जाता है, तो इसके तात्कालिक निर्देशांक कंसोल पर प्रदर्शित होते हैं।

import wx
  
class Example(wx.Frame): 
            
   def __init__(self, *args, **kw): 
      super(Example, self).__init__(*args, **kw)  
      self.InitUI() 
           
   def InitUI(self): 
      self.Bind(wx.EVT_MOVE, self.OnMove) 
      self.SetSize((250, 180)) 
      self.SetTitle('Move event') 
      self.Centre() 
      self.Show(True)
		   
   def OnMove(self, e): 
      x, y = e.GetPosition() 
      print "current window position x = ",x," y= ",y 
         
ex = wx.App() 
Example(None) 
ex.MainLoop()

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

वर्तमान विंडो स्थिति x = 562 y = 309

वर्तमान विंडो स्थिति x = 562 y = 309

वर्तमान विंडो स्थिति x = 326 y = 304

वर्तमान विंडो स्थिति x = 384 y = 240

वर्तमान विंडो स्थिति x = 173 y = 408

वर्तमान विंडो स्थिति x = 226 y = 30

वर्तमान विंडो स्थिति x = 481 y = 80

Wx.Event से विरासत में मिले कुछ उपवर्ग निम्नलिखित तालिका में सूचीबद्ध हैं -

एस.एन. घटनाक्रम और विवरण
1

wxKeyEvent

तब होता है जब एक कुंजी दबाया जाता है या जारी किया जाता है

2

wxPaintEvent

जब भी विंडो की सामग्री को फिर से तैयार करने की आवश्यकता होती है, तब उत्पन्न होती है

3

wxMouseEvent

माउस बटन जैसे माउस गतिविधि के कारण किसी भी घटना के बारे में डेटा को दबाया या खींचा जाता है

4

wxScrollEvent

WxScrollbar और wxSlider जैसे स्क्रॉल करने योग्य नियंत्रणों से संबद्ध है

5

wxCommandEvent

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

6

wxMenuEvent

मेनू कमांड बटन को छोड़कर विभिन्न मेनू से संबंधित घटनाएं

7

wxColourPickerEvent

wxColourPickerCtrl ने ईवेंट उत्पन्न किए

8

wxDirFilePickerEvent

FileDialog और DirDialog द्वारा उत्पन्न ईवेंट

WxPython में घटनाएँ दो प्रकार की होती हैं। बुनियादी घटनाओं और कमान की घटनाओं। एक मूल घटना स्थानीय विंडो में रहती है जिसमें यह उत्पन्न होती है। अधिकांश wxWidgets कमांड ईवेंट उत्पन्न करते हैं। एcommand event खिड़की या खिड़कियों के लिए प्रचारित किया जा सकता है, जो कक्षा पदानुक्रम में स्रोत विंडो के ऊपर हैं।

उदाहरण

निम्नलिखित घटना प्रसार का एक सरल उदाहरण है। पूरा कोड है -

import wx
  
class MyPanel(wx.Panel): 
     
   def __init__(self, parent): 
      super(MyPanel, self).__init__(parent)
		
      b = wx.Button(self, label = 'Btn', pos = (100,100)) 
      b.Bind(wx.EVT_BUTTON, self.btnclk) 
      self.Bind(wx.EVT_BUTTON, self.OnButtonClicked) 
		
   def OnButtonClicked(self, e): 
         
      print 'Panel received click event. propagated to Frame class' 
      e.Skip()  
		
   def btnclk(self,e): 
      print "Button received click event. propagated to Panel class" 
      e.Skip()
		
class Example(wx.Frame):

   def __init__(self,parent): 
      super(Example, self).__init__(parent)  
         
      self.InitUI() 

   def InitUI(self):
	
      mpnl = MyPanel(self) 
      self.Bind(wx.EVT_BUTTON, self.OnButtonClicked)
		
      self.SetTitle('Event propagation demo') 
      self.Centre() 
      self.Show(True)
		
   def OnButtonClicked(self, e): 
         
      print 'click event received by frame class' 
      e.Skip()
		
ex = wx.App() 
Example(None) 
ex.MainLoop()

उपरोक्त कोड में, दो वर्ग हैं। MyPanel, एक wx.Panel उपवर्ग और उदाहरण, एक wx.rame उपवर्ग जो कार्यक्रम के लिए शीर्ष स्तर की खिड़की है। पैनल में एक बटन रखा गया है।

यह बटन ऑब्जेक्ट ईवेंट हैंडलर btnclk () के लिए बाध्य है, जो इसे मूल वर्ग (इस मामले में MyPanel) में प्रचारित करता है। बटन क्लिक एक उत्पन्न करता हैCommandEvent जिसे स्किप () विधि द्वारा अपने माता-पिता को प्रचारित किया जा सकता है।

MyPanel क्लास ऑब्जेक्ट किसी अन्य हैंडलर OnButtonClicked () को प्राप्त इवेंट को भी बांधता है। यह फ़ंक्शन बदले में अपने मूल, उदाहरण वर्ग में पहुंचाता है। उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

Button received click event. Propagated to Panel class. 
Panel received click event. Propagated to Frame class. 
Click event received by frame class.

एक GUI विजेट को पिक्सल में मापा गया इसके पूर्ण निर्देशांक को निर्दिष्ट करके कंटेनर विंडो के अंदर रखा जा सकता है। निर्देशांक इसके निर्माता के आकार के तर्क द्वारा परिभाषित खिड़की के आयामों के सापेक्ष हैं। विंडो के अंदर विजेट की स्थिति को परिभाषित किया गया हैpos इसके निर्माता का तर्क।

import wx  

app = wx.App() 
window = wx.Frame(None, title = "wxPython Frame", size = (300,200)) 
panel = wx.Panel(window) 
label = wx.StaticText(panel, label = "Hello World", pos = (100,50)) 
window.Show(True) 
app.MainLoop()

यह Absolute Positioning हालांकि निम्नलिखित कारणों से उपयुक्त नहीं है -

  • विंडो के आकार बदलने पर भी विजेट की स्थिति नहीं बदलती है।

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

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

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

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

लेआउट मैनेजर को wxPython में Sizer कहा जाता है। Wx.Sizer सभी शोधकर्ता उपवर्गों का आधार वर्ग है। आइए कुछ महत्वपूर्ण sizers की चर्चा करते हैं जैसे wx.BoxSizer, wx.StaticBoxSizer, wx.GridSizer, wx.FlexGridSizer और wx.GridBagSizer।

एस.एन. Sizers और विवरण
1 BoxSizer

यह sizer नियंत्रणों को पंक्ति-वार या कॉलम-वार तरीके से व्यवस्थित करने की अनुमति देता है। BoxSizer का लेआउट उसके अभिविन्यास तर्क (या तो wxVERTICAL या wxHORIZONTAL) द्वारा निर्धारित किया जाता है।

2 GridSizer

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

3 FlexiGridSizer

इस sizer में एक दो आयामी ग्रिड भी है। हालांकि, यह कोशिकाओं में नियंत्रण बिछाने में थोड़ा अधिक लचीलापन प्रदान करता है।

4 GridBagSizer

GridBagSizer एक बहुमुखी शोधक है। यह FlexiGridSizer की तुलना में अधिक संवर्द्धन प्रदान करता है। बाल विजेट ग्रिड के भीतर एक विशिष्ट सेल में जोड़ा जा सकता है।

5 StaticBoxSizer

एक StaticBoxSizer एक स्थिर बॉक्स में एक बॉक्स sizer डालता है। यह शीर्ष पर एक लेबल के साथ बॉक्स के चारों ओर एक सीमा प्रदान करता है।

किसी भी GUI इंटरफ़ेस में बटन विजेट का सबसे अधिक उपयोग किया जाता है। यह उपयोगकर्ता द्वारा उत्पन्न क्लिक इवेंट को कैप्चर करता है। इसका सबसे स्पष्ट उपयोग इसके लिए बाध्य एक हैंडलर फ़ंक्शन को ट्रिगर करना है।

wxPython क्लास लाइब्रेरी विभिन्न प्रकार के बटन प्रदान करती है। एक सरल, पारंपरिक बटन है,wx.Buttonक्लास ऑब्जेक्ट, जो कुछ टेक्स्ट को कैप्शन के रूप में कैरी करता है। एक दो-राज्य बटन भी उपलब्ध है, जिसे नाम दिया गया हैwx.ToggleButton। इसकी दबाया या उदास राज्य को इवेंटहैंडलर फ़ंक्शन द्वारा पहचाना जा सकता है।

एक अन्य प्रकार का बटन, wx.BitmapButton एक बिटमैप (छवि) को उसके चेहरे पर आइकन के रूप में प्रदर्शित करता है।

Wx.Button वर्ग और wx.ToggleButton वर्ग के लिए कंस्ट्रक्टर निम्नलिखित तर्क लेता है -

Wx.Button(parent, id, label, pos, size, style)

ये wx.Button वर्ग के कुछ महत्वपूर्ण तरीके हैं -

एस.एन. तरीके और विवरण
1

SetLabel()

बटन के कैप्शन को प्रोग्रामेटिक रूप से सेट करता है

2

GetLabel()

बटन का कैप्शन लौटाता है

3

SetDefault()

शीर्ष स्तर विंडो के लिए बटन डिफ़ॉल्ट रूप से सेट है। Enter कुंजी दबाने पर क्लिक ईवेंट का अनुकरण करता है

Wx.ToggleButton वर्ग के दो महत्वपूर्ण तरीके हैं -

एस.एन. तरीके और विवरण
1

GetValue()

टॉगल बटन की स्थिति लौटाता है (चालू / बंद)

2

SetValue()

बटन की स्थिति को प्रोग्रामेटिक रूप से सेट करता है

एक बिटमैप बटन बनाने के लिए, सबसे पहले, एक बिटमैप ऑब्जेक्ट को एक छवि फ़ाइल से बाहर बनाने की आवश्यकता होती है।

Wx.Bitmap क्लास कंस्ट्रक्टर का निम्नलिखित भिन्न रूप सबसे अधिक उपयोग किया जाता है -

Wx.Bitmap(fiiename, wx.BITMAP_TYPE)

कुछ पूर्वनिर्धारित बिटमैप प्रकार स्थिरांक हैं -

wx.BITMAP_TYPE_BMP
wx.BITMAP_TYPE_ICO
wx.BITMAP_TYPE_CUR
wx.BITMAP_TYPE_TIFF
wx.BITMAP_TYPE_TIF
wx.BITMAP_TYPE_GIF
wx.BITMAP_TYPE_PNG
wx.BITMAP_TYPE_JPEG
wx.BITMAP_TYPE_PCX
wx.BITMAP_TYPE_ICON
wx.BITMAP_TYPE_ANY

इस बिटमैप ऑब्जेक्ट का उपयोग wx.BitmapButton क्लास कंस्ट्रक्टर के मापदंडों में से एक के रूप में किया जाता है।

Wx.BitmapButton(parent, id, bitmap, pos, size, style)

कुछ OS प्लेटफ़ॉर्म पर, बिटमैप बटन बिटमैप और लेबल दोनों को प्रदर्शित कर सकता है। सेटलैबेल () तरीके कैप्शन प्रदान करते हैं। अन्य प्लेटफार्मों पर, यह एक आंतरिक लेबल के रूप में कार्य करता है।

सामान्य बटन के साथ ही बिटमैप बटन wx.CommandEvent का उत्सर्जन करता है। EVT_BUTTON बाइंडर एक हैंडलर फंक्शन को इससे जोड़ देता है।

दूसरी ओर टॉगल बटन wx.TOGGLEBUTTON बाइंडर का उपयोग करता है।

निम्नलिखित उदाहरण में, तीनों प्रकार के बटन एक पैनल के वर्टिकल बॉक्स सिस्टर में रखे गए हैं।

साधारण बटन ऑब्जेक्ट स्टेटमेंट का उपयोग करके बनाया गया है -

self.btn = wx.Button(panel, -1, "click Me")

टॉगल बटन का निर्माण निम्नलिखित कथन द्वारा किया गया है -

self.tbtn = wx.ToggleButton(panel , -1, "click to on")

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

vbox.Add(self.btn,0,wx.ALIGN_CENTER) 
vbox.Add(self.tbtn,0,wx.EXPAND|wx.ALIGN_CENTER)

Note - wx.EXPAND फ्लैग के कारण, टॉगल बटन फ्रेम की पूरी चौड़ाई पर कब्जा कर लेता है।

EVT_BUTTON और EVT_TOGGLEBUTTON बाइंडरों का उपयोग करके वे संबंधित हैंडलर से जुड़े हुए हैं।

self.btn.Bind(wx.EVT_BUTTON,self.OnClicked) 
self.tbtn.Bind(wx.EVT_TOGGLEBUTTON,self.OnToggle)

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

bmp = wx.Bitmap("NEW.BMP", wx.BITMAP_TYPE_BMP) 
self.bmpbtn = wx.BitmapButton(panel, id = wx.ID_ANY, bitmap = bmp,
   size = (bmp.GetWidth()+10, bmp.GetHeight()+10))
  
bmp1 = wx.Bitmap("OPEN.BMP", wx.BITMAP_TYPE_BMP) 
self.bmpbtn1 = wx.BitmapButton(panel, id = wx.ID_ANY, bitmap = bmp1,
   size = (bmp.GetWidth()+10, bmp.GetHeight()+10))
  
bmp2 = wx.Bitmap("SAVE.BMP", wx.BITMAP_TYPE_BMP) 
self.bmpbtn2 = wx.BitmapButton(panel, id = wx.ID_ANY, bitmap = bmp2,
   size = (bmp.GetWidth()+10, bmp.GetHeight()+10))

इन तीन बटनों के क्लिक इवेंट को ऑनक्लिप्ड () विधि से निर्देशित किया जाता है।

self.bmpbtn.Bind(wx.EVT_BUTTON, self.OnClicked) 
self.bmpbtn1.Bind(wx.EVT_BUTTON, self.OnClicked) 
self.bmpbtn2.Bind(wx.EVT_BUTTON, self.OnClicked)

इन बटनों के आंतरिक लेबल क्रमशः NEW, OPEN और SAVE पर सेट हैं।

OnClicked () ईवेंट हैंडलर फ़ंक्शन स्रोत बटन के लेबल को पुनर्प्राप्त करता है, जिसके कारण क्लिक ईवेंट हुआ। वह लेबल कंसोल पर मुद्रित होता है।

def OnClicked(self, event): 
   btn = event.GetEventObject().GetLabel() 
   print "Label of pressed button = ",btn

टॉगल बटन क्लिक होने पर ऑनटॉगल () ईवेंट हैंडलर चालू हो जाता है। इसका राज्य GetValue () विधि द्वारा पढ़ा जाता है और तदनुसार, बटन का कैप्शन सेट किया जाता है।

def OnToggle(self,event): 
   state = event.GetEventObject().GetValue() 
   if state == True: 
      print "off" 
      event.GetEventObject().SetLabel("click to off") 
   else: 
      print "on" 
      event.GetEventObject().SetLabel("click to on")

पूर्ण कोड सूची इस प्रकार है -

import wx 
class Mywin(wx.Frame): 
   def __init__(self, parent, title): 
      super(Mywin, self).__init__(parent, title = title,size = (200,150))  
      panel = wx.Panel(self) 
      vbox = wx.BoxSizer(wx.VERTICAL) 
         
      self.btn = wx.Button(panel,-1,"click Me") 
      vbox.Add(self.btn,0,wx.ALIGN_CENTER) 
      self.btn.Bind(wx.EVT_BUTTON,self.OnClicked) 
         
      self.tbtn = wx.ToggleButton(panel , -1, "click to on") 
      vbox.Add(self.tbtn,0,wx.EXPAND|wx.ALIGN_CENTER) 
      self.tbtn.Bind(wx.EVT_TOGGLEBUTTON,self.OnToggle) 
         
      hbox = wx.BoxSizer(wx.HORIZONTAL) 
         
      bmp = wx.Bitmap("NEW.BMP", wx.BITMAP_TYPE_BMP) 
      self.bmpbtn = wx.BitmapButton(panel, id = wx.ID_ANY, bitmap = bmp,
         size = (bmp.GetWidth()+10, bmp.GetHeight()+10)) 
			
      hbox.Add(self.bmpbtn,0,wx.ALIGN_CENTER) 
      self.bmpbtn.Bind(wx.EVT_BUTTON,self.OnClicked) 
      self.bmpbtn.SetLabel("NEW") 
         
      bmp1 = wx.Bitmap("OPEN.BMP", wx.BITMAP_TYPE_BMP) 
      self.bmpbtn1 = wx.BitmapButton(panel, id = wx.ID_ANY, bitmap = bmp1,
         size = (bmp.GetWidth()+10, bmp.GetHeight()+10)) 
			
      hbox.Add(self.bmpbtn1,0,wx.ALIGN_CENTER) 
      self.bmpbtn1.Bind(wx.EVT_BUTTON,self.OnClicked) 
      self.bmpbtn1.SetLabel("OPEN") 
         
      bmp2 = wx.Bitmap("SAVE.BMP", wx.BITMAP_TYPE_BMP) 
      self.bmpbtn2 = wx.BitmapButton(panel, id = wx.ID_ANY, bitmap = bmp2,
         size = (bmp.GetWidth()+10, bmp.GetHeight()+10))
			
      hbox.Add(self.bmpbtn2,0,wx.ALIGN_CENTER) 
      self.bmpbtn2.Bind(wx.EVT_BUTTON,self.OnClicked)
      self.bmpbtn2.SetLabel("SAVE") 
         
      vbox.Add(hbox,1,wx.ALIGN_CENTER) 
      panel.SetSizer(vbox) 
        
      self.Centre() 
      self.Show() 
      self.Fit()  
		
   def OnClicked(self, event): 
      btn = event.GetEventObject().GetLabel() 
      print "Label of pressed button = ",btn 
		
   def OnToggle(self,event): 
      state = event.GetEventObject().GetValue() 
		
      if state == True: 
         print "Toggle button state off" 
         event.GetEventObject().SetLabel("click to off") 
      else: 
         print " Toggle button state on" 
         event.GetEventObject().SetLabel("click to on") 
             
app = wx.App() 
Mywin(None,  'Button demo') 
app.MainLoop()

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

दबाए गए बटन का लेबल = मुझे क्लिक करें

बटन बंद टॉगल करें

बटन स्थिति टॉगल करें

दबाया बटन का लेबल = नया

दबाए गए बटन का लेबल = OPEN

दबाए गए बटन का लेबल = सेव

wxAuiएक उन्नत उपयोगकर्ता इंटरफ़ेस लाइब्रेरी है जो wxWidgets API में शामिल है। WUI.aui.AuiManager AUI ढांचे में केंद्रीय वर्ग।

AuiManagerwx.aui.AuiPanelInfo ऑब्जेक्ट में प्रत्येक पैनल की जानकारी का उपयोग करके एक विशेष फ्रेम से जुड़े पैन का प्रबंधन करता है। आइए जानें पैनलइन्फो ऑब्जेक्ट कंट्रोल डॉकिंग और फ्लोटिंग व्यवहार के विभिन्न गुणों के बारे में।

शीर्ष स्तर के फ्रेम में डॉक करने योग्य विंडो डालने में निम्नलिखित चरण शामिल हैं -

सबसे पहले, AuiManager ऑब्जेक्ट बनाएं।

self.mgr = wx.aui.AuiManager(self)

फिर, आवश्यक नियंत्रण वाला एक पैनल डिज़ाइन किया गया है।

pnl = wx.Panel(self) 
pbox = wx.BoxSizer(wx.HORIZONTAL) 
text1 = wx.TextCtrl(pnl, -1, "Dockable", style = wx.NO_BORDER | wx.TE_MULTILINE) 
pbox.Add(text1, 1, flag = wx.EXPAND) 
pnl.SetSizer(pbox)

AuiPanelInfo के निम्न पैरामीटर सेट हैं।

  • Direction - टॉप, बॉटम, लेफ्ट, राइट या सेंटर

  • Position- डॉक करने योग्य क्षेत्र के अंदर एक से अधिक फलक रखे जा सकते हैं। प्रत्येक को एक स्थिति नंबर दिया जाता है।

  • Row- एक पंक्ति में एक से अधिक फलक दिखाई देते हैं। एक ही पंक्ति में दिखने वाले एक से अधिक टूलबार की तरह।

  • Layer - पैन को परतों में रखा जा सकता है।

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

info1 = wx.aui.AuiPaneInfo().Bottom() 
self.mgr.AddPane(pnl,info1)

बाकी शीर्ष स्तर की खिड़की में हमेशा की तरह अन्य नियंत्रण हो सकते हैं।

पूरा कोड इस प्रकार है -

import wx 
import wx.aui
  
class Mywin(wx.Frame):
  
   def __init__(self, parent, title): 
      super(Mywin, self).__init__(parent, title = title, size = (300,300)) 
		
      self.mgr = wx.aui.AuiManager(self)
		
      pnl = wx.Panel(self) 
      pbox = wx.BoxSizer(wx.HORIZONTAL)
      text1 = wx.TextCtrl(pnl, -1, "Dockable", style = wx.NO_BORDER | wx.TE_MULTILINE) 
      pbox.Add(text1, 1, flag = wx.EXPAND) 
      pnl.SetSizer(pbox) 
         
      info1 = wx.aui.AuiPaneInfo().Bottom() 
      self.mgr.AddPane(pnl, info1) 
      panel = wx.Panel(self) 
      text2 = wx.TextCtrl(panel, size = (300,200), style =  wx.NO_BORDER | wx.TE_MULTILINE) 
      box = wx.BoxSizer(wx.HORIZONTAL) 
      box.Add(text2, 1, flag = wx.EXPAND) 
         
      panel.SetSizerAndFit(box) 
      self.mgr.Update() 
		
      self.Bind(wx.EVT_CLOSE, self.OnClose) 
      self.Centre() 
      self.Show(True) 
		
   def OnClose(self, event): 
      self.mgr.UnInit() 
      self.Destroy() 
		
app = wx.App()
Mywin(None,"Dock Demo")  
app.MainLoop()

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

एक सामान्य GUI एप्लिकेशन में कई विंडो हो सकती हैं। टैब्ड और स्टैक्ड विजेट एक बार में एक ऐसी विंडो को सक्रिय करने की अनुमति देते हैं। हालाँकि, कई बार यह दृष्टिकोण उपयोगी नहीं हो सकता है क्योंकि अन्य विंडो छिपी हुई है।

एक साथ कई विंडो प्रदर्शित करने का एक तरीका उन्हें स्वतंत्र विंडो के रूप में बनाना है। इसे एसडीआई कहा जाता है (Single Document Interface)। इसके लिए अधिक मेमोरी संसाधनों की आवश्यकता होती है क्योंकि प्रत्येक विंडो का अपना मेनू सिस्टम, टूलबार आदि हो सकता है।

WxPython में MDI फ्रेमवर्क एक wx.MDiparentFrame वर्ग प्रदान करता है। इसकी वस्तु कई बाल खिड़कियों के लिए एक कंटेनर के रूप में कार्य करती है, प्रत्येक wx.MDIChildFrame वर्ग की एक वस्तु है।

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

उदाहरण

निम्न उदाहरण MDIParentFrame के उपयोग को शीर्ष स्तर की खिड़की के रूप में दिखाता है। NewWindow नामक एक मेनू बटन क्लाइंट क्षेत्र में एक बच्चा विंडो जोड़ता है। कई खिड़कियों को जोड़ा जा सकता है और फिर एक कैस्केड या टाइल वाले क्रम में व्यवस्थित किया जा सकता है।

पूरा कोड इस प्रकार है -

import wx 
 
class MDIFrame(wx.MDIParentFrame): 
   def __init__(self): 
      wx.MDIParentFrame.__init__(self, None, -1, "MDI Parent", size = (600,400)) 
      menu = wx.Menu() 
      menu.Append(5000, "&New Window") 
      menu.Append(5001, "&Exit") 
      menubar = wx.MenuBar() 
      menubar.Append(menu, "&File") 
		
      self.SetMenuBar(menubar) 
      self.Bind(wx.EVT_MENU, self.OnNewWindow, id = 5000) 
      self.Bind(wx.EVT_MENU, self.OnExit, id = 5001) 
		
   def OnExit(self, evt): 
      self.Close(True)  
		
   def OnNewWindow(self, evt): 
      win = wx.MDIChildFrame(self, -1, "Child Window")
      win.Show(True) 
		
app = wx.App() 
frame = MDIFrame() 
frame.Show() 
app.MainLoop()

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

GDI+ (ग्राफिक्स ड्राइंग इंटरफ़ेस), CoreGraphics तथा Cairo librarieswxPython में ड्राइंग API की रूपरेखा तैयार करें। wx.GraphicsContext प्राथमिक ड्रॉबल ऑब्जेक्ट है, जिसके उपयोग से विभिन्न डिवाइस संदर्भ ऑब्जेक्ट बनाए जाते हैं।

wx.DC एक अमूर्त वर्ग है। इसकी व्युत्पन्न कक्षाएं विभिन्न उपकरणों पर ग्राफिक्स और पाठ को प्रस्तुत करने के लिए उपयोग की जाती हैं। डिवाइस संदर्भ वर्ग हैं -

  • wx.ScreenDC - स्क्रीन पर पेंट करने के लिए इसका उपयोग करें, जैसा कि एक व्यक्तिगत विंडो के विपरीत है।

  • wx.ClientDC - खिड़की के ग्राहक क्षेत्र (सीमाओं और अन्य सजावट के बिना हिस्सा) पर पेंट करने के लिए इसका उपयोग करें, लेकिन एक wxPaintEvent के भीतर से इसका उपयोग न करें।

  • wx.PaintDC- विंडो के क्लाइंट क्षेत्र पर पेंट करने के लिए इसका उपयोग करें, लेकिन केवल एक wxPaintEvent के भीतर से।

  • wx.WindowDC- सजावट सहित खिड़की के पूरे क्षेत्र पर पेंट करने के लिए इसका उपयोग करें। यह गैर-विंडोज प्लेटफार्मों पर उपलब्ध नहीं हो सकता है।

WxPython का आरेखण API आरेखण, पाठ और छवि बनाने के लिए अलग-अलग कार्य प्रदान करता है। ड्राइंग उद्देश्य के लिए आवश्यक वस्तुओं, जैसे कि कलर, पेन, ब्रश और फॉन्ट का निर्माण भी GDI कक्षाओं का उपयोग करके किया जा सकता है।

wx.Colour क्लास

रंग वस्तु आरजीबी (लाल, हरा और नीला) तीव्रता मूल्यों के संयोजन का प्रतिनिधित्व करती है, प्रत्येक 0-255 के पैमाने पर। कुछ पूर्वनिर्धारित रंग वस्तुएं हैं जैसे -

  • wxBLACK
  • wxBLUE
  • wxCYAN
  • wxGREEN
  • wxYELLOW
  • wxLIGHT_GREY
  • wxRED
  • wxWHITE

RGB मानों के कस्टम संयोजन के साथ रंग बनता है wx.Colour object

wx.Colour(r,g,b)

wx.Pen वर्ग

पेन ऑब्जेक्ट ग्राफिक्स के आकार, लाइन, आयत, सर्कल आदि की रंग, चौड़ाई और शैली को निर्धारित करता है।

Predefined Pen objects हैं -

wxBLACK_DASHED_PEN
wxBLACK_PEN
wxBLUE_PEN
wxCYAN_PEN
wxGREEN_PEN
wxYELLOW_PEN
wxGREY_PEN
wxLIGHT_GREY_PEN
wxMEDIUM_GREY_PEN
wxRED_PEN
wxTRANSPARENT_PEN
wxWHITE_PEN

Predefined Pen styles हैं -

wx.SOLID
wx.DOT
wx.LONG_DASH
wx.SHORT_DASH
wx.DOT_DASH
wx.TRANSPARENT

wx.Brush क्लास

आयत, दीर्घवृत्त, वृत्त आदि जैसी आकृतियों की पृष्ठभूमि को भरने के लिए ब्रश एक अन्य प्राथमिक ग्राफिक्स वस्तु है।

एक कस्टम ब्रश ऑब्जेक्ट को wx.Colour और ब्रश स्टाइल पैरामीटर की आवश्यकता होती है। निम्नलिखित पूर्वनिर्धारित ब्रश शैलियों की एक सूची है -

wx.SOLID
wx.STIPPLE
wx.BDIAGONAL_HATCH
wx.CROSSDIAG_HATCH
wx.FDIAGONAL_HATCH
wx.CROSS_HATCH
wx.HORIZONTAL_HATCH
wx.VERTICAL_HATCH
wx.TRANSPARENT

wxPython में कई कार्य हैं जो विभिन्न आकृतियों, पाठ और छवि को चित्रित करने की सुविधा प्रदान करते हैं।

एस.एन. कार्य और विवरण
1

DrawRectangle()

दिए गए आयामों की एक आयत खींचता है

2

DrawCircle()

केंद्र और त्रिज्या के रूप में दिए गए बिंदु पर एक वृत्त खींचता है

3

DrawEllipse()

दिए गए x और y त्रिज्या के साथ एक दीर्घवृत्त खींचता है

4

DrawLine()

एक रेखा खींचता है दो wx.Point ऑब्जेक्ट

5

DrawBitmap()

दिए गए स्थान पर एक चित्र बनाएँ

6

DrawText()

दिए गए पाठ को निर्दिष्ट स्थान पर प्रदर्शित करता है

उदाहरण

उपरोक्त कार्यों को निम्नलिखित उदाहरण में लागू किया गया है, जिससे पेन, ब्रश, रंग और फ़ॉन्ट ऑब्जेक्ट का उपयोग किया जाता है।

पूरा कोड इस प्रकार है -

import wx 
 
class Mywin(wx.Frame): 
            
   def __init__(self, parent, title): 
      super(Mywin, self).__init__(parent, title = title,size = (500,300))  
      self.InitUI() 
         
   def InitUI(self): 
      self.Bind(wx.EVT_PAINT, self.OnPaint) 
      self.Centre() 
      self.Show(True)
		
   def OnPaint(self, e): 
      dc = wx.PaintDC(self) 
      brush = wx.Brush("white")  
      dc.SetBackground(brush)  
      dc.Clear() 
        
      dc.DrawBitmap(wx.Bitmap("python.jpg"),10,10,True) 
      color = wx.Colour(255,0,0)
      b = wx.Brush(color) 
		
      dc.SetBrush(b) 
      dc.DrawCircle(300,125,50) 
      dc.SetBrush(wx.Brush(wx.Colour(255,255,255))) 
      dc.DrawCircle(300,125,30) 
		
      font = wx.Font(18, wx.ROMAN, wx.ITALIC, wx.NORMAL) 
      dc.SetFont(font) 
      dc.DrawText("Hello wxPython",200,10) 
		
      pen = wx.Pen(wx.Colour(0,0,255)) 
      dc.SetPen(pen) 
      dc.DrawLine(200,50,350,50) 
      dc.SetBrush(wx.Brush(wx.Colour(0,255,0), wx.CROSS_HATCH)) 
      dc.DrawRectangle(380, 15, 90, 60) 
		
ex = wx.App() 
Mywin(None,'Drawing demo') 
ex.MainLoop()

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

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

ड्रैग और ड्रॉप ऑपरेशन में निम्नलिखित चरण शामिल हैं -

  • एक ड्रॉप लक्ष्य घोषित करें
  • डेटा ऑब्जेक्ट बनाएँ
  • Wx.DropSource बनाएँ
  • ड्रैग ऑपरेशन निष्पादित करें
  • रद्द करें या ड्रॉप स्वीकार करें

WxPython में, दो पूर्वनिर्धारित ड्रॉप लक्ष्य हैं -

  • wx.TextDropTarget
  • wx.FileDropTarget

कई wxPython विगेट्स ड्रैग एंड ड्रॉप गतिविधि का समर्थन करते हैं। स्रोत नियंत्रण में ड्रैगिंग सक्षम होना चाहिए, जबकि लक्ष्य नियंत्रण ड्रैग को स्वीकार (अस्वीकार) करने की स्थिति में होना चाहिए।

स्रोत डेटा जिसे उपयोगकर्ता खींच रहा है उसे लक्ष्य ऑब्जेक्ट पर रखा गया है। OnDropText () की लक्ष्य वस्तु डेटा का उपभोग करती है। यदि वांछित है, तो स्रोत ऑब्जेक्ट का डेटा हटाया जा सकता है।

उदाहरण

निम्नलिखित उदाहरण में, दो ListCrl वस्तुओं को एक बॉक्स Sizer में क्षैतिज रूप से रखा गया है। बाईं ओर सूची भाषाओं [] डेटा के साथ आबादी है। इसे ड्रैग के स्रोत के रूप में नामित किया गया है। दाईं ओर एक लक्ष्य है।

languages = ['C', 'C++', 'Java', 'Python', 'Perl', 'JavaScript', 'PHP', 'VB.NET','C#'] 
self.lst1 = wx.ListCtrl(panel, -1, style = wx.LC_LIST) 
self.lst2 = wx.ListCtrl(panel, -1, style = wx.LC_LIST) 

   for lang in languages: 
      self.lst1.InsertStringItem(0,lang)

दूसरी सूची नियंत्रण खाली है और TextDropTarget वर्ग की वस्तु के लिए एक तर्क है।

class MyTextDropTarget(wx.TextDropTarget):
   def __init__(self, object): 
      wx.TextDropTarget.__init__(self) 
      self.object = object
		
   def OnDropText(self, x, y, data): 
      self.object.InsertStringItem(0, data)

OnDropText () विधि लक्ष्य सूची नियंत्रण में स्रोत डेटा जोड़ता है।

ड्रैग ऑपरेशन को ईवेंट बाइंडर द्वारा आरंभ किया जाता है।

wx.EVT_LIST_BEGIN_DRAG(self, self.lst1.GetId(), self.OnDragInit)

OnDragInit () फ़ंक्शन टारगेट पर ड्रैग डेटा डालता है और स्रोत से हटाता है।

def OnDragInit(self, event): 
   text = self.lst1.GetItemText(event.GetIndex()) 
   tobj = wx.PyTextDataObject(text) 
   src = wx.DropSource(self.lst1) 
   src.SetData(tobj) 
   src.DoDragDrop(True) 
   self.lst1.DeleteItem(event.GetIndex())

पूरा कोड इस प्रकार है -

import wx
  
class MyTarget(wx.TextDropTarget): 
   def __init__(self, object): 
      wx.TextDropTarget.__init__(self) 
      self.object = object  
		
   def OnDropText(self, x, y, data): 
      self.object.InsertStringItem(0, data)  
		
class Mywin(wx.Frame): 
            
   def __init__(self, parent, title): 
      super(Mywin, self).__init__(parent, title = title,size = (-1,300))   
      panel = wx.Panel(self) 
      box = wx.BoxSizer(wx.HORIZONTAL)  
      languages = ['C', 'C++', 'Java', 'Python', 'Perl', 'JavaScript',
         'PHP', 'VB.NET','C#']
			
      self.lst1 = wx.ListCtrl(panel, -1, style = wx.LC_LIST) 
      self.lst2 = wx.ListCtrl(panel, -1, style = wx.LC_LIST) 
      for lang in languages: 
      self.lst1.InsertStringItem(0,lang) 
             
      dt = MyTarget(self.lst2) 
      self.lst2.SetDropTarget(dt) 
      wx.EVT_LIST_BEGIN_DRAG(self, self.lst1.GetId(), self.OnDragInit)
		
      box.Add(self.lst1,0,wx.EXPAND) 
      box.Add(self.lst2, 1, wx.EXPAND) 
		
      panel.SetSizer(box) 
      panel.Fit() 
      self.Centre() 
      self.Show(True)  
     
   def OnDragInit(self, event): 
      text = self.lst1.GetItemText(event.GetIndex()) 
      tobj = wx.PyTextDataObject(text) 
      src = wx.DropSource(self.lst1) 
      src.SetData(tobj) 
      src.DoDragDrop(True) 
      self.lst1.DeleteItem(event.GetIndex()) 
		
ex = wx.App() 
Mywin(None,'Drag&Drop Demo') 
ex.MainLoop()

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