PyQt5 - त्वरित गाइड
PyQt एक GUI विजेट टूलकिट है। यह एक पायथन इंटरफ़ेस हैQtसबसे शक्तिशाली और लोकप्रिय क्रॉस-प्लेटफ़ॉर्म GUI लाइब्रेरी में से एक है। PyQt नदी किनारे कम्प्यूटिंग लिमिटेड द्वारा विकसित किया गया था PyQt के नवीनतम संस्करण को अपनी आधिकारिक वेबसाइट से डाउनलोड किया जा सकता है - riverbankcomputing.com
PyQt एपीआई बड़ी संख्या में वर्गों और कार्यों वाले मॉड्यूल का एक सेट है। जबकिQtCore मॉड्यूल में फ़ाइल और निर्देशिका आदि के साथ काम करने के लिए गैर-जीयूआई कार्यक्षमता शामिल है, QtGuiमॉड्यूल में सभी ग्राफिकल नियंत्रण शामिल हैं। इसके अलावा, एक्सएमएल के साथ काम करने के लिए मॉड्यूल हैं(QtXml), एसवीजी (QtSvg)और एसक्यूएल (QtSql), आदि।
अक्सर उपयोग किए जाने वाले मॉड्यूल की एक सूची नीचे दी गई है -
QtCore - कोर गैर-जीयूआई कक्षाएं अन्य मॉड्यूल द्वारा उपयोग की जाती हैं
QtGui - ग्राफिकल यूजर इंटरफेस घटक
QtMultimedia - निम्न-स्तरीय मल्टीमीडिया प्रोग्रामिंग के लिए कक्षाएं
QtNetwork - नेटवर्क प्रोग्रामिंग के लिए कक्षाएं
QtOpenGL - ओपनगैल सपोर्ट क्लासेस
QtScript - क्यूटी लिपियों के मूल्यांकन के लिए कक्षाएं
QtSql एसक्यूएल का उपयोग कर डेटाबेस एकीकरण के लिए कक्षाएं
QtSvg - एसवीजी फ़ाइलों की सामग्री को प्रदर्शित करने के लिए कक्षाएं
QtWebKit - HTML के प्रतिपादन और संपादन के लिए कक्षाएं
QtXml - एक्सएमएल से निपटने के लिए कक्षाएं
QtWidgets - क्लासिक डेस्कटॉप शैली यूआई बनाने के लिए कक्षाएं
QtDesigner - क्यूटी डिजाइनर का विस्तार करने के लिए कक्षाएं
सहायक वातावरण
PyQt विंडोज, लिनक्स और मैक ओएस सहित सभी लोकप्रिय ऑपरेटिंग सिस्टम के साथ संगत है। यह दोहरे लाइसेंस वाला है, जो जीपीएल के साथ-साथ वाणिज्यिक लाइसेंस के तहत उपलब्ध है। नवीनतम स्थिर संस्करण हैPyQt5-5.13.2.
खिड़कियाँ
32-बिट या 64-बिट आर्किटेक्चर के लिए पहियों को प्रदान किया जाता है जो पायथन संस्करण 3.5 या उसके बाद के अनुरूप हैं। इंस्टॉल करने का अनुशंसित तरीका उपयोग कर रहा हैPIP उपयोगिता -
pip3 install PyQt5
PyQt5 पहियों का समर्थन करने के लिए Qt डिज़ाइनर जैसे विकास उपकरण स्थापित करने के लिए, निम्नलिखित आदेश है -
pip3 install pyqt5-tools
आप स्रोत कोड www.riverbankcomputing.com/static/Downloads/PyQt5 से Linux / macOS पर PyQt5 भी बना सकते हैं
PyQt5 API पहले के संस्करणों के साथ स्वचालित रूप से संगत नहीं है। इसलिए, प्रासंगिक बदलाव करके PyQt4 मॉड्यूल वाले पायथन कोड को मैन्युअल रूप से अपग्रेड किया जाना चाहिए। इस अध्याय में, PyQt4 और PyQt5 के बीच मुख्य अंतर सूचीबद्ध किए गए हैं।
PyQt5 पहले v2.6 की तुलना में पायथन के संस्करणों पर समर्थित नहीं है।
PyQt5 सिग्नल और स्लॉट के बीच संबंध के लिए QObject क्लास के कनेक्ट () पद्धति का समर्थन नहीं करता है। इसलिए उपयोग को और अधिक लागू नहीं किया जा सकता है -
QObject.connect(widget, QtCore.SIGNAL(‘signalname’), slot_function)
केवल निम्नलिखित सिंटैक्स को परिभाषित किया गया है -
widget.signal.connect(slot_function)
पहले QtGui मॉड्यूल में परिभाषित कक्षाएं वितरित की गई हैं QtGui, QtPrintSupport एक QtWidgets मॉड्यूल।
नए QFileDialog वर्ग में, द getOpenFileNameAndFilter() विधि द्वारा प्रतिस्थापित किया जाता है getOpenFileName(), getOpenFileNamesAndFilter() द्वारा getOpenFileNames() तथा getSaveFileNameAndFilter() द्वारा getSaveFileName()। इन विधियों के पुराने हस्ताक्षर भी बदल गए हैं।
PyQt5 में एक वर्ग को परिभाषित करने का प्रावधान नहीं है जो एक से अधिक Qt वर्ग से उप-वर्गीय है।
pyuic5 उपयोगिता (डिज़ाइनर की XML फ़ाइल से पायथन कोड उत्पन्न करने के लिए) --pyqt3-आवरण फ्लैग का समर्थन नहीं करता है।
pyrcc5-py2 और -py3 झंडे का समर्थन नहीं करता है। Pyrcc5 का आउटपुट पाइथन v2.6 के सभी संस्करणों के साथ संगत है।
PyQt5 हमेशा आक्रमण करता है sip.setdestroyonexit() स्वचालित रूप से और सभी लिपटे उदाहरणों के सी ++ विध्वंसक को कॉल करता है जो इसके मालिक हैं।
PyQt का उपयोग करके एक सरल GUI एप्लिकेशन बनाना निम्नलिखित चरणों में शामिल है -
PyQt5 पैकेज से QtCore, QtGui और QtWidgets मॉड्यूल आयात करें।
QApplication class का एक एप्लिकेशन ऑब्जेक्ट बनाएं।
QWidget ऑब्जेक्ट शीर्ष स्तर की विंडो बनाता है। इसमें QLabel ऑब्जेक्ट जोड़ें।
लेबल के कैप्शन को "हैलो वर्ल्ड" के रूप में सेट करें।
SetGeometry () विधि द्वारा विंडो के आकार और स्थिति को परिभाषित करें।
द्वारा आवेदन का मुख्य भाग दर्ज करें app.exec_() तरीका।
निम्नलिखित PyQt में हैलो वर्ल्ड प्रोग्राम निष्पादित करने के लिए कोड है -
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def window():
app = QApplication(sys.argv)
w = QWidget()
b = QLabel(w)
b.setText("Hello World!")
w.setGeometry(100,100,200,50)
b.move(50,20)
w.setWindowTitle("PyQt5")
w.show()
sys.exit(app.exec_())
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
उपरोक्त कोड का एक वस्तु उन्मुख समाधान विकसित करना भी संभव है।
PyQt5 पैकेज से QtCore, QtGui और QtWidgets मॉड्यूल आयात करें।
QApplication class का एक एप्लिकेशन ऑब्जेक्ट बनाएं।
QWidget क्लास के आधार पर विंडो क्लास घोषित करें
QLabel ऑब्जेक्ट जोड़ें और लेबल के कैप्शन को "हैलो वर्ल्ड" के रूप में सेट करें।
SetGeometry () विधि द्वारा विंडो के आकार और स्थिति को परिभाषित करें।
द्वारा आवेदन का मुख्य भाग दर्ज करें app.exec_() तरीका।
निम्नलिखित वस्तु उन्मुख समाधान का पूरा कोड है -
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class window(QWidget):
def __init__(self, parent = None):
super(window, self).__init__(parent)
self.resize(200,50)
self.setWindowTitle("PyQt5")
self.label = QLabel(self)
self.label.setText("Hello World")
font = QFont()
font.setFamily("Arial")
font.setPointSize(16)
self.label.setFont(font)
self.label.move(50,20)
def main():
app = QApplication(sys.argv)
ex = window()
ex.show()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
PyQt APIकक्षाओं और विधियों का एक बड़ा संग्रह है। इन वर्गों को 20 से अधिक मॉड्यूल में परिभाषित किया गया है।
निम्नलिखित अक्सर उपयोग किए जाने वाले कुछ मॉड्यूल हैं -
अनु क्रमांक। | मॉड्यूल और विवरण |
---|---|
1 | QtCore कोर गैर-जीयूआई कक्षाएं अन्य मॉड्यूल द्वारा उपयोग की जाती हैं |
2 | QtGui ग्राफिकल यूजर इंटरफेस घटक |
3 | QtMultimedia निम्न-स्तरीय मल्टीमीडिया प्रोग्रामिंग के लिए कक्षाएं |
4 | QtNetwork नेटवर्क प्रोग्रामिंग के लिए कक्षाएं |
5 | QtOpenGL ओपनगेल सपोर्ट क्लासेस |
6 | QtScript क्यूटी लिपियों के मूल्यांकन के लिए कक्षाएं |
7 | QtSql SQL का उपयोग करके डेटाबेस एकीकरण के लिए कक्षाएं |
8 | QtSvg एसवीजी फ़ाइलों की सामग्री प्रदर्शित करने के लिए कक्षाएं |
9 | QtWebKit HTML के प्रतिपादन और संपादन के लिए कक्षाएं |
10 | QtXml एक्सएमएल से निपटने के लिए कक्षाएं |
1 1 | QtWidgets क्लासिक डेस्कटॉप शैली UI बनाने के लिए कक्षाएं। |
12 | QtDesigner क्यूटी डिजाइनर का विस्तार करने के लिए कक्षाएं |
13 | QtAssistant ऑनलाइन मदद के लिए समर्थन |
PyQt5 विकास उपकरण क्यूटी विकास के लिए उपयोगी उपयोगिताओं का एक संग्रह है। निम्नलिखित ऐसी उपयोगिताओं की एक चयनित सूची है -
अनु क्रमांक। | उपकरण का नाम और विवरण |
---|---|
1 | assistant Qt सहायक प्रलेखन उपकरण |
2 | pyqt5designer क्यूटी डिजाइनर जीयूआई लेआउट टूल |
3 | linguist Qt भाषाई अनुवाद उपकरण |
4 | lrelease ts फ़ाइलों को qm फ़ाइलों के लिए संकलित करें |
5 | pylupdate5 अनुवाद स्ट्रिंग्स निकालें और ts फ़ाइलों को जनरेट या अपडेट करें |
6 | qmake Qt सॉफ्टवेयर बिल्ड टूल |
7 | pyqt5qmlscene QML फ़ाइल दर्शक |
8 | pyqmlviewer QML फ़ाइल दर्शक |
9 | pyrcc5 Qt संसाधन फ़ाइल संकलक |
10 | pyuic5 क्यूटी यूजर इंटरफेस कंपाइलर ui फाइलों से कोड जनरेट करने के लिए |
1 1 | pyqmltestrunner QML कोड पर यूनिट परीक्षण चल रहा है |
12 | qdbus डी-बस सेवाओं को सूचीबद्ध करने के लिए कमांड-लाइन टूल |
13 | QDoc सॉफ्टवेयर परियोजनाओं के लिए प्रलेखन जनरेटर। |
14 | Qhelpgenerator Qt सहायता फ़ाइलों को बनाना और देखना। |
15 | qmlimportscanner QML आयात पर पर्स और रिपोर्ट |
PyQt API में 400 से अधिक कक्षाएं हैं। QObjectवर्ग पदानुक्रम के शीर्ष पर है। यह सभी Qt वस्तुओं का आधार वर्ग है। साथ ही,QPaintDevice वर्ग सभी वस्तुओं के लिए आधार वर्ग है जिसे चित्रित किया जा सकता है।
QApplicationक्लास मुख्य सेटिंग्स और GUI एप्लिकेशन के नियंत्रण प्रवाह का प्रबंधन करता है। इसमें मुख्य ईवेंट लूप होता है जिसके अंदर विंडो तत्वों और अन्य स्रोतों से उत्पन्न घटनाओं को संसाधित और प्रेषित किया जाता है। यह सिस्टम-वाइड और एप्लिकेशन-वाइड सेटिंग्स को भी हैंडल करता है।
QWidget वर्ग, QObject और QPaintDevice वर्गों से प्राप्त सभी उपयोगकर्ता इंटरफ़ेस ऑब्जेक्ट के लिए आधार वर्ग है। QDialog तथा QFrameकक्षाएं भी QWidget वर्ग से ली गई हैं। उनकी अपनी उप-वर्ग प्रणाली है।
यहाँ अक्सर उपयोग किए जाने वाले विगेट्स की एक सूची है
अनु क्रमांक। | विजेट और विवरण |
---|---|
1 | QLabel पाठ या छवि प्रदर्शित करने के लिए उपयोग किया जाता है |
2 | QLineEdit उपयोगकर्ता को पाठ की एक पंक्ति में प्रवेश करने की अनुमति देता है |
3 | QTextEdit उपयोगकर्ता को बहु-पंक्ति पाठ दर्ज करने की अनुमति देता है |
4 | QPushButton कार्रवाई करने के लिए एक कमांड बटन |
5 | QRadioButton कई विकल्पों में से एक को चुनने में सक्षम करता है |
6 | QCheckBox एक से अधिक विकल्पों की पसंद को सक्षम करता है |
7 | QSpinBox पूर्णांक मान को बढ़ाने / घटाने में सक्षम करता है |
8 | QScrollBar प्रदर्शन एपर्चर से परे एक विजेट की सामग्री का उपयोग करने में सक्षम बनाता है |
9 | QSlider बाध्य मान को रैखिक रूप से बदलने में सक्षम करता है। |
10 | QComboBox से चुनने के लिए मदों की एक ड्रॉपडाउन सूची प्रदान करता है |
1 1 | QMenuBar क्षैतिज बार QMenu वस्तुओं को पकड़े हुए |
12 | QStatusBar आमतौर पर QMainWindow के निचले भाग में, स्थिति की जानकारी प्रदान करता है। |
13 | QToolBar आमतौर पर QMainWindow या फ्लोटिंग के शीर्ष पर। एक्शन बटन शामिल हैं |
14 | QListView ListMode या IconMode में आइटमों की चयन सूची प्रदान करता है |
15 | QPixmap QLabel या QPushButton ऑब्जेक्ट पर प्रदर्शन के लिए ऑफ-स्क्रीन छवि प्रतिनिधित्व |
16 | QDialog मोडल या मॉडलस विंडो जो मूल विंडो पर जानकारी लौटा सकती है |
एक सामान्य GUI आधारित एप्लिकेशन का शीर्ष स्तर विंडो द्वारा बनाया गया है QMainWindowविजेट वस्तु। ऊपर सूचीबद्ध कुछ विजेट इस मुख्य विंडो में अपनी नियुक्त जगह लेते हैं, जबकि अन्य को विभिन्न लेआउट प्रबंधकों का उपयोग करके केंद्रीय विजेट क्षेत्र में रखा जाता है।
निम्नलिखित आरेख QMainWindow रूपरेखा को दर्शाता है -
PyQt इंस्टॉलर एक GUI बिल्डर टूल के साथ आता है Qt Designer। अपने सरल ड्रैग एंड ड्रॉप इंटरफेस का उपयोग करके, कोड लिखने के बिना एक GUI इंटरफ़ेस जल्दी से बनाया जा सकता है। हालाँकि, यह आईडीई नहीं है जैसे कि विजुअल स्टूडियो। इसलिए, Qt डिज़ाइनर के पास एप्लिकेशन को डीबग करने और बनाने की सुविधा नहीं है।
Qt डिज़ाइनर एप्लिकेशन शुरू करें जो विकास उपकरणों का एक हिस्सा है और वर्चुअल वातावरण की स्क्रिप्ट फ़ोल्डर में स्थापित है।
फ़ाइल → नया मेनू चुनकर GUI इंटरफ़ेस डिज़ाइन करना शुरू करें।
फिर आप बाएँ फलक पर विजेट बॉक्स से आवश्यक विजेट्स को खींच और छोड़ सकते हैं। आप प्रपत्र पर रखी गई विजेट के गुणों को भी मान प्रदान कर सकते हैं।
डिज़ाइन किए गए फॉर्म को डेमो के रूप में सहेजा जाता है। इस यूआई फ़ाइल में डिजाइन में विगेट्स के XML प्रतिनिधित्व और उनके गुण शामिल हैं। यह डिज़ाइन pyuic5 कमांड लाइन उपयोगिता का उपयोग करके पायथन के समकक्ष अनुवाद किया गया है। यह उपयोगिता Qt टूलकिट के यूरिक मॉड्यूल के लिए एक आवरण है। Pyuic5 का उपयोग इस प्रकार है -
pyuic5 -x demo.ui -o demo.py
उपरोक्त कमांड में, -x स्विच उत्पन्न पायथन लिपि में (एक्सएमएल से) अतिरिक्त कोड की एक छोटी राशि जोड़ता है ताकि यह एक स्व-निष्पादन योग्य स्टैंडअलोन एप्लिकेशन बन जाए।
if __name__ == "__main__":
import sys
app = QtGui.QApplication(sys.argv)
Dialog = QtGui.QDialog()
ui = Ui_Dialog()
ui.setupUi(Dialog)
Dialog.show()
sys.exit(app.exec_())
परिणामी अजगर स्क्रिप्ट को निम्नलिखित डायलॉग बॉक्स दिखाने के लिए निष्पादित किया जाता है -
python demo.py
उपयोगकर्ता इनपुट फ़ील्ड में डेटा इनपुट कर सकता है लेकिन ऐड बटन पर क्लिक करने से कोई क्रिया उत्पन्न नहीं होगी क्योंकि यह किसी फ़ंक्शन से संबद्ध नहीं है। उपयोगकर्ता द्वारा उत्पन्न प्रतिक्रिया को प्रतिक्रिया के रूप में कहा जाता हैevent handling।
कंसोल मोड एप्लिकेशन के विपरीत, जिसे क्रमिक तरीके से निष्पादित किया जाता है, एक GUI आधारित एप्लिकेशन इवेंट संचालित होता है। उपयोगकर्ता के कार्यों के जवाब में कार्य या विधियों को क्रियान्वित किया जाता है जैसे कि बटन पर क्लिक करना, किसी संग्रह से आइटम का चयन करना या माउस क्लिक आदि, जिसे कहा जाता हैevents।
GUI इंटरफ़ेस बनाने के लिए उपयोग किए जाने वाले विजेट ऐसे आयोजनों के स्रोत के रूप में कार्य करते हैं। प्रत्येक PyQt विजेट, जो QObject वर्ग से लिया गया है, का उत्सर्जन करने के लिए डिज़ाइन किया गया है‘signal’एक या अधिक घटनाओं के जवाब में। अपने आप पर संकेत कोई कार्रवाई नहीं करता है। इसके बजाय, यह एक से 'जुड़ा' है‘slot’। स्लॉट कोई भी हो सकता हैcallable Python function।
क्यूटी डिज़ाइनर के सिग्नल / स्लॉट संपादक का उपयोग करना
पहले एक लाइनएडिट कंट्रोल और एक पुशबटन के साथ एक सरल रूप तैयार करें।
यह वांछित है कि यदि बटन दबाया जाता है, तो पाठ बॉक्स की सामग्री को मिटा दिया जाना चाहिए। QLineEdit विजेट में इस उद्देश्य के लिए एक स्पष्ट () विधि है। इसलिए, बटनclicked सिग्नल से जुड़ा होना है clear() पाठ बॉक्स की विधि।
इसके साथ शुरू करने के लिए, संपादन मेनू / (या F4 दबाएं) से संकेत / स्लॉट संपादित करें चुनें। फिर माउस से बटन को हाइलाइट करें और कर्सर को टेक्स्टबॉक्स की ओर खींचें
जैसे ही माउस जारी किया जाता है, बटन के संकेत और स्लॉट के तरीकों को दर्शाने वाला एक संवाद प्रदर्शित किया जाएगा। क्लिक किया गया संकेत और स्पष्ट () विधि का चयन करें
नीचे दाईं ओर सिग्नल / स्लॉट संपादक विंडो परिणाम दिखाएगा -
नीचे दिए गए कोड में ui फ़ाइल से ui और बिल्ड और पायथन कोड सहेजें -
pyuic5 -x signalslot.ui -o signalslot.py
उत्पन्न पायथन कोड में निम्नलिखित कथन द्वारा संकेत और स्लॉट के बीच संबंध होगा -
self.pushButton.clicked.connect(self.lineEdit.clear)
Signallot.py चलाएं और LineEdit में कुछ टेक्स्ट डालें। यदि बटन दबाया जाता है, तो पाठ साफ़ हो जाएगा।
बिल्डिंग सिग्नल-स्लॉट कनेक्शन
डिज़ाइनर का उपयोग करने के बजाय, आप सिंटैक्स का अनुसरण करके सीधे सिग्नल-स्लॉट कनेक्शन स्थापित कर सकते हैं -
widget.signal.connect(slot_function)
मान लीजिए कि एक बटन क्लिक करने पर एक फ़ंक्शन को बुलाया जाना है। यहां, क्लिक किए गए सिग्नल को कॉल करने योग्य फ़ंक्शन से जोड़ा जाना है। इसे निम्नलिखित में से किसी तकनीक में प्राप्त किया जा सकता है -
button.clicked.connect(slot_function)
उदाहरण
निम्न उदाहरण में, QDialog विंडो में दो QPushButton ऑब्जेक्ट्स (b1 और b2) जोड़े गए हैं। हम क्रमशः b1 और b2 पर क्लिक करके फ़ंक्शन बी 1_क्लिप्ड () और बी 2_क्लिप्ड () कॉल करना चाहते हैं।
जब b1 क्लिक किया जाता है, तो क्लिक किया गया () सिग्नल b1_clicked () फ़ंक्शन से जुड़ा होता है -
b1.clicked.connect(b1_clicked())
जब b2 क्लिक किया जाता है, तो क्लिक किया हुआ () सिग्नल b2_clicked () फ़ंक्शन से जुड़ा होता है।
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def window():
app = QApplication(sys.argv)
win = QDialog()
b1 = QPushButton(win)
b1.setText("Button1")
b1.move(50,20)
b1.clicked.connect(b1_clicked)
b2 = QPushButton(win)
b2.setText("Button2")
b2.move(50,50)
b2.clicked.connect(b2_clicked)
win.setGeometry(100,100,200,100)
win.setWindowTitle("PyQt5")
win.show()
sys.exit(app.exec_())
def b1_clicked():
print ("Button 1 clicked")
def b2_clicked():
print ("Button 2 clicked")
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
उत्पादन
Button 1 clicked
Button 2 clicked
एक GUI विजेट को पिक्सेल विंडो में मापा जा सकता है, जो इसके पूर्ण निर्देशांक को पिक्सेल में मापा जाता है। निर्देशांक setGeometry () विधि द्वारा परिभाषित विंडो के आयामों के सापेक्ष हैं।
setGeometry () सिंटैक्स
QWidget.setGeometry(xpos, ypos, width, height)
निम्नलिखित कोड स्निपेट में, मॉनिटर द्वारा स्थिति (10, 10) में 300 बाय 200 पिक्सेल आयामों की शीर्ष स्तर विंडो प्रदर्शित की जाती है।
import sys
from PyQt4 import QtGui
def window():
app = QtGui.QApplication(sys.argv)
w = QtGui.QWidget()
b = QtGui.QPushButton(w)
b.setText("Hello World!")
b.move(50,20)
w.setGeometry(10,10,300,200)
w.setWindowTitle(“PyQt”)
w.show()
sys.exit(app.exec_())
if __name__ == '__main__':
window()
ए PushButton विजेट को विंडो में जोड़ा जाता है और उसे 50 पिक्सेल दाईं ओर रखा जाता है और खिड़की के ऊपरी बाएँ स्थान से 20 पिक्सेल नीचे।
हालांकि, यह पूर्ण स्थिति निम्नलिखित कारणों से उपयुक्त नहीं है -
विंडो के आकार बदलने पर भी विजेट की स्थिति नहीं बदलती है।
अलग-अलग रिज़ॉल्यूशन वाले विभिन्न डिस्प्ले डिवाइस पर उपस्थिति एक समान नहीं हो सकती है।
लेआउट में संशोधन कठिन है क्योंकि इसे पूरे फॉर्म को फिर से डिज़ाइन करने की आवश्यकता हो सकती है।
PyQt एपीआई कंटेनर के अंदर विजेट्स की स्थिति के अधिक सुरुचिपूर्ण प्रबंधन के लिए लेआउट कक्षाएं प्रदान करता है। पूर्ण स्थिति पर लेआउट प्रबंधकों के फायदे हैं -
विंडो के अंदर विजेट स्वचालित रूप से आकार परिवर्तन कर रहे हैं।
विभिन्न प्रस्तावों के साथ प्रदर्शन उपकरणों पर एक समान उपस्थिति सुनिश्चित करता है।
रीडायरेक्ट किए बिना विजेट को गतिशील रूप से जोड़ना या हटाना संभव है।
Qt टूलकिट विभिन्न लेआउट्स को परिभाषित करता है जिनका उपयोग Qt डिज़ाइनर उपयोगिता के साथ किया जा सकता है।
यहां उन वर्गों की सूची दी गई है, जिनके बारे में हम इस अध्याय में एक-एक करके चर्चा करेंगे।
अनु क्रमांक। | कक्षाएं और विवरण |
---|---|
1 | QBoxLayout QBoxLayout वर्ग विगेट्स को लंबवत या क्षैतिज रूप से बढ़ाता है। इसके व्युत्पन्न वर्ग QVBoxLayout हैं (विगेट्स को व्यवस्थित रूप से व्यवस्थित करने के लिए) और QHBoxLayout (विगेट्स को क्षैतिज रूप से व्यवस्थित करने के लिए)। |
2 | QGridLayout GridLayout वर्ग ऑब्जेक्ट पंक्तियों और स्तंभों में व्यवस्थित कोशिकाओं की एक ग्रिड के साथ प्रस्तुत करता है। वर्ग में ऐडविजेट () विधि है। सेल की पंक्तियों और स्तंभों की संख्या निर्दिष्ट करके किसी भी विजेट को जोड़ा जा सकता है। |
3 | QFormLayout QFormLayout दो कॉलम फॉर्म बनाने का एक सुविधाजनक तरीका है, जहां प्रत्येक पंक्ति में एक लेबल के साथ जुड़े इनपुट फ़ील्ड होते हैं। एक सम्मेलन के रूप में, बाएं कॉलम में लेबल होता है और दाएं कॉलम में एक इनपुट फ़ील्ड होती है। |
यहां उन विजेट्स की सूची दी गई है, जिनके बारे में हम इस अध्याय में एक-एक करके चर्चा करेंगे।
अनु क्रमांक | विजेट और विवरण |
---|---|
1 | QLabel QLabel ऑब्जेक्ट गैर-संपादन योग्य पाठ या छवि, या एनिमेटेड GIF की मूवी प्रदर्शित करने के लिए एक प्लेसहोल्डर के रूप में कार्य करता है। इसे अन्य विगेट्स के लिए एक मेनमोनिक कुंजी के रूप में भी इस्तेमाल किया जा सकता है। |
2 | QLineEdit QLineEdit ऑब्जेक्ट सबसे अधिक इस्तेमाल किया जाने वाला इनपुट फ़ील्ड है। यह एक बॉक्स प्रदान करता है जिसमें पाठ की एक पंक्ति दर्ज की जा सकती है। बहु-पंक्ति पाठ में प्रवेश करने के लिए, क्यूटेक्स्टडिट ऑब्जेक्ट की आवश्यकता होती है। |
3 | QPushButton PyQt API में, QPushButton क्लास ऑब्जेक्ट एक बटन प्रस्तुत करता है जिसे क्लिक करने पर एक निश्चित फ़ंक्शन को इनवॉइस करने के लिए प्रोग्राम किया जा सकता है। |
4 | QRadioButton एक QRadioButton क्लास ऑब्जेक्ट एक टेक्स्ट लेबल के साथ एक चयन योग्य बटन प्रस्तुत करता है। उपयोगकर्ता प्रपत्र पर प्रस्तुत कई विकल्पों में से एक का चयन कर सकता है। यह वर्ग QAbstractButton वर्ग से लिया गया है। |
5 | QCheckBox पाठ लेबल से पहले एक आयताकार बॉक्स प्रकट होता है जब QCheckBox ऑब्जेक्ट को मूल विंडो में जोड़ा जाता है। QRadioButton की तरह, यह भी एक चयन करने योग्य बटन है। |
6 | QComboBox QComboBox ऑब्जेक्ट से चुनने के लिए आइटम की एक ड्रॉपडाउन सूची प्रस्तुत करता है। यह केवल वर्तमान में चयनित आइटम को प्रदर्शित करने के लिए आवश्यक फॉर्म पर न्यूनतम स्क्रीन स्थान लेता है। |
7 | QSpinBox एक QSpinBox ऑब्जेक्ट उपयोगकर्ता को एक टेक्स्टबॉक्स के साथ प्रस्तुत करता है जो अपने दाईं ओर ऊपर / नीचे बटन के साथ पूर्णांक प्रदर्शित करता है। |
8 | QSlider विजेट और सिग्नल QSlider वर्ग ऑब्जेक्ट उपयोगकर्ता को एक खांचे के साथ प्रस्तुत करता है जिस पर एक हैंडल को स्थानांतरित किया जा सकता है। यह एक बंधे हुए मूल्य को नियंत्रित करने के लिए एक क्लासिक विजेट है। |
9 | QMenuBar, QMenu और QAction QMainWindow ऑब्जेक्ट के शीर्षक बार के ठीक नीचे एक क्षैतिज QMenuBar QMenu ऑब्जेक्ट प्रदर्शित करने के लिए आरक्षित है। |
10 | QToolBar एक क्यूटलबार विजेट एक चल पैनल है जिसमें टेक्स्ट बटन, आइकन या अन्य विजेट के साथ बटन होते हैं। |
1 1 | QInputDialog यह एक प्री-कॉन्फ़िगर डायलॉग है जिसमें टेक्स्ट फ़ील्ड और दो बटन हैं, ठीक है और रद्द करें। ओके बटन पर यूजर क्लिक करने या एंटर दबाने के बाद पैरेंट विंडो टेक्स्ट बॉक्स में इनपुट जमा करता है। |
12 | QFontDialog एक अन्य आमतौर पर इस्तेमाल किया जाने वाला संवाद, एक फ़ॉन्ट चयनकर्ता विजेट QDialog वर्ग की दृश्य उपस्थिति है। इस संवाद का परिणाम एक Qfont ऑब्जेक्ट है, जिसे मूल विंडो द्वारा उपभोग किया जा सकता है। |
13 | QFileDialog यह विजेट एक फ़ाइल चयनकर्ता संवाद है। यह उपयोगकर्ता को फ़ाइल सिस्टम के माध्यम से नेविगेट करने और खोलने या सहेजने के लिए फ़ाइल का चयन करने में सक्षम बनाता है। संवाद स्थिर कार्यों के माध्यम से या डायलॉग ऑब्जेक्ट पर exec_ () फ़ंक्शन को कॉल करके किया जाता है। |
14 | QTab यदि किसी प्रपत्र में बहुत सारे फ़ील्ड एक साथ प्रदर्शित किए जाते हैं, तो उन्हें अलग टैब के प्रत्येक टैब के नीचे रखे गए विभिन्न पृष्ठों में व्यवस्थित किया जा सकता है। QTabWidget एक टैब बार और एक पृष्ठ क्षेत्र प्रदान करता है। |
15 | QStacked QStackedWidget का कामकाज QTabWidget के समान है। यह विंडो के क्लाइंट क्षेत्र के कुशल उपयोग में भी मदद करता है। |
16 | QSplitter यह एक और उन्नत लेआउट प्रबंधक है जो बाल विगेट्स के आकार को गतिशील रूप से उनके बीच की सीमाओं को खींचकर बदलने की अनुमति देता है। स्प्लिटर नियंत्रण एक हैंडल प्रदान करता है जिसे नियंत्रणों का आकार बदलने के लिए खींचा जा सकता है। |
17 | QDock एक डॉक करने योग्य विंडो एक सबविंडो है जो फ्लोटिंग स्थिति में रह सकती है या एक निर्दिष्ट स्थान पर मुख्य विंडो से जुड़ी हो सकती है। QMainWindow क्लास की मुख्य विंडो ऑब्जेक्ट में डॉकेबल विंडो के लिए आरक्षित क्षेत्र है। |
18 | QStatusBar QMainWindow वस्तु स्थिति पट्टी के रूप में नीचे एक क्षैतिज पट्टी होती है। इसका उपयोग स्थायी या प्रासंगिक स्थिति जानकारी प्रदर्शित करने के लिए किया जाता है। |
19 | QList QListWidget वर्ग सूची से आइटम जोड़ने या निकालने के लिए एक आइटम-आधारित इंटरफ़ेस है। सूची में प्रत्येक आइटम एक QListWidgetItem ऑब्जेक्ट है। ListWidget को बहुस्तरीय होने के लिए सेट किया जा सकता है। |
20 | QScrollBar स्क्रॉलबार नियंत्रण उपयोगकर्ता को देखने योग्य क्षेत्र के बाहर दस्तावेज़ के कुछ हिस्सों तक पहुंचने में सक्षम बनाता है। यह वर्तमान स्थिति को दृश्य संकेतक प्रदान करता है। |
21 | QCalendar QCalendar विजेट एक उपयोगी दिनांक पिकर नियंत्रण है। यह एक महीने का दृश्य प्रदान करता है। उपयोगकर्ता माउस या कीबोर्ड के उपयोग से तारीख का चयन कर सकता है, डिफ़ॉल्ट आज की तारीख है। |
ए QDialogविजेट उपयोगकर्ता से प्रतिक्रिया एकत्र करने के लिए ज्यादातर उपयोग की जाने वाली एक शीर्ष स्तरीय विंडो प्रस्तुत करता है। इसे होने के लिए कॉन्फ़िगर किया जा सकता हैModal (जहां यह अपनी मूल विंडो को ब्लॉक करता है) या Modeless (संवाद विंडो को बायपास किया जा सकता है)।
PyQt API में कई प्री-कॉन्फ़िगर किए गए डायलॉग विजेट्स जैसे InputDialog, FileDialog, FontDogog इत्यादि हैं।
उदाहरण
निम्नलिखित उदाहरण में, WindowModalityडायलॉग विंडो की विशेषता यह तय करती है कि यह मोडल है या मॉडलस। संवाद का कोई भी एक बटन डिफ़ॉल्ट रूप से सेट किया जा सकता है। संवाद द्वारा खारिज कर दिया गया हैQDialog.reject() विधि जब उपयोगकर्ता एस्केप कुंजी दबाता है।
एक शीर्ष स्तर QWidget विंडो पर एक PushButton, जब क्लिक किया जाता है, एक संवाद विंडो का उत्पादन करता है। एक डायलॉग बॉक्स में इसकी शीर्षक पट्टी पर न्यूनतम और अधिकतम नियंत्रण नहीं होता है।
उपयोगकर्ता इस संवाद बॉक्स को पृष्ठभूमि में नहीं हटा सकता क्योंकि इसकी WindowModality सेट है ApplicationModal।
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def window():
app = QApplication(sys.argv)
w = QWidget()
btn = QPushButton(w)
btn.setText("Hello World!")
btn.move(100,50)
btn.clicked.connect(showdialog)
w.setWindowTitle("PyQt Dialog demo")
w.show()
sys.exit(app.exec_())
def showdialog():
dlg = QDialog()
b1 = QPushButton("ok",dlg)
b1.move(50,50)
dlg.setWindowTitle("Dialog") 9. PyQt5 — QDialog Class
dlg.setWindowModality(Qt.ApplicationModal)
dlg.exec_()
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है। मुख्य विंडो में बटन पर क्लिक करें और डायलॉग बॉक्स पॉप अप करें -
QMessageBoxकुछ सूचना संदेश प्रदर्शित करने के लिए आमतौर पर इस्तेमाल किया जाने वाला मोडल संवाद है और वैकल्पिक रूप से उपयोगकर्ता से किसी भी एक मानक बटन पर क्लिक करके प्रतिक्रिया देने के लिए कहें। प्रत्येक मानक बटन में एक पूर्वनिर्धारित कैप्शन होता है, एक भूमिका और एक पूर्वनिर्धारित हेक्साडेसिमल संख्या देता है।
QMessageBox वर्ग से जुड़े महत्वपूर्ण तरीके और गणना निम्न तालिका में दिए गए हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | setIcon() संदेश की गंभीरता के अनुरूप पूर्वनिर्धारित आइकन प्रदर्शित करता है
|
2 | setText() प्रदर्शित होने के लिए मुख्य संदेश का पाठ सेट करता है |
3 | setInformativeText() अतिरिक्त जानकारी प्रदर्शित करता है |
4 | setDetailText() डायल एक विवरण बटन दिखाता है। यह पाठ उस पर क्लिक करने पर प्रकट होता है |
5 | setTitle() संवाद का कस्टम शीर्षक प्रदर्शित करता है |
6 | setStandardButtons() प्रदर्शित होने के लिए मानक बटन की सूची। प्रत्येक बटन के साथ जुड़ा हुआ है QMessageBox.Ok 0x00000400 QMessageBox.Open 0x00002000 QMessageBox.Save 0x00000800 QMessageBox.Cancel 0x00400000 QMessageBox.Close 0x00200000 QMessageBox.Yes 0x00004000 QMessageBox.No 0x00010000 QMessageBox.Abort 0x00040000 QMessageBox.Retry 0x00080000 QMessageBox.Ignore 0x00100000 |
7 | setDefaultButton() बटन को डिफ़ॉल्ट के रूप में सेट करता है। यदि Enter दबाया जाता है तो यह क्लिक किए गए सिग्नल का उत्सर्जन करता है |
8 | setEscapeButton() बची हुई कुंजी को दबाने पर बटन को क्लिक के रूप में माना जाता है |
उदाहरण
निम्न उदाहरण में, शीर्ष स्तर विंडो पर बटन के संकेत पर क्लिक करें, कनेक्टेड फ़ंक्शन संदेश बॉक्स संवाद प्रदर्शित करता है।
msg = QMessageBox()
msg.setIcon(QMessageBox.Information)
msg.setText("This is a message box")
msg.setInformativeText("This is additional information")
msg.setWindowTitle("MessageBox demo")
msg.setDetailedText("The details are as follows:")
setStandardButton () फ़ंक्शन वांछित बटन प्रदर्शित करता है।
msg.setStandardButtons(QMessageBox.Ok | QMessageBox.Cancel)
बटन क्लच () सिग्नल एक स्लॉट फ़ंक्शन से जुड़ा होता है, जो सिग्नल के स्रोत के कैप्शन की पहचान करता है।
msg.buttonClicked.connect(msgbtn)
उदाहरण के लिए पूरा कोड इस प्रकार है -
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def window():
app = QApplication(sys.argv)
w = QWidget()
b = QPushButton(w)
b.setText("Show message!")
b.move(100,50)
b.clicked.connect(showdialog)
w.setWindowTitle("PyQt MessageBox demo")
w.show()
sys.exit(app.exec_())
def showdialog():
msg = QMessageBox()
msg.setIcon(QMessageBox.Information)
msg.setText("This is a message box")
msg.setInformativeText("This is additional information")
msg.setWindowTitle("MessageBox demo")
msg.setDetailedText("The details are as follows:")
msg.setStandardButtons(QMessageBox.Ok | QMessageBox.Cancel)
msg.buttonClicked.connect(msgbtn)
retval = msg.exec_()
def msgbtn(i):
print ("Button pressed is:",i.text())
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है। जब मुख्य विंडो का बटन क्लिक किया जाता है तो संदेश बॉक्स पॉप-अप हो जाता है -
यदि आप MessageBox पर Ok या Cancel बटन पर क्लिक करते हैं, तो कंसोल पर निम्न आउटपुट का उत्पादन होता है -
Button pressed is: OK
Button pressed is: Cancel
एक सामान्य GUI एप्लिकेशन में कई विंडो हो सकती हैं। टैब्ड और स्टैक्ड विजेट एक बार में एक ऐसी विंडो को सक्रिय करने की अनुमति देते हैं। हालाँकि, कई बार यह दृष्टिकोण उपयोगी नहीं हो सकता है क्योंकि अन्य विंडो छिपी हुई है।
एक साथ कई विंडो प्रदर्शित करने का एक तरीका उन्हें स्वतंत्र विंडो के रूप में बनाना है। इसे एसडीआई कहा जाता है(single Document Interface)। इसके लिए अधिक मेमोरी संसाधनों की आवश्यकता होती है क्योंकि प्रत्येक विंडो का अपना मेनू सिस्टम, टूलबार आदि हो सकता है।
एमडीआई (Multiple Document Interface)अनुप्रयोग कम मेमोरी संसाधनों का उपभोग करते हैं। उप खिड़कियां मुख्य कंटेनर के अंदर एक दूसरे के संबंध में रखी गई हैं। कंटेनर विजेट कहा जाता हैQMdiArea।
QMdiArea विजेट आम तौर पर QMainWondow ऑब्जेक्ट के केंद्रीय विजेट पर है। इस क्षेत्र में बाल खिड़कियां उदाहरण हैंQMdiSubWindowकक्षा। सबविंडो ऑब्जेक्ट के आंतरिक विजेट के रूप में किसी भी QWidget को सेट करना संभव है। एमडीआई क्षेत्र में उप-खिड़कियां कैस्केड या टाइल फैशन में व्यवस्थित की जा सकती हैं।
निम्न तालिका QMdiArea वर्ग और QMdiSubWindow वर्ग के महत्वपूर्ण तरीकों को सूचीबद्ध करती है -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | addSubWindow() MDI क्षेत्र में एक नए सबविंडो के रूप में एक विजेट जोड़ता है |
2 | removeSubWindow() एक विजेट को हटाता है जो एक सबविंडो का आंतरिक विजेट है |
3 | setActiveSubWindow() एक सबविंडो सक्रिय करता है |
4 | cascadeSubWindows() एक cascaded फैशन में MDiArea में उप-विंडो की व्यवस्था करता है |
5 | tileSubWindows() MDIArea में टाइल वाले अंदाज़ में सब-विंडो की व्यवस्था करता है |
6 | closeActiveSubWindow() सक्रिय सबविंडो को बंद कर देता है |
7 | subWindowList() एमडीआई क्षेत्र में उप-विंडो की सूची लौटाता है |
8 | setWidget() QMdiSubwindow उदाहरण के आंतरिक विजेट के रूप में एक QWidget सेट करता है |
QMdiArea ऑब्जेक्ट subWindowActivated () सिग्नल का उत्सर्जन करता है जबकि WindowMateChanged () सिग्नल QMdisubWindow ऑब्जेक्ट द्वारा उत्सर्जित होता है।
उदाहरण
निम्नलिखित उदाहरण में, QMainWindow के शीर्ष स्तर की विंडो में एक मेनू और MdiArea है।
self.mdi = QMdiArea()
self.setCentralWidget(self.mdi)
bar = self.menuBar()
file = bar.addMenu("File")
file.addAction("New")
file.addAction("cascade")
file.addAction("Tiled")
मेनू का ट्रिगर () संकेत विंडोनेशन () फ़ंक्शन से जुड़ा है।
file.triggered[QAction].connect(self.windowaction)
मेनू की नई क्रिया एमडीआई क्षेत्र में एक उप-घटाव को जोड़ती है जिसमें एक शीर्षक होता है जिसमें एक वृद्धिशील संख्या होती है।
MainWindow.count = MainWindow.count+1
sub = QMdiSubWindow()
sub.setWidget(QTextEdit())
sub.setWindowTitle("subwindow"+str(MainWindow.count))
self.mdi.addSubWindow(sub)
sub.show()
मेनू के कैस्केड और टाइल वाले बटन वर्तमान में क्रमशः कैस्केड और टाइल वाले फैशन में उप-विंडो प्रदर्शित करते हैं।
पूरा कोड इस प्रकार है -
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class MainWindow(QMainWindow):
count = 0
def __init__(self, parent = None):
super(MainWindow, self).__init__(parent)
self.mdi = QMdiArea()
self.setCentralWidget(self.mdi)
bar = self.menuBar()
file = bar.addMenu("File")
file.addAction("New")
file.addAction("cascade")
file.addAction("Tiled")
file.triggered[QAction].connect(self.windowaction)
self.setWindowTitle("MDI demo")
def windowaction(self, q):
print ("triggered")
if q.text() == "New":
MainWindow.count = MainWindow.count+1
sub = QMdiSubWindow()
sub.setWidget(QTextEdit())
sub.setWindowTitle("subwindow"+str(MainWindow.count))
self.mdi.addSubWindow(sub)
sub.show()
if q.text() == "cascade":
self.mdi.cascadeSubWindows()
if q.text() == "Tiled":
self.mdi.tileSubWindows()
def main():
app = QApplication(sys.argv)
ex = MainWindow()
ex.show()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
कोड और तीन खिड़कियों के ऊपर कैस्केड और टाइल वाले गठन में चलाएं -
का प्रावधान drag and dropउपयोगकर्ता के लिए बहुत सहज है। यह कई डेस्कटॉप अनुप्रयोगों में पाया जाता है जहां उपयोगकर्ता एक विंडो से दूसरी विंडो में ऑब्जेक्ट को कॉपी या स्थानांतरित कर सकता है।
MIME आधारित ड्रैग एंड ड्रॉप डेटा ट्रांसफर पर आधारित है QDrag कक्षा। QMimeDataऑब्जेक्ट डेटा को उनके संबंधित MIME प्रकार के साथ जोड़ते हैं। इसे क्लिपबोर्ड पर संग्रहीत किया जाता है और फिर ड्रैग एंड ड्रॉप प्रक्रिया में उपयोग किया जाता है।
निम्न QMimeData वर्ग फ़ंक्शन MIME प्रकार का पता लगाने और आसानी से उपयोग करने की अनुमति देते हैं।
टेस्टर | प्राप्त करनेवाला | बैठानेवाला | MIME प्रकार |
---|---|---|---|
hasText () | पाठ () | setText () | पाठ / सादे |
hasHtml () | एचटीएमएल () | setHtml () | पाठ / html |
hasUrls () | यूआरएल () | setUrls () | पाठ / uri-सूची |
hasImage () | imageData () | setImageData () | छवि / * |
hasColor () | colorData () | setColorData () | आवेदन / x-रंग |
कई QWidget ऑब्जेक्ट ड्रैग और ड्रॉप गतिविधि का समर्थन करते हैं। जो अपने डेटा को खींचने की अनुमति देते हैं, उनमें सेटट्राएंगेबल () होता है जिसे सही पर सेट किया जाना चाहिए। दूसरी ओर, विगेट्स को ड्रैग और ड्रॉप ईवेंट का जवाब देना चाहिए ताकि उनमें खींचे गए डेटा को स्टोर किया जा सके।
DragEnterEvent एक ईवेंट प्रदान करता है, जो लक्ष्य विजेट को भेजा जाता है क्योंकि खींचने वाली क्रिया इसमें प्रवेश करती है।
DragMoveEvent का उपयोग तब किया जाता है जब ड्रैग एंड ड्रॉप की कार्रवाई जारी रहती है।
DragLeaveEvent विजेट को छोड़ने और छोड़ने की क्रिया के रूप में उत्पन्न होता है।
DropEventदूसरी ओर, तब होता है जब ड्रॉप पूरा हो जाता है। घटना की प्रस्तावित कार्रवाई को सशर्त स्वीकार या अस्वीकार किया जा सकता है।
उदाहरण
निम्नलिखित कोड में, DragEnterEventयह सत्यापित करता है कि इवेंट के MIME डेटा में टेक्स्ट है या नहीं। यदि हाँ, तो ईवेंट की प्रस्तावित कार्रवाई स्वीकार कर ली जाती है और कॉम्बो बॉक्स में टेक्स्ट को एक नए आइटम के रूप में जोड़ दिया जाता है।
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class combo(QComboBox):
def __init__(self, title, parent):
super(combo, self).__init__( parent)
self.setAcceptDrops(True)
def dragEnterEvent(self, e):
print (e)
if e.mimeData().hasText():
e.accept()
else:
e.ignore()
def dropEvent(self, e):
self.addItem(e.mimeData().text())
class Example(QWidget):
def __init__(self):
super(Example, self).__init__()
self.initUI()
def initUI(self):
lo = QFormLayout()
lo.addRow(QLabel("Type some text in textbox and drag it into combo box"))
edit = QLineEdit()
edit.setDragEnabled(True)
com = combo("Button", self)
lo.addRow(edit,com)
self.setLayout(lo)
self.setWindowTitle('Simple drag and drop')
def main():
app = QApplication(sys.argv)
ex = Example()
ex.show()
app.exec_()
if __name__ == '__main__':
main()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
PyQt5 लाइब्रेरी में है QtSqlमापांक। यह कई एसक्यूएल आधारित डेटाबेस के साथ संवाद करने के लिए एक विस्तृत वर्ग प्रणाली है। आईटी इसQSqlDatabaseएक कनेक्शन वस्तु के माध्यम से पहुँच प्रदान करता है। निम्नलिखित वर्तमान में उपलब्ध SQL ड्राइवरों की सूची है -
अनु क्रमांक। | ड्राइवर का प्रकार और विवरण |
---|---|
1 | QDB2 आईबीएम DB2 |
2 | QIBASE बोरलैंड इंटरबेस ड्राइवर |
3 | QMYSQL MySQL ड्राइवर |
4 | QOCI ओरेकल कॉल इंटरफ़ेस ड्राइवर |
5 | QODBC ODBC ड्राइवर (Microsoft SQL सर्वर शामिल है) |
6 | QPSQL PostgreSQL ड्राइवर |
7 | QSQLITE SQLite संस्करण 3 या उससे ऊपर |
8 | QSQLITE2 SQLite संस्करण 2 |
उदाहरण
इस अध्याय के लिए, SQLite डेटाबेस के साथ एक कनेक्शन स्थैतिक विधि का उपयोग करके स्थापित किया गया है -
db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sports.db')
QSqlDatabase class के अन्य तरीके इस प्रकार हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | setDatabaseName() उस डेटाबेस का नाम सेट करता है जिसके साथ कनेक्शन मांगा गया है |
2 | setHostName() उस होस्ट का नाम सेट करता है जिस पर डेटाबेस स्थापित है |
3 | setUserName() कनेक्शन के लिए उपयोगकर्ता नाम निर्दिष्ट करता है |
4 | setPassword() यदि कोई हो तो कनेक्शन ऑब्जेक्ट का पासवर्ड सेट करता है |
5 | commit() लेनदेन को पूरा करता है और सफल होने पर सही रिटर्न देता है |
6 | rollback() डेटाबेस लेनदेन को वापस रोल करता है |
7 | close() कनेक्शन बंद कर देता है |
QSqlQueryक्लास में SQL कमांड को निष्पादित और हेरफेर करने की कार्यक्षमता है। डीडीएल और डीएमएल दोनों प्रकार के एसक्यूएल प्रश्नों को निष्पादित किया जा सकता है। पहला कदम निम्नलिखित बयानों का उपयोग करके SQlite डेटाबेस बनाना है -
db = QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sportsdatabase.db')
इसके बाद, क्वेरी ऑब्जेक्ट को प्राप्त करें QSqlQuery() पद्धति और इसके सबसे महत्वपूर्ण तरीके को exec_ () कहते हैं, जो कि एक तर्क के रूप में लिया जाता है जिसमें SQL कथन को निष्पादित किया जाता है।
query = QtSql.QSqlQuery()
query.exec_("create table sportsmen(id int primary key, " "firstname varchar(20), lastname varchar(20))")
निम्न स्क्रिप्ट पाँच रिकॉर्ड के साथ आबादी वाले स्पोर्ट्सपर्सन की तालिका के साथ SQLite डेटाबेस sports.db बनाता है।
import sys
from PyQt5.QtSql import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def createDB():
db = QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sportsdatabase.db')
if not db.open():
msg = QMessageBox()
msg.setIcon(QMessageBox.Critical)
msg.setText("Error in Database Creation")
retval = msg.exec_()
return False
query = QSqlQuery()
query.exec_("create table sportsmen(
id int primary key, ""firstname varchar(20), lastname varchar(20))")
query.exec_("insert into sportsmen values(101, 'Roger', 'Federer')")
query.exec_("insert into sportsmen values(102, 'Christiano', 'Ronaldo')")
query.exec_("insert into sportsmen values(103, 'Ussain', 'Bolt')")
query.exec_("insert into sportsmen values(104, 'Sachin', 'Tendulkar')")
query.exec_("insert into sportsmen values(105, 'Saina', 'Nehwal')")
return True
if __name__ == '__main__':
app = QApplication(sys.argv)
createDB()
यह पुष्टि करने के लिए कि इसमें स्पोर्ट्समैन तालिका में जोड़े गए उपरोक्त रिकॉर्ड के साथ SQLite डेटाबेस बनाया गया है, नामक SQLite Gui उपयोगिता का उपयोग करें SQLiteStudio।
QSqlTableModelPyQt में कक्षा एक उच्च-स्तरीय इंटरफ़ेस है जो एकल तालिका में रिकॉर्ड पढ़ने और लिखने के लिए संपादन योग्य डेटा मॉडल प्रदान करता है। इस मॉडल का उपयोग पॉप्युलेट करने के लिए किया जाता हैQTableViewवस्तु। यह उपयोगकर्ता को एक स्क्रॉल करने योग्य और संपादन योग्य दृश्य प्रस्तुत करता है जिसे किसी भी शीर्ष स्तर की खिड़की पर रखा जा सकता है।
एक QSqlTableModel ऑब्जेक्ट को निम्न तरीके से घोषित किया जाता है -
model = QtSql.QSqlTableModel()
इसकी संपादन रणनीति निम्नलिखित में से किसी में भी सेट की जा सकती है -
QSqlTableModel.OnFieldChange | सभी परिवर्तनों को तुरंत लागू किया जाएगा |
---|---|
QSqlTableModel.OnRowChange | जब उपयोगकर्ता एक अलग पंक्ति का चयन करता है तो परिवर्तन लागू किए जाएंगे |
QSqlTableModel.OnManualSubmit | सभी परिवर्तनों को तब तक कैश किया जाएगा जब तक कि सब सबमिट नहीं करेंगे () या रिवर्ट () को कहा जाता है |
उदाहरण
निम्नलिखित उदाहरण में, स्पोर्ट्सपर्सन टेबल का उपयोग एक मॉडल के रूप में किया जाता है और रणनीति निम्नानुसार सेट की जाती है -
model.setTable('sportsmen')
model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
model.select()
क्यूटेबल व्यू वर्ग PyQt में मॉडल / व्यू फ्रेमवर्क का हिस्सा है। QTableView ऑब्जेक्ट निम्नानुसार बनाया गया है -
view = QtGui.QTableView()
view.setModel(model)
view.setWindowTitle(title)
return view
यह qableableView ऑब्जेक्ट और दो QPushButton विजेट्स शीर्ष स्तर QDialog विंडो में जोड़े जाते हैं। ऐड बटन पर क्लिक () सिग्नल एड्रो से जुड़ा हुआ है () जो मॉडल टेबल पर इन्सर्ट रो () करता है।
button.clicked.connect(addrow)
def addrow():
print model.rowCount()
ret = model.insertRows(model.rowCount(), 1)
print ret
डिलीट बटन से जुड़ा स्लॉट एक लैंबडा फ़ंक्शन को निष्पादित करता है जो एक पंक्ति को हटाता है, जिसे उपयोगकर्ता द्वारा चुना जाता है।
btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))
पूरा कोड इस प्रकार है -
import sys
from PyQt5.QtSql import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def initializeModel(model):
model.setTable('sportsmen')
model.setEditStrategy(QSqlTableModel.OnFieldChange)
model.select()
model.setHeaderData(0, Qt.Horizontal, "ID")
model.setHeaderData(1, Qt.Horizontal, "First name")
model.setHeaderData(2, Qt.Horizontal, "Last name")
def createView(title, model):
view = QTableView()
view.setModel(model)
view.setWindowTitle(title)
return view
def addrow():
print (model.rowCount())
ret = model.insertRows(model.rowCount(), 1)
print (ret)
def findrow(i):
delrow = i.row()
if __name__ == '__main__':
app = QApplication(sys.argv)
db = QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sportsdatabase.db')
model = QSqlTableModel()
delrow = -1
initializeModel(model)
view1 = createView("Table Model (View 1)", model)
view1.clicked.connect(findrow)
dlg = QDialog()
layout = QVBoxLayout()
layout.addWidget(view1)
button = QPushButton("Add a row")
button.clicked.connect(addrow)
layout.addWidget(button)
btn1 = QPushButton("del a row")
btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))
layout.addWidget(btn1)
dlg.setLayout(layout)
dlg.setWindowTitle("Database Demo")
dlg.show()
sys.exit(app.exec_())
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
कुछ रिकॉर्ड जोड़ने और हटाने का प्रयास करें और लेनदेन की पुष्टि करने के लिए SQLiteStudio पर वापस जाएं।
सब QWidgetPyQt में कक्षाएं QPaintDevice वर्ग से उप-वर्गित हैं। एQPaintDeviceएक दो आयामी स्थान है जो एक QPainter का उपयोग करने पर खींचा जा सकता है। पेंट डिवाइस के आयामों को शीर्ष-बाएं कोने से शुरू होने वाले पिक्सेल में मापा जाता है।
QPainterकक्षा विजेट और प्रिंटर जैसे अन्य पेंट करने योग्य उपकरणों पर निम्न स्तर की पेंटिंग करती है। आम तौर पर, विजेट के पेंट इवेंट में इसका उपयोग किया जाता है। QPaintEvent जब भी विजेट का स्वरूप अद्यतन किया जाता है।
चित्रकार को कॉल करके सक्रिय किया जाता है begin() विधि, जबकि end()विधि इसे निष्क्रिय कर देती है। बीच में, वांछित पैटर्न उपयुक्त विधियों द्वारा चित्रित किया गया है जैसा कि निम्न तालिका में सूचीबद्ध है।
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | begin() लक्ष्य डिवाइस पर पेंटिंग शुरू करता है |
2 | drawArc() शुरू और अंत कोण के बीच एक चाप खींचता है |
3 | drawEllipse() एक आयत के अंदर एक दीर्घवृत्त खींचता है |
4 | drawLine() निर्दिष्ट बिंदु निर्देशांक के साथ एक रेखा खींचता है |
5 | drawPixmap() पिक्समैप को छवि फ़ाइल से निकालता है और इसे निर्दिष्ट स्थान पर प्रदर्शित करता है |
6 | drwaPolygon() निर्देशांक की एक सरणी का उपयोग कर एक बहुभुज खींचता है |
7 | drawRect() दी गई चौड़ाई और ऊंचाई के साथ ऊपरी-बाएँ समन्वय पर शुरू होने वाली एक आयत खींचता है |
8 | drawText() दिए गए निर्देशांक पर पाठ प्रदर्शित करता है |
9 | fillRect() क्यूक्लर पैरामीटर के साथ आयत को भरता है |
10 | setBrush() पेंटिंग के लिए एक ब्रश शैली सेट करता है |
1 1 | setPen() ड्राइंग के लिए उपयोग किए जाने वाले पेन का रंग, आकार और शैली सेट करता है |
उदाहरण
निम्नलिखित कोड में, PyQt की ड्राइंग विधियों के विभिन्न तरीकों का उपयोग किया जाता है।
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class Example(QWidget):
def __init__(self):
super(Example, self).__init__()
self.initUI()
def initUI(self):
self.text = "hello world"
self.setGeometry(100,100, 400,300)
self.setWindowTitle('Draw Demo')
self.show()
def paintEvent(self, event):
qp = QPainter()
qp.begin(self)
qp.setPen(QColor(Qt.red))
qp.setFont(QFont('Arial', 20))
qp.drawText(10,50, "hello Python")
qp.setPen(QColor(Qt.blue))
qp.drawLine(10,100,100,100)
qp.drawRect(10,150,150,100)
qp.setPen(QColor(Qt.yellow))
qp.drawEllipse(100,50,100,50)
qp.drawPixmap(220,10,QPixmap("pythonlogo.png"))
qp.fillRect(20,175,130,70,QBrush(Qt.SolidPattern))
qp.end()
def main():
app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
इस अध्याय में, हम ब्रश स्टाइल कॉन्स्टेंट सीखेंगे।
ब्रश स्टाइल कांस्टेंट
नीचे दिए गए ब्रश स्टाइल कॉन्स्टेंट हैं -
Qt.NoBrush | कोई ब्रश पैटर्न नहीं |
Qt.SolidPattern | वर्दी का रंग |
Qt.Dense1Pattern | बेहद घने ब्रश पैटर्न |
Qt.HorPattern | क्षैतिज रेखाएँ |
Qt.VerPattern | ऊर्ध्वाधर पंक्तियां |
Qt.CrossPattern | क्षैतिज और ऊर्ध्वाधर लाइनों को पार करना |
Qt.BDiagPattern | पिछड़ी हुई विकर्ण रेखाएँ |
Qt.FDiagPattern | आगे तिरछी रेखाएँ |
Qt.DiagCrossPattern | विकर्ण रेखाओं को पार करना |
पूर्वनिर्धारित QColor शैलियाँ
नीचे दिए गए पूर्वनिर्धारित QColor शैलियाँ हैं -
Qt.NoBrush | कोई ब्रश पैटर्न नहीं |
Qt.SolidPattern | वर्दी का रंग |
Qt.Dense1Pattern | बेहद घने ब्रश पैटर्न |
Qt.HorPattern | क्षैतिज रेखाएँ |
Qt.VerPattern | ऊर्ध्वाधर पंक्तियां |
Qt.CrossPattern | क्षैतिज और ऊर्ध्वाधर लाइनों को पार करना |
Qt.BDiagPattern | पिछड़ी हुई विकर्ण रेखाएँ |
Qt.FDiagPattern | आगे तिरछी रेखाएँ |
Qt.DiagCrossPattern | विकर्ण रेखाओं को पार करना |
पूर्वनिर्धारित QColor वस्तुओं
नीचे दिए गए पूर्वनिर्धारित QColor वस्तुएँ हैं -
Qt.white |
Qt.black |
Qt.red |
Qt.darkRed |
Qt.green |
Qt.darkGreen |
Qt.blue |
Qt.cyan |
Qt.magenta |
Qt.yellow |
Qt.darkYellow |
Qt.gray |
QClipboardक्लास सिस्टम-वाइड क्लिपबोर्ड तक पहुंच प्रदान करता है जो अनुप्रयोगों के बीच डेटा को कॉपी और पेस्ट करने के लिए एक सरल तंत्र प्रदान करता है। इसकी क्रिया भी इसके समान हैQDrag वर्ग और समान डेटा प्रकार का उपयोग करता है।
QApplication class में एक static method है clipboard()जो क्लिपबोर्ड ऑब्जेक्ट का संदर्भ देता है। किसी भी प्रकार के MimeData को क्लिपबोर्ड से कॉपी या पेस्ट किया जा सकता है।
निम्नलिखित क्लिपबोर्ड वर्ग विधियां हैं जो आमतौर पर उपयोग की जाती हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | clear() क्लिपबोर्ड सामग्री साफ़ करता है |
2 | setImage() क्लिपबोर्ड में QImage की प्रतियां |
3 | setMimeData() MIME डेटा को क्लिपबोर्ड में सेट करता है |
4 | setPixmap() क्लिपबोर्ड में कॉपी पिक्समैप ऑब्जेक्ट |
5 | setText() क्लिपबोर्ड में प्रतियां QString |
6 | text() क्लिपबोर्ड से पाठ को पुनः प्राप्त करता है |
क्लिपबोर्ड ऑब्जेक्ट से जुड़ा सिग्नल है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | dataChanged() जब भी क्लिपबोर्ड डेटा बदलता है |
उदाहरण
निम्न उदाहरण में, दो TextEdit ऑब्जेक्ट और दो Pushbuttons एक शीर्ष स्तर विंडो में जोड़े जाते हैं।
क्लिपबोर्ड ऑब्जेक्ट के साथ शुरू करने के लिए त्वरित है। Textedit ऑब्जेक्ट की कॉपी () विधि डेटा को सिस्टम क्लिपबोर्ड पर कॉपी करती है। जब पेस्ट बटन पर क्लिक किया जाता है, तो यह क्लिपबोर्ड डेटा प्राप्त करता है और इसे अन्य टेक्स्टडिट ऑब्जेक्ट में पेस्ट करता है।
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class Example(QWidget):
def __init__(self):
super(Example, self).__init__()
self.initUI()
def initUI(self):
hbox = QVBoxLayout()
self.edit1=QTextEdit()
hbox.addWidget(self.edit1)
self.btn1=QPushButton("Copy")
hbox.addWidget(self.btn1)
self.edit2=QTextEdit()
self.btn2=QPushButton("Paste")
hbox.addWidget(self.edit2)
hbox.addWidget(self.btn2)
self.btn1.clicked.connect(self.copytext)
self.btn2.clicked.connect(self.pastetext)
self.setLayout(hbox)
self.setGeometry(300, 300, 300, 200)
self.setWindowTitle('Clipboard')
self.show()
def copytext(self):
#clipboard.setText(self.edit1.copy())
self.edit1.copy()
print (clipboard.text())
msg=QMessageBox()
msg.setText(clipboard.text()+" copied on clipboard")
msg.exec_()
def pastetext(self):
self.edit2.setText(clipboard.text())
app = QApplication(sys.argv)
clipboard=app.clipboard()
ex = Example()
ex.setWindowTitle("clipboard Example")
sys.exit(app.exec_())
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
QPixmapवर्ग एक छवि का ऑफ-स्क्रीन प्रतिनिधित्व प्रदान करता है। इसका उपयोग QPaintDevice ऑब्जेक्ट के रूप में किया जा सकता है या किसी अन्य विजेट में लोड किया जा सकता है, आमतौर पर एक लेबल या बटन।
Qt API में एक और समान वर्ग है QImage, जो I / O और अन्य पिक्सेल जोड़तोड़ के लिए अनुकूलित है। दूसरी ओर, Pixmap स्क्रीन पर इसे दिखाने के लिए अनुकूलित है। दोनों प्रारूप आपस में जुड़े हुए हैं।
इमेज फाइल के प्रकार जिन्हें QPixmap ऑब्जेक्ट में पढ़ा जा सकता है वे इस प्रकार हैं -
बीएमपी | विंडोज बिटमैप |
GIF | ग्राफिक इंटरचेंज प्रारूप (वैकल्पिक) |
जेपीजी | फ़ोटोग्राफ़ी संबंधी विशेषज्ञों का संयुक्त समूह |
जेपीईजी | फ़ोटोग्राफ़ी संबंधी विशेषज्ञों का संयुक्त समूह |
पीएनजी | पोर्टेबल नेटवर्क ग्राफ़िक्स |
पीबीएम | पोर्टेबल बिटमैप |
PGM | पोर्टेबल ग्रेमैप |
पीपीएम | पोर्टेबल पिक्समैप |
XBM | X11 बिटमैप |
XPM | X11 पिक्समैप |
QPixmap ऑब्जेक्ट को संभालने में निम्नलिखित तरीके उपयोगी हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | copy() पिक्समैप डेटा को एक क्यूरेक्ट ऑब्जेक्ट से कॉपी करता है |
2 | fromImage() QPmmap में QImage ऑब्जेक्ट को कनवर्ट करता है |
3 | grabWidget() दिए गए विजेट से एक पिक्समैप बनाता है |
4 | grabWindow() एक विंडो में डेटा का Pixmap बनाएं |
5 | Load() पिक्समैप के रूप में एक छवि फ़ाइल लोड करता है |
6 | save() QPixmap ऑब्जेक्ट को फ़ाइल के रूप में सहेजता है |
7 | toImage एक QPixmap को QImage में रूपांतरित करता है |
QPixmap का सबसे आम उपयोग लेबल / बटन पर चित्र प्रदर्शित करना है।
उदाहरण
निम्न उदाहरण QLabel पर प्रदर्शित चित्र को दिखाता है setPixmap() तरीका।
पूरा कोड इस प्रकार है -
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def window():
app = QApplication(sys.argv)
win = QWidget()
l1 = QLabel()
l1.setPixmap(QPixmap("python.png"))
vbox = QVBoxLayout()
vbox.addWidget(l1)
win.setLayout(vbox)
win.setWindowTitle("QPixmap Demo")
win.show()
sys.exit(app.exec_())
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -