Jython - लेआउट प्रबंधन

जावा में लेआउट प्रबंधक वे वर्ग हैं, जो कंटेनर ऑब्जेक्ट्स में नियंत्रणों की नियुक्ति का प्रबंधन करते हैं जैसे Frame, Dialog या Panel। लेआउट प्रबंधक किसी फ़्रेम में नियंत्रण की सापेक्ष स्थिति बनाए रखते हैं, भले ही रिज़ॉल्यूशन बदल जाए या फ़्रेम स्वयं आकार बदल जाता है।

ये वर्ग लागू करते हैं Layout interface। निम्नलिखित लेआउट प्रबंधकों को परिभाषित किया गया हैAWT library -

  • BorderLayout
  • FlowLayout
  • GridLayout
  • CardLayout
  • GridBagLayout

निम्नलिखित लेआउट प्रबंधक में परिभाषित किए गए हैं Swing library -

  • BoxLayout
  • GroupLayout
  • ScrollPaneLayout
  • SpringLayout

हम निम्नलिखित उदाहरणों में AWT लेआउट प्रबंधकों और स्विंग लेआउट प्रबंधकों का उपयोग करेंगे।

  • पूर्ण लेआउट
  • प्रवाह लेआउट
  • जाली का नक्शा
  • बॉर्डर लेआउट
  • बॉक्स लेआउट
  • समूह लेआउट

आइए अब हम इनमें से प्रत्येक के बारे में विस्तार से चर्चा करें।

पूर्ण लेआउट

इससे पहले कि हम उपरोक्त सभी लेआउट प्रबंधकों का पता लगाएं, हमें एक कंटेनर में नियंत्रण की पूर्ण स्थिति को देखना चाहिए। हमें फ्रेम ऑब्जेक्ट के लेआउट विधि को 'कोई नहीं' पर सेट करना होगा।

frame.setLayout(None)

फिर कॉल करके नियंत्रण रखें setBounds()तरीका। यह चार तर्क लेता है - x स्थिति, y स्थिति, चौड़ाई और ऊंचाई।

उदाहरण के लिए - एक बटन ऑब्जेक्ट को पूर्ण स्थिति पर और पूर्ण आकार के साथ रखने के लिए।

btn = JButton("Add")
btn.setBounds(60,80,60,20)

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

निम्नलिखित जाइथन स्क्रिप्ट में, तीन Jlabel ऑब्जेक्ट्स क्रमशः "phy", "maths" और "Total Total" प्रदर्शित करने के लिए उपयोग किए जाते हैं। इन तीनों के सामने - JTextField ऑब्जेक्ट्स रखे गए हैं। एक बटन ऑब्जेक्ट "कुल" लेबल के ऊपर रखा गया है।

सबसे पहले JFrame विंडो को लेआउट सेट के साथ बनाया जाता है।

frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(300,200)
frame.setLayout(None)

फिर उनकी पूर्ण स्थिति और आकार के अनुसार विभिन्न नियंत्रण जोड़े जाते हैं। पूरा कोड नीचे दिया गया है -

from javax.swing import JFrame, JLabel, JButton, JTextField

frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(300,200)
frame.setLayout(None)

lbl1 = JLabel("Phy")
lbl1.setBounds(60,20,40,20)
txt1 = JTextField(10)
txt1.setBounds(120,20,60,20)
lbl2 = JLabel("Maths")
lbl2.setBounds(60,50,40,20)
txt2 = JTextField(10)
txt2.setBounds(120, 50, 60,20)
btn = JButton("Add")
btn.setBounds(60,80,60,20)
lbl3 = JLabel("Total")
lbl3.setBounds(60,110,40,20)
txt3 = JTextField(10)
txt3.setBounds(120, 110, 60,20)

frame.add(lbl1)
frame.add(txt1)
frame.add(lbl2)
frame.add(txt2)
frame.add(btn)
frame.add(lbl3)
frame.add(txt3)
frame.setVisible(True)

उपरोक्त कोड के लिए आउटपुट निम्नानुसार है।

ज्यथोन फ्लो लयआउट

FlowLayout कंटेनर कक्षाओं के लिए डिफ़ॉल्ट लेआउट प्रबंधक है। यह बाएं से दाएं और फिर ऊपर से नीचे की दिशा में नियंत्रण की व्यवस्था करता है।

निम्न उदाहरण में, एक Jlabel ऑब्जेक्ट, JTextField ऑब्जेक्ट और JButton ऑब्जेक्ट को FlowLayout मैनेजर का उपयोग करके JFrame में प्रदर्शित किया जाना है। के साथ शुरू करने के लिए, हम से आवश्यक वर्गों का आयात करते हैंjavax.swing पैकेज और java.awt पैकेज।

from javax.swing import JFrame, JLabel, JButton, JTextField
from java.awt import FlowLayout

फिर एक JFrame ऑब्जेक्ट बनाएं और उसके स्थान के साथ-साथ आकार गुण भी सेट करें।

frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(200,200)
Set the layout manager for the frame as FlowLayout.
frame.setLayout(FlowLayout())

अब JLabel, JTextfield और JButton वर्गों के लिए ऑब्जेक्ट घोषित करें।

label = JLabel("Welcome to Jython Swing")
txt = JTextField(30)
btn = JButton("ok")

अंत में फ्रेम में इन नियंत्रणों को कॉल करके जोड़ें add() JFrame वर्ग की विधि।

frame.add(label)
frame.add(txt)
frame.add(btn)

फ़्रेम प्रदर्शित करने के लिए, इसकी दृश्यमान संपत्ति को सत्य पर सेट करें। पूरी ज्योनट स्क्रिप्ट और इसका आउटपुट नीचे दिया गया है -

from javax.swing import JFrame, JLabel, JButton, JTextField
from java.awt import FlowLayout

frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(200,200)

frame.setLayout(FlowLayout())

label = JLabel("Welcome to Jython Swing")
txt = JTextField(30)
btn = JButton("ok")

frame.add(label)
frame.add(txt)
frame.add(btn)
frame.setVisible(True)

जाइथन ग्रिडलैयूट

Gridlayout प्रबंधक एक आयताकार ग्रिड में नियंत्रण की नियुक्ति की अनुमति देता है। ग्रिड के प्रत्येक सेल में एक नियंत्रण रखा जाता है।

निम्नलिखित उदाहरण में, ग्रिडलाइउट को 4 पंक्तियों और 4 कॉलमों में विभाजित करते हुए JFrame ऑब्जेक्ट पर लागू किया जाता है। ग्रिड के प्रत्येक सेल में एक JButton ऑब्जेक्ट रखा जाना है।

आइए हम पहले आवश्यक पुस्तकालयों का आयात करें -

from javax.swing import JFrame, JButton
from java.awt import GridLayout

फिर JFrame कंटेनर बनाएं -

frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(400,400)

अब, इसके आयामों को 4 द्वारा 4 के रूप में निर्दिष्ट करके GridLayout लागू करें।

frame.setLayout(GridLayout(4,4))

हमें अब दो लूप्स का उपयोग करना चाहिए, प्रत्येक 1 से 4 तक जा रहा है, इसलिए सोलह जेबटन ऑब्जेक्ट्स को बाद की कोशिकाओं में रखा गया है।

k = 0
frame.setLayout(GridLayout(4,4))
for i in range(1,5):
   for j in range(1,5):
      k = k+1
      frame.add(JButton(str(k)))

अंत में फ्रेम की दृश्यता को सही पर सेट करें। पूरा Jython कोड नीचे दिया गया है।

from javax.swing import JFrame, JButton
from java.awt import GridLayout

frame = JFrame("Hello")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setLocation(100,100)
frame.setSize(400,400)

frame.setLayout(GridLayout(4,4))

k = 0
for i in range(1,5):
   for j in range(1,5):
      k = k+1
      frame.add(JButton(str(k)))

frame.setVisible(True)

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

ज्यथोन बॉर्डरलेयूट

BorderLayout प्रबंधक कंटेनर को पाँच भौगोलिक क्षेत्रों और प्रत्येक क्षेत्र में एक घटक के साथ विभाजित करता है। इन क्षेत्रों को निम्न रूप से परिभाषित स्थिरांक द्वारा दर्शाया गया है -

  • BorderLayout.NORTH
  • BorderLayout.SOUTH
  • BorderLayout.EAST
  • BorderLayout.WEST
  • BorderLayout.CENTER

आइए हम निम्नलिखित उदाहरण पर विचार करें -

ज्यथॉन बॉक्स लियआउट

BoxLayout वर्ग में परिभाषित किया गया है javax.swing package। इसका उपयोग कंटेनर में घटकों को खड़ी या क्षैतिज रूप से व्यवस्थित करने के लिए किया जाता है। दिशा निम्नलिखित स्थिरांक द्वारा निर्धारित की जाती है -

  • X_AXIS
  • Y_AXIS
  • LINE_AXIS
  • PAGE_AXIS

पूर्णांक स्थिरांक उस अक्ष को निर्दिष्ट करता है जिसके साथ कंटेनर के घटकों को बाहर रखा जाना चाहिए। जब कंटेनर में डिफ़ॉल्ट घटक अभिविन्यास होता है, तो LINE_AXIS निर्दिष्ट करता है कि घटकों को बाएं से दाईं ओर रखा जाए, और PAGE_AXIS निर्दिष्ट करता है कि घटकों को ऊपर से नीचे तक बिछाया जाए।

निम्नलिखित उदाहरण में, पैनल (JPanel वर्ग का) JFrame ऑब्जेक्ट में जोड़ा गया है। वर्टिकल बॉक्स लियूट इसे लगाया जाता है और इसमें दो और पैनल, ऊपर और नीचे जोड़े जाते हैं। इन दोनों आंतरिक पैनलों में दो बटन हैं जो क्षैतिज बॉक्सलेउटआउट में जोड़े गए हैं।

आइए हम पहले शीर्ष-स्तरीय JFrame विंडो बनाएँ।

frame = JFrame()
frame.setTitle("Buttons")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setSize(300, 150)

JPanel ऑब्जेक्ट को एक लंबवत BoxLayout घोषित किया गया है। इसे शीर्ष-स्तरीय फ्रेम में जोड़ें।

panel = JPanel()
panel.setLayout(BoxLayout(panel, BoxLayout.Y_AXIS))
frame.add(panel)

इस पैनल में, दो और पैनल ऊपर और नीचे जोड़े जाते हैं। उनमें से प्रत्येक में दो JButton ऑब्जेक्ट हैं, जो उन्हें क्षैतिज रूप से 25 पिक्सेल के एक अंतरिक्ष धारक के साथ जोड़कर उन्हें अलग करते हैं।

###top panel
top = JPanel()
top.setLayout(BoxLayout(top, BoxLayout.X_AXIS))
b1 = JButton("OK")
b2 = JButton("Close")
top.add(Box.createVerticalGlue())
top.add(b1)
top.add(Box.createRigidArea(Dimension(25, 0)))
top.add(b2)

इसी तरह, नीचे पैनल का निर्माण किया जाता है।

###bottom panel
bottom = JPanel()
bottom.setLayout(BoxLayout(bottom, BoxLayout.X_AXIS))
b3 = JButton("Open")
b4 = JButton("Save")
bottom.add(b3)
bottom.add(Box.createRigidArea(Dimension(25, 0)))
bottom.add(b4)
bottom.add(Box.createVerticalGlue())

ध्यान दें कि createRigidArea()फ़ंक्शन का उपयोग दो बटनों के बीच 25 पिक्सेल का स्थान बनाने के लिए किया जाता है। यह भीcreateVerticalGlue() फ़ंक्शन लेआउट में अग्रणी या अनुगामी स्थान रखता है।

इसके साथ शुरू करने के लिए, ऊपर और नीचे के पैनल जोड़ें और फ्रेम की दृश्यता संपत्ति को सही पर सेट करें। पूरा कोड इस प्रकार है -

from java.awt import Dimension
from javax.swing import JButton, JFrame,JPanel,BoxLayout,Box

frame = JFrame()
frame.setTitle("Buttons")
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
frame.setSize(300, 150)

panel = JPanel()
panel.setLayout(BoxLayout(panel, BoxLayout.Y_AXIS))
frame.add(panel)

###top panel
top = JPanel()
top.setLayout(BoxLayout(top, BoxLayout.X_AXIS))
b1 = JButton("OK")
b2 = JButton("Close")
top.add(Box.createVerticalGlue())
top.add(b1)
top.add(Box.createRigidArea(Dimension(25, 0)))
top.add(b2)

###bottom panel
bottom = JPanel()
bottom.setLayout(BoxLayout(bottom, BoxLayout.X_AXIS))
b3 = JButton("Open")
b4 = JButton("Save")
bottom.add(b3)
bottom.add(Box.createRigidArea(Dimension(25, 0)))
bottom.add(b4)
bottom.add(Box.createVerticalGlue())

panel.add(bottom)
panel.add(top)
frame.setVisible(True)

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

जयतोन ग्रुप लयआउट

GroupLayout प्रबंधक घटकों को एक श्रेणीबद्ध तरीके से समूहित करता है। समूहन दो वर्गों द्वारा किया जाता है,SequentialGroup तथा ParallelGroup, दोनों जावा में ग्रुप इंटरफ़ेस लागू करते हैं।

लेआउट प्रक्रिया दो चरणों में विभाजित है। एक-चरण में, घटकों को क्षैतिज अक्ष के साथ रखा जाता है, और दूसरे में ऊर्ध्वाधर अक्ष के साथ। प्रत्येक घटक को लेआउट में दो बार परिभाषित किया जाना चाहिए।

क्रमबद्ध और समानांतर दो प्रकार की व्यवस्थाएँ हैं। दोनों में, हम घटकों को क्रमिक रूप से या समानांतर में व्यवस्थित कर सकते हैं। क्षैतिज व्यवस्था में, पंक्ति को अनुक्रमिक समूह कहा जाता है और स्तंभ को समानांतर समूह कहा जाता है। दूसरी ओर, समानांतर व्यवस्था में, तत्व की पंक्ति एक समानांतर समूह और एक स्तंभ है, जिसे अनुक्रमिक कहा जाता है।

निम्नलिखित उदाहरण में, पांच बटन इस तरह से व्यवस्थित किए गए हैं कि तीन प्रत्येक पंक्ति और स्तंभ में दिखाई देते हैं। इसके साथ शुरू करने के लिए, JFrame विंडो में एक Jpanel ऑब्जेक्ट जोड़ें और Grouplayout के रूप में इसका लेआउट सेट करें।

frame =  JFrame()
panel =  JPanel()
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
layout =  GroupLayout(panel)
panel.setLayout(layout)

फिर JButton ऑब्जेक्ट्स का निर्माण करें -

buttonD = JButton("D")
buttonR = JButton("R")
buttonY = JButton("Y")
buttonO = JButton("O")
buttonT = JButton("T")

अगला, हम एक बनाते हैं SequentialGroup नामित LeftToRightकौन सा बटन और बटन जोड़ा जाता है। उनके बीच में, एक ParallelGroup ColumnMiddle (अन्य तीन बटन के साथ लंबवत जोड़ा गया) रखा गया है।

leftToRight = layout.createSequentialGroup()
leftToRight.addComponent(buttonD)
columnMiddle = layout.createParallelGroup()
columnMiddle.addComponent(buttonR)
columnMiddle.addComponent(buttonO)
columnMiddle.addComponent(buttonT)
leftToRight.addGroup(columnMiddle)
leftToRight.addComponent(buttonY)

अब ऊर्ध्वाधर SequentialGroup की परिभाषा TopToBottom कहा जाता है। तीन बटनों की पैरेललग्रुप पंक्ति जोड़ें और फिर दो बटन लंबवत आराम करें।

topToBottom = layout.createSequentialGroup()
rowTop = layout.createParallelGroup()
rowTop.addComponent(buttonD)
rowTop.addComponent(buttonR)
rowTop.addComponent(buttonY)
topToBottom.addGroup(rowTop)
topToBottom.addComponent(buttonO)
topToBottom.addComponent(buttonT)

अंत में, LeftToRight समूह को क्षैतिज रूप से और TopToBottom समूह को लेआउट ऑब्जेक्ट पर लंबवत सेट करें। पूरा कोड नीचे दिया गया है -

from javax.swing import JButton, JFrame,JPanel,GroupLayout

frame = JFrame()
panel = JPanel()
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE)
layout = GroupLayout(panel)
panel.setLayout(layout)

buttonD = JButton("D")
buttonR = JButton("R")
buttonY = JButton("Y")
buttonO = JButton("O")
buttonT = JButton("T")

leftToRight = layout.createSequentialGroup()
leftToRight.addComponent(buttonD)
columnMiddle = layout.createParallelGroup()
columnMiddle.addComponent(buttonR)
columnMiddle.addComponent(buttonO)
columnMiddle.addComponent(buttonT)
leftToRight.addGroup(columnMiddle)
leftToRight.addComponent(buttonY)

topToBottom = layout.createSequentialGroup()
rowTop = layout.createParallelGroup()
rowTop.addComponent(buttonD)
rowTop.addComponent(buttonR)
rowTop.addComponent(buttonY)
topToBottom.addGroup(rowTop)
topToBottom.addComponent(buttonO)
topToBottom.addComponent(buttonT)

layout.setHorizontalGroup(leftToRight)
layout.setVerticalGroup(topToBottom)

frame.add(panel)
frame.pack()
frame.setVisible(True)

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