PyQt - त्वरित गाइड
PyQt एक GUI विजेट टूलकिट है। यह एक पायथन इंटरफ़ेस हैQtसबसे शक्तिशाली और लोकप्रिय क्रॉस-प्लेटफ़ॉर्म GUI लाइब्रेरी में से एक है। PyQt नदी किनारे कम्प्यूटिंग लिमिटेड द्वारा विकसित किया गया था PyQt के नवीनतम संस्करण को अपनी आधिकारिक वेबसाइट से डाउनलोड किया जा सकता है - riverbankcomputing.com
PyQt एपीआई बड़ी संख्या में वर्गों और कार्यों वाले मॉड्यूल का एक सेट है। जबकिQtCore मॉड्यूल में फ़ाइल और निर्देशिका आदि के साथ काम करने के लिए गैर-जीयूआई कार्यक्षमता शामिल है, QtGuiमॉड्यूल में सभी ग्राफिकल नियंत्रण शामिल हैं। इसके अलावा, एक्सएमएल के साथ काम करने के लिए मॉड्यूल हैं(QtXml), एसवीजी (QtSvg)और एसक्यूएल (QtSql), आदि।
सहायक वातावरण
PyQt विंडोज, लिनक्स और मैक ओएस सहित सभी लोकप्रिय ऑपरेटिंग सिस्टम के साथ संगत है। यह दोहरे लाइसेंस वाला है, जो जीपीएल के साथ-साथ वाणिज्यिक लाइसेंस के तहत उपलब्ध है।
खिड़कियाँ
आप पायथन संस्करण (2.7 या 3.4) और हार्डवेयर आर्किटेक्चर (32 बिट या 64 बिट) के अनुरूप उपरोक्त डाउनलोड लिंक से एक उपयुक्त इंस्टॉलर डाउनलोड और स्थापित कर सकते हैं। ध्यान दें कि PyQt के दो संस्करण हैं जो क्रमशः उपलब्ध हैं,PyQt 4.8 तथा PyQt 5.5।
जबकि PyQt4 Python 2 के साथ-साथ Python 3 के लिए भी उपलब्ध है, PyQt5 का उपयोग Python 3. * के साथ ही किया जा सकता है।
PyQt4 Windows Binaries
PyQt4-4.11.4-जीपीएल-Py3.4-Qt4.8.7-x64.exe | विंडोज 64 बिट इंस्टॉलर |
PyQt4-4.11.4-जीपीएल-Py3.4-Qt4.8.7-x32.exe | विंडोज 32 बिट इंस्टॉलर |
PyQt4-4.11.4-जीपीएल-Py3.4-Qt5.5.0-x64.exe | विंडोज 64 बिट इंस्टॉलर |
PyQt4-4.11.4-जीपीएल-Py3.4-Qt5.5.0-x32.exe | विंडोज 32 बिट इंस्टॉलर |
PyQt4-4.11.4-जीपीएल-Py2.7-Qt4.8.7-x64.exe | विंडोज 64 बिट इंस्टॉलर |
PyQt4-4.11.4-जीपीएल-Py2.7-Qt4.8.7-x32.exe | विंडोज 32 बिट इंस्टॉलर |
PyQt5 Windows Binaries
PyQt5-5.5-जीपीएल-Py3.4-Qt5.5.0-x64.exe | विंडोज 64 बिट इंस्टॉलर |
PyQt5-5.5-जीपीएल-Py3.4-Qt5.5.0-x32.exe | विंडोज 32 बिट इंस्टॉलर |
लिनक्स
Ubuntu या किसी अन्य डेबियन लिनक्स वितरण के लिए, PyQt को स्थापित करने के लिए निम्नलिखित कमांड का उपयोग करें -
sudo apt-get install python-qt4
or
sudo apt-get install pyqt5-dev-tools
आप 'डाउनलोड' पृष्ठ पर उपलब्ध स्रोत कोड से भी निर्माण कर सकते हैं।
PyQt-X11-जीपीएल-4.11.4.tar.gz | लिनक्स, PyQt4 के लिए UNIX स्रोत |
PyQt-जीपीएल-5.5.tar.gz | PyQt5 के लिए लिनक्स, UNIX, MacOS / X स्रोत |
मैक ओ एस
PyQtX परियोजना (http://sourceforge.net/projects/pyqtx/) मैक के लिए PyQt के बायनेरिज़ होस्ट करता है। होमब्रेव इंस्टॉलर का प्रयोग निम्न कमांड के अनुसार करें -
brew install pyqt
PyQt का उपयोग करके एक सरल GUI एप्लिकेशन बनाना निम्नलिखित चरणों में शामिल है -
आयात QtGui मॉड्यूल।
एप्लिकेशन ऑब्जेक्ट बनाएं।
QWidget ऑब्जेक्ट शीर्ष स्तर की विंडो बनाता है। इसमें QLabel ऑब्जेक्ट जोड़ें।
लेबल के कैप्शन को "हैलो वर्ल्ड" के रूप में सेट करें।
SetGeometry () विधि द्वारा विंडो के आकार और स्थिति को परिभाषित करें।
द्वारा आवेदन का मुख्य भाग दर्ज करें app.exec_() तरीका।
import sys
from PyQt4 import QtGui
def window():
app = QtGui.QApplication(sys.argv)
w = QtGui.QWidget()
b = QtGui.QLabel(w)
b.setText("Hello World!")
w.setGeometry(100,100,200,50)
b.move(50,20)
w.setWindowTitle(“PyQt”)
w.show()
sys.exit(app.exec_())
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
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 | QtAssistant ऑनलाइन मदद के लिए समर्थन |
12 | QtDesigner क्यूटी डिजाइनर का विस्तार करने के लिए कक्षाएं |
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 डिज़ाइनर के पास एप्लिकेशन को डीबग करने और बनाने की सुविधा नहीं है।
क्यूटी डिजाइनर का उपयोग करके एक जीयूआई इंटरफ़ेस का निर्माण आवेदन के लिए एक शीर्ष स्तर की खिड़की चुनने के साथ शुरू होता है।
फिर आप बाएँ फलक पर विजेट बॉक्स से आवश्यक विगेट्स खींच और छोड़ सकते हैं। आप प्रपत्र पर रखी गई विजेट के गुणों को भी मान प्रदान कर सकते हैं।
डिज़ाइन किए गए फॉर्म को डेमो के रूप में सहेजा जाता है। इस यूआई फ़ाइल में डिजाइन में विगेट्स के XML प्रतिनिधित्व और उनके गुण शामिल हैं। यह डिज़ाइन pyuic4 कमांड लाइन उपयोगिता का उपयोग करके पायथन में अनुवाद किया गया है। यह उपयोगिता यूरिक मॉड्यूल के लिए एक आवरण है। Pyuic4 का उपयोग इस प्रकार है -
pyuic4 –x demo.ui –o demo.py
उपरोक्त कमांड में, -x स्विच उत्पन्न XML में थोड़ी मात्रा में अतिरिक्त कोड जोड़ता है ताकि यह स्व-निष्पादन योग्य स्टैंडअलोन एप्लिकेशन बन जाए।
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_())
परिणामी अजगर स्क्रिप्ट को निम्नलिखित डायलॉग बॉक्स दिखाने के लिए निष्पादित किया जाता है -
उपयोगकर्ता इनपुट फ़ील्ड में डेटा इनपुट कर सकता है लेकिन ऐड बटन पर क्लिक करने से कोई क्रिया उत्पन्न नहीं होगी क्योंकि यह किसी फ़ंक्शन से संबद्ध नहीं है। उपयोगकर्ता द्वारा उत्पन्न प्रतिक्रिया को प्रतिक्रिया के रूप में कहा जाता हैevent handling।
कंसोल मोड एप्लिकेशन के विपरीत, जिसे क्रमिक तरीके से निष्पादित किया जाता है, एक GUI आधारित एप्लिकेशन इवेंट संचालित होता है। उपयोगकर्ता के कार्यों के जवाब में कार्य या विधियों को क्रियान्वित किया जाता है जैसे कि बटन पर क्लिक करना, किसी संग्रह से आइटम का चयन करना या माउस क्लिक आदि, जिसे कहा जाता हैevents।
GUI इंटरफ़ेस बनाने के लिए उपयोग किए जाने वाले विजेट ऐसे आयोजनों के स्रोत के रूप में कार्य करते हैं। प्रत्येक PyQt विजेट, जो QObject वर्ग से लिया गया है, का उत्सर्जन करने के लिए डिज़ाइन किया गया है 'signal'एक या एक से अधिक घटनाओं के जवाब में। अपने आप पर संकेत कोई कार्रवाई नहीं करता है। इसके बजाय, यह एक से 'जुड़ा' हैslot'। स्लॉट कोई भी हो सकता हैcallable Python function।
PyQt में, एक संकेत और एक स्लॉट के बीच संबंध विभिन्न तरीकों से हासिल किया जा सकता है। सबसे अधिक इस्तेमाल की जाने वाली तकनीकें निम्नलिखित हैं -
QtCore.QObject.connect(widget, QtCore.SIGNAL(‘signalname’), slot_function)
एक स्लॉट_फंक्शन को कॉल करने का एक और अधिक सुविधाजनक तरीका, जब एक विजेट द्वारा सिग्नल उत्सर्जित किया जाता है, इस प्रकार है -
widget.signal.connect(slot_function)
मान लीजिए कि एक बटन क्लिक करने पर एक फ़ंक्शन को बुलाया जाना है। यहां, क्लिक किए गए सिग्नल को कॉल करने योग्य फ़ंक्शन से जोड़ा जाना है। इसे निम्नलिखित दो तकनीकों में से किसी में भी प्राप्त किया जा सकता है -
QtCore.QObject.connect(button, QtCore.SIGNAL(“clicked()”), 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 () फ़ंक्शन से जुड़ा होता है
QObject.connect(b2, SIGNAL("clicked()"), b2_clicked)
उदाहरण
import sys
from PyQt4.QtCore import *
from PyQt4.QtGui 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)
QObject.connect(b2,SIGNAL("clicked()"),b2_clicked)
win.setGeometry(100,100,200,100)
win.setWindowTitle("PyQt")
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 पिक्सेल नीचे।
यह Absolute Positioningहालांकि, निम्नलिखित कारणों से उपयुक्त नहीं है -
विंडो के आकार बदलने पर भी विजेट की स्थिति नहीं बदलती है।
अलग-अलग रिज़ॉल्यूशन वाले विभिन्न डिस्प्ले डिवाइस पर उपस्थिति एक समान नहीं हो सकती है।
लेआउट में संशोधन कठिन है क्योंकि इसे पूरे फॉर्म को फिर से डिज़ाइन करने की आवश्यकता हो सकती है।
PyQt एपीआई कंटेनर के अंदर विजेट्स की स्थिति के अधिक सुरुचिपूर्ण प्रबंधन के लिए लेआउट कक्षाएं प्रदान करता है। पूर्ण स्थिति पर लेआउट प्रबंधकों के फायदे हैं -
विंडो के अंदर विजेट स्वचालित रूप से आकार परिवर्तन कर रहे हैं।
विभिन्न प्रस्तावों के साथ प्रदर्शन उपकरणों पर एक समान उपस्थिति सुनिश्चित करता है।
रीडायरेक्ट किए बिना विजेट को गतिशील रूप से जोड़ना या हटाना संभव है।
यहां उन वर्गों की सूची दी गई है, जिनके बारे में हम इस अध्याय में एक-एक करके चर्चा करेंगे।
अनु क्रमांक। | कक्षाएं और विवरण |
---|---|
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 यदि किसी प्रपत्र में बहुत सारे फ़ील्ड एक साथ प्रदर्शित किए जाते हैं, तो उन्हें अलग टैब के प्रत्येक टैब के नीचे रखे गए विभिन्न पृष्ठों में व्यवस्थित किया जा सकता है। QTabWidget एक टैब बार और एक पृष्ठ क्षेत्र प्रदान करता है। |
17 | QDock एक डॉक करने योग्य विंडो एक सबविंडो है जो फ्लोटिंग स्थिति में रह सकती है या एक निर्दिष्ट स्थान पर मुख्य विंडो से जुड़ी हो सकती है। QMainWindow क्लास की मुख्य विंडो ऑब्जेक्ट में डॉकेबल विंडो के लिए आरक्षित क्षेत्र है। |
18 | QStatusBar QMainWindow वस्तु स्थिति पट्टी के रूप में नीचे एक क्षैतिज पट्टी होती है। इसका उपयोग स्थायी या प्रासंगिक स्थिति जानकारी प्रदर्शित करने के लिए किया जाता है। |
19 | QList QListWidget वर्ग सूची से आइटम जोड़ने या निकालने के लिए एक आइटम-आधारित इंटरफ़ेस है। सूची में प्रत्येक आइटम एक QListWidgetItem ऑब्जेक्ट है। ListWidget को बहुस्तरीय होने के लिए सेट किया जा सकता है। |
20 | QScrollBar स्क्रॉलबार नियंत्रण उपयोगकर्ता को देखने योग्य क्षेत्र के बाहर दस्तावेज़ के कुछ हिस्सों तक पहुंचने में सक्षम बनाता है। यह वर्तमान स्थिति को दृश्य संकेतक प्रदान करता है। |
21 | QCalendar QCalendar विजेट एक उपयोगी दिनांक पिकर नियंत्रण है। यह एक महीने का दृश्य प्रदान करता है। उपयोगकर्ता माउस या कीबोर्ड के उपयोग से तारीख का चयन कर सकता है, डिफ़ॉल्ट आज की तारीख है। |
ए QDialogविजेट उपयोगकर्ता से प्रतिक्रिया एकत्र करने के लिए ज्यादातर उपयोग की जाने वाली एक शीर्ष स्तरीय विंडो प्रस्तुत करता है। इसे होने के लिए कॉन्फ़िगर किया जा सकता हैModal (जहां यह अपनी मूल विंडो को ब्लॉक करता है) या Modeless (संवाद विंडो को बायपास किया जा सकता है)।
PyQt API में कई प्री-कॉन्फ़िगर किए गए डायलॉग विजेट्स जैसे InputDialog, FileDialog, FontDogog इत्यादि हैं।
उदाहरण
निम्नलिखित उदाहरण में, DialM विंडो का WindowModality विशेषता यह तय करता है कि यह मोडल है या मॉडलस। संवाद का कोई भी एक बटन डिफ़ॉल्ट रूप से सेट किया जा सकता है। जब उपयोगकर्ता एस्केप कुंजी दबाता है तो संवाद QDialog.reject () विधि द्वारा छोड़ दिया जाता है।
एक शीर्ष स्तर QWidget विंडो पर एक PushButton, जब क्लिक किया जाता है, एक संवाद विंडो का उत्पादन करता है। एक डायलॉग बॉक्स में इसकी शीर्षक पट्टी पर न्यूनतम और अधिकतम नियंत्रण नहीं होता है।
उपयोगकर्ता इस संवाद बॉक्स को पृष्ठभूमि में नहीं हटा सकता क्योंकि इसका WindowModality ApplicationModal पर सेट है।
import sys
from PyQt4.QtGui import *
from PyQt4.QtCore import *
def window():
app = QApplication(sys.argv)
w = QWidget()
b = QPushButton(w)
b.setText("Hello World!")
b.move(50,50)
b.clicked.connect(showdialog)
w.setWindowTitle("PyQt Dialog demo")
w.show()
sys.exit(app.exec_())
def showdialog():
d = QDialog()
b1 = QPushButton("ok",d)
b1.move(50,50)
d.setWindowTitle("Dialog")
d.setWindowModality(Qt.ApplicationModal)
d.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 PyQt4.QtGui import *
from PyQt4.QtCore import *
def window():
app = QApplication(sys.argv)
w = QWidget()
b = QPushButton(w)
b.setText("Show message!")
b.move(50,50)
b.clicked.connect(showdialog)
w.setWindowTitle("PyQt Dialog 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_()
print "value of pressed message box button:", retval
def msgbtn(i):
print "Button pressed is:",i.text()
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
एक सामान्य GUI एप्लिकेशन में कई विंडो हो सकती हैं। टैब्ड और स्टैक्ड विजेट एक बार में एक ऐसी विंडो को सक्रिय करने की अनुमति देते हैं। हालाँकि, कई बार यह दृष्टिकोण उपयोगी नहीं हो सकता है क्योंकि अन्य विंडो छिपी हुई है।
एक साथ कई विंडो प्रदर्शित करने का एक तरीका उन्हें स्वतंत्र विंडो के रूप में बनाना है। इसे एसडीआई (सिंगल डॉक्यूमेंट इंटरफेस) कहा जाता है। इसके लिए अधिक मेमोरी संसाधनों की आवश्यकता होती है क्योंकि प्रत्येक विंडो का अपना मेनू सिस्टम, टूलबार आदि हो सकता है।
एमडीआई (मल्टीपल डॉक्यूमेंट इंटरफेस) एप्लिकेशन कम मेमोरी संसाधनों का उपभोग करते हैं। उप-खिड़कियां मुख्य कंटेनर के अंदर एक दूसरे के संबंध में रखी गई हैं। कंटेनर विजेट कहा जाता है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 () सिग्नल का उत्सर्जन करता है जबकि WindowStateChanged () सिग्नल 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 PyQt4.QtCore import *
from PyQt4.QtGui 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 PyQt4.QtGui import *
from PyQt4.QtCore 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 & drop')
def main():
app = QApplication(sys.argv)
ex = Example()
ex.show()
app.exec_()
if __name__ == '__main__':
main()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
PyQt API में कई SQL आधारित डेटाबेस के साथ संचार करने के लिए एक विस्तृत वर्ग प्रणाली है। इसके 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 कमांड को निष्पादित और हेरफेर करने की कार्यक्षमता है। डीडीएल और डीएमएल दोनों प्रकार के एसक्यूएल प्रश्नों को निष्पादित किया जा सकता है। कक्षा में सबसे महत्वपूर्ण तरीका है exec_ (), जो एक तर्क के रूप में लेता है जिसमें SQL स्टेटमेंट को निष्पादित किया जाता है।
query = QtSql.QSqlQuery()
query.exec_("create table sportsmen(id int primary key,
" "firstname varchar(20), lastname varchar(20))")
निम्न स्क्रिप्ट पाँच रिकॉर्ड के साथ आबादी वाले स्पोर्ट्सपर्सन की तालिका के साथ SQLite डेटाबेस sports.db बनाता है।
from PyQt4 import QtSql, QtGui
def createDB():
db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sports.db')
if not db.open():
QtGui.QMessageBox.critical(None, QtGui.qApp.tr("Cannot open database"),
QtGui.qApp.tr("Unable to establish a database connection.\n"
"This example needs SQLite support. Please read "
"the Qt SQL driver documentation for information "
"how to build it.\n\n" "Click Cancel to exit."),
QtGui.QMessageBox.Cancel)
return False
query = QtSql.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__':
import sys
app = QtGui.QApplication(sys.argv)
createDB()
PyQt में QSqlTableModel क्लास एक उच्च-स्तरीय इंटरफ़ेस है जो एकल तालिका में रिकॉर्ड पढ़ने और लिखने के लिए संपादन योग्य डेटा मॉडल प्रदान करता है। यह मॉडल किसी क्यूटेबल व्यू ऑब्जेक्ट को पॉप्युलेट करने के लिए उपयोग किया जाता है। यह उपयोगकर्ता को एक स्क्रॉल करने योग्य और संपादन योग्य दृश्य प्रस्तुत करता है जिसे किसी भी शीर्ष स्तर की खिड़की पर रखा जा सकता है।
एक qableableModel वस्तु को निम्नलिखित तरीके से घोषित किया जाता है -
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 PyQt4 import QtCore, QtGui, QtSql
import sportsconnection
def initializeModel(model):
model.setTable('sportsmen')
model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
model.select()
model.setHeaderData(0, QtCore.Qt.Horizontal, "ID")
model.setHeaderData(1, QtCore.Qt.Horizontal, "First name")
model.setHeaderData(2, QtCore.Qt.Horizontal, "Last name")
def createView(title, model):
view = QtGui.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 = QtGui.QApplication(sys.argv)
db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sports.db')
model = QtSql.QSqlTableModel()
delrow = -1
initializeModel(model)
view1 = createView("Table Model (View 1)", model)
view1.clicked.connect(findrow)
dlg = QtGui.QDialog()
layout = QtGui.QVBoxLayout()
layout.addWidget(view1)
button = QtGui.QPushButton("Add a row")
button.clicked.connect(addrow)
layout.addWidget(button)
btn1 = QtGui.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_())
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
सब QWidgetPyQt में कक्षाएं QPaintDevice वर्ग से उप-वर्गित हैं। एQPaintDeviceएक दो आयामी स्थान है जो एक QPainter का उपयोग करने पर खींचा जा सकता है। पेंट डिवाइस के आयामों को शीर्ष-बाएं कोने से शुरू होने वाले पिक्सेल में मापा जाता है।
QPainter वर्ग विजेट और प्रिंटर जैसे अन्य पेंट करने योग्य उपकरणों पर निम्न स्तर की पेंटिंग करता है। आम तौर पर, विजेट के पेंट इवेंट में इसका उपयोग किया जाता है। QPaintEvent जब भी विजेट का स्वरूप अद्यतन किया जाता है।
प्रारंभ () विधि को कॉल करके चित्रकार सक्रिय होता है, जबकि अंत () विधि इसे निष्क्रिय कर देती है। बीच में, वांछित पैटर्न को उपयुक्त विधियों द्वारा चित्रित किया गया है जैसा कि निम्न तालिका में सूचीबद्ध है।
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | begin() लक्ष्य डिवाइस पर पेंटिंग शुरू करता है |
2 | drawArc() शुरू और अंत कोण के बीच एक चाप खींचता है |
3 | drawEllipse() एक आयत के अंदर एक दीर्घवृत्त खींचता है |
4 | drawLine() निर्दिष्ट बिंदु निर्देशांक के साथ एक रेखा खींचता है |
5 | drawPixmap() पिक्समैप को छवि फ़ाइल से निकालता है और इसे निर्दिष्ट स्थान पर प्रदर्शित करता है |
6 | drwaPolygon() निर्देशांक की एक सरणी का उपयोग कर एक बहुभुज खींचता है |
7 | drawRect() दी गई चौड़ाई और ऊंचाई के साथ ऊपरी-बाएँ समन्वय पर शुरू होने वाली एक आयत खींचता है |
8 | drawText() दिए गए निर्देशांक पर पाठ प्रदर्शित करता है |
9 | fillRect() क्यूक्लर पैरामीटर के साथ आयत को भरता है |
10 | setBrush() पेंटिंग के लिए एक ब्रश शैली सेट करता है |
1 1 | setPen() ड्राइंग के लिए उपयोग किए जाने वाले पेन का रंग, आकार और शैली सेट करता है |
पूर्वनिर्धारित QColor शैलियाँ
Qt.NoBrush | कोई ब्रश पैटर्न नहीं |
Qt.SolidPattern | वर्दी का रंग |
Qt.Dense1Pattern | बेहद घने ब्रश पैटर्न |
Qt.HorPattern | क्षैतिज रेखाएँ |
Qt.VerPattern | ऊर्ध्वाधर पंक्तियां |
Qt.CrossPattern | क्षैतिज और ऊर्ध्वाधर लाइनों को पार करना |
Qt.BDiagPattern | पिछड़ी हुई विकर्ण रेखाएँ |
Qt.FDiagPattern | आगे तिरछी रेखाएँ |
Qt.DiagCrossPattern | विकर्ण रेखाओं को पार करना |
पूर्वनिर्धारित 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 |
कस्टम रंग को RGB या CMYK या HSV मान निर्दिष्ट करके चुना जा सकता है।
उदाहरण
निम्न उदाहरण इन विधियों में से कुछ को लागू करता है।
import sys
from PyQt4.QtGui import *
from PyQt4.QtCore 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 Pyth
on")
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("python.jpg"))
qp.fillRect(200,175,150,100,QBrush(Qt.SolidPattern))
qp.end()
def main():
app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -
QClipboardक्लास सिस्टम-वाइड क्लिपबोर्ड तक पहुंच प्रदान करता है जो अनुप्रयोगों के बीच डेटा को कॉपी और पेस्ट करने के लिए एक सरल तंत्र प्रदान करता है। इसकी क्रिया QDrag वर्ग के समान है और समान डेटा प्रकारों का उपयोग करती है।
QApplication वर्ग में एक स्टैटिक विधि क्लिपबोर्ड () है जो क्लिपबोर्ड ऑब्जेक्ट के संदर्भ में देता है। किसी भी प्रकार के MimeData को क्लिपबोर्ड से कॉपी या पेस्ट किया जा सकता है।
निम्नलिखित क्लिपबोर्ड वर्ग विधियां हैं जो आमतौर पर उपयोग की जाती हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | clear() क्लिपबोर्ड सामग्री साफ़ करता है |
2 | setImage() क्लिपबोर्ड में QImage की प्रतियां |
3 | setMimeData() MIME डेटा को क्लिपबोर्ड में सेट करता है |
4 | setPixmap() क्लिपबोर्ड में कॉपी पिक्समैप ऑब्जेक्ट |
5 | setText() क्लिपबोर्ड में प्रतियां QString |
6 | text() क्लिपबोर्ड से पाठ पुनर्प्राप्त करता है |
क्लिपबोर्ड ऑब्जेक्ट से जुड़ा सिग्नल है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | dataChanged() जब भी क्लिपबोर्ड डेटा बदलता है |
उदाहरण
निम्न उदाहरण में, दो TextEdit ऑब्जेक्ट और दो Pushbuttons एक शीर्ष स्तर विंडो में जोड़े जाते हैं।
क्लिपबोर्ड ऑब्जेक्ट के साथ शुरू करने के लिए त्वरित है। Textedit ऑब्जेक्ट की कॉपी () विधि डेटा को सिस्टम क्लिपबोर्ड पर कॉपी करती है। जब पेस्ट बटन पर क्लिक किया जाता है, तो यह क्लिपबोर्ड डेटा प्राप्त करता है और इसे अन्य टेक्स्टडिट ऑब्जेक्ट में पेस्ट करता है।
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 पर प्रदर्शित छवि दिखाता है। पूरा कोड इस प्रकार है -
import sys
from PyQt4.QtCore import *
from PyQt4.QtGui import *
def window():
app = QApplication(sys.argv)
win = QWidget()
l1 = QLabel()
l1.setPixmap(QPixmap("python.jpg"))
vbox = QVBoxLayout()
vbox.addWidget(l1)
win.setLayout(vbox)
win.setWindowTitle("QPixmap Demo")
win.show()
sys.exit(app.exec_())
if __name__ == '__main__':
window()
उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -