访问动态添加的小部件(pyqt)
Accessing dynamically added widgets (pyqt)
我想将文本添加到文本框中,我已根据此问题的已接受答案使用按钮添加了该文本框:Dynamically adding and removing widgets in pyqt
但是我的问题是我无法访问我添加的文本框。 This post 告诉我,在使用 addWidget()
添加到布局时,我可以使用 itemAt()
来遍历添加的项目。但是我只能访问 QWidgetIem
类型的 'inner layout'
这是我的代码:-
from PyQt4 import QtGui, QtCore
import sys
class Main(QtGui.QMainWindow):
def __init__(self, parent = None):
super(Main, self).__init__(parent)
# main button
self.addButton = QtGui.QPushButton('button to add other widgets')
self.addButton.clicked.connect(self.addWidget)
# scroll area widget contents - layout
self.scrollLayout = QtGui.QHBoxLayout()
# scroll area widget contents
self.scrollWidget = QtGui.QWidget()
self.scrollWidget.setLayout(self.scrollLayout)
# scroll area
self.scrollArea = QtGui.QScrollArea()
self.scrollArea.setWidgetResizable(True)
self.scrollArea.setWidget(self.scrollWidget)
# main layout
self.mainLayout = QtGui.QVBoxLayout()
# add all main to the main vLayout
self.mainLayout.addWidget(self.addButton)
self.mainLayout.addWidget(self.scrollArea)
# central widget
self.centralWidget = QtGui.QWidget()
self.centralWidget.setLayout(self.mainLayout)
# set central widget
self.setCentralWidget(self.centralWidget)
def addWidget(self):
self.scrollLayout.addWidget(Test())
# This doesn't work
print self.scrollLayout.itemAt(0)
class Test(QtGui.QWidget):
def __init__(self, parent=None):
super(Test, self).__init__(parent)
# Sensor Indicator
self.pushButton = QtGui.QPushButton()
self.pushButton.setStyleSheet("background-color: green")
# Console Window to display sensor data
self.logOutput = QtGui.QTextEdit()
self.logOutput.setReadOnly(True)
self.logOutput.setLineWrapMode(QtGui.QTextEdit.NoWrap)
self.font = self.logOutput.font()
self.font.setFamily("Courier")
self.font.setPointSize(10)
layout = QtGui.QVBoxLayout()
layout.addWidget(self.pushButton)
layout.addWidget(self.logOutput)
self.setLayout(layout)
app = QtGui.QApplication(sys.argv)
myWidget = Main()
myWidget.show()
app.exec_()
QWidgetItem
有一个 widget()
函数用于检索它包含的对象:
def addWidget(self):
self.scrollLayout.addWidget(Test())
index = self.scrollLayout.count() - 1
widget = self.scrollLayout.itemAt(index).widget()
if widget is not None:
widget.logOutput.setText('Hello World!')
我想将文本添加到文本框中,我已根据此问题的已接受答案使用按钮添加了该文本框:Dynamically adding and removing widgets in pyqt
但是我的问题是我无法访问我添加的文本框。 This post 告诉我,在使用 addWidget()
添加到布局时,我可以使用 itemAt()
来遍历添加的项目。但是我只能访问 QWidgetIem
这是我的代码:-
from PyQt4 import QtGui, QtCore
import sys
class Main(QtGui.QMainWindow):
def __init__(self, parent = None):
super(Main, self).__init__(parent)
# main button
self.addButton = QtGui.QPushButton('button to add other widgets')
self.addButton.clicked.connect(self.addWidget)
# scroll area widget contents - layout
self.scrollLayout = QtGui.QHBoxLayout()
# scroll area widget contents
self.scrollWidget = QtGui.QWidget()
self.scrollWidget.setLayout(self.scrollLayout)
# scroll area
self.scrollArea = QtGui.QScrollArea()
self.scrollArea.setWidgetResizable(True)
self.scrollArea.setWidget(self.scrollWidget)
# main layout
self.mainLayout = QtGui.QVBoxLayout()
# add all main to the main vLayout
self.mainLayout.addWidget(self.addButton)
self.mainLayout.addWidget(self.scrollArea)
# central widget
self.centralWidget = QtGui.QWidget()
self.centralWidget.setLayout(self.mainLayout)
# set central widget
self.setCentralWidget(self.centralWidget)
def addWidget(self):
self.scrollLayout.addWidget(Test())
# This doesn't work
print self.scrollLayout.itemAt(0)
class Test(QtGui.QWidget):
def __init__(self, parent=None):
super(Test, self).__init__(parent)
# Sensor Indicator
self.pushButton = QtGui.QPushButton()
self.pushButton.setStyleSheet("background-color: green")
# Console Window to display sensor data
self.logOutput = QtGui.QTextEdit()
self.logOutput.setReadOnly(True)
self.logOutput.setLineWrapMode(QtGui.QTextEdit.NoWrap)
self.font = self.logOutput.font()
self.font.setFamily("Courier")
self.font.setPointSize(10)
layout = QtGui.QVBoxLayout()
layout.addWidget(self.pushButton)
layout.addWidget(self.logOutput)
self.setLayout(layout)
app = QtGui.QApplication(sys.argv)
myWidget = Main()
myWidget.show()
app.exec_()
QWidgetItem
有一个 widget()
函数用于检索它包含的对象:
def addWidget(self):
self.scrollLayout.addWidget(Test())
index = self.scrollLayout.count() - 1
widget = self.scrollLayout.itemAt(index).widget()
if widget is not None:
widget.logOutput.setText('Hello World!')