在PYQT5中设置来自keypress事件的小部件

时间:2017-05-02 17:44:05

标签: python python-3.x pyqt pyqt5

当我按空格键时,我正在尝试设置小部件。 我有一个包含QLabel的QGridLayout。 我想在QGridLayout中设置来自coord的特定Qlabel的文本,但是当我从keypress函数访问QGridLayout时,变量为null。

import sys
from PyQt5 import QtCore, QtWidgets
from PyQt5.QtWidgets import QMainWindow, QLabel, QGridLayout, QWidget
from PyQt5.QtCore import QSize    

class Position:
   def __init__(self, x, y):
      self.x = x
      self.y = y

class HelloWindow(QMainWindow):
    global gridLayout
    def __init__(self):
        QMainWindow.__init__(self)

        self.setMinimumSize(QSize(640, 640))    
        self.setWindowTitle("Hello world") 

        centralWidget = QWidget(self)          
        self.setCentralWidget(centralWidget)   

        gridLayout = QGridLayout(self)
        gridLayout.setSpacing(0)  
        centralWidget.setLayout(gridLayout)  

        file_text = open("logic/file.txt", "r")
        file = file_text.read()
        file = file.replace("[(","")
        file = file.replace(")]","")
        file = file.replace("),(",";")
        positions = file.split(';')
        lista = []
        for pos in positions:
         coord = pos.split(',')
         temp = Position(int(coord[0]),int(coord[1]))
         lista.append(temp)
        file_text.close()

        cont = 0
        for x in range(0, 9):
         for y in range(0, 9):
            if cont < 64:
               title = QLabel(str(cont+1), self) 
               title.setAlignment(QtCore.Qt.AlignCenter)
               title.setContentsMargins(0,0,0,0)
               title.setStyleSheet('QLabel {background-color: white; color: red; font-size: 24px; font-weight: bold}')
               if cont%2 == 0:
                  title.setStyleSheet('QLabel {background-color: black; color: red; font-size: 24px; font-weight: bold}')
               gridLayout.addWidget(title,lista[cont].x,lista[cont].y)
               cont += 1

    def keyPressEvent(self, event):
      if event.key() == QtCore.Qt.Key_Escape:
         self.close()
      if event.key() == QtCore.Qt.Key_Space:
         item = gridLayout.itemAtPosition(1,1)
         w = item.widget()
         w.setText("test")

if __name__ == "__main__":
    app = QtWidgets.QApplication(sys.argv)
    mainWin = HelloWindow()
    mainWin.show()
    sys.exit( app.exec_() )

下一节是测试

def keyPressEvent(self, event):
      if event.key() == QtCore.Qt.Key_Escape:
         self.close()
      if event.key() == QtCore.Qt.Key_Space:
         item = gridLayout.itemAtPosition(1,1)
         w = item.widget()
         w.setText("test")

我可以从你的coord访问widget来设置你的文字。

1 个答案:

答案 0 :(得分:1)

问题来自于全局变量的误用,在你的情况下每次使用它都必须声明:

class HelloWindow(QMainWindow):
    def __init__(self):
        QMainWindow.__init__(self)
        [...]
        global gridLayout
        gridLayout = QGridLayout(self)
        [...]

    def keyPressEvent(self, event):
      if event.key() == QtCore.Qt.Key_Escape:
         self.close()
      if event.key() == QtCore.Qt.Key_Space:
        global gridLayout
        item = gridLayout.itemAtPosition(1,1)
        w = item.widget()
        w.setText("test")

更优雅的解决方案是将gridLayout声明为该类的属性,为此必须在所有情况下将gridLayout更改为self.gridLayout

class Position:
   def __init__(self, x, y):
      self.x = x
      self.y = y

class HelloWindow(QMainWindow):
    def __init__(self):
        QMainWindow.__init__(self)

        self.setMinimumSize(QSize(640, 640))    
        self.setWindowTitle("Hello world") 

        centralWidget = QWidget(self)          
        self.setCentralWidget(centralWidget)   
        self.gridLayout =QGridLayout(self)
        self.gridLayout.setSpacing(0)  
        centralWidget.setLayout(self.gridLayout)  

        file_text = open("logic/file.txt", "r")
        file = file_text.read()
        file = file.replace("[(","")
        file = file.replace(")]","")
        file = file.replace("),(",";")
        positions = file.split(';')
        lista = []
        for pos in positions:
            coord = pos.split(',')
            temp = Position(int(coord[0]),int(coord[1]))
            lista.append(temp)
        file_text.close()

        cont = 0
        for x in range(0, 9):
            for y in range(0, 9):
                if cont < 64:
                    title = QLabel(str(cont+1), self) 
                    title.setAlignment(QtCore.Qt.AlignCenter)
                    title.setContentsMargins(0,0,0,0)
                    title.setStyleSheet('QLabel {background-color: white; color: red; font-size: 24px; font-weight: bold}')
                    if cont%2 == 0:
                       title.setStyleSheet('QLabel {background-color: black; color: red; font-size: 24px; font-weight: bold}')
                    self.gridLayout.addWidget(title,lista[cont].x,lista[cont].y)
                    cont += 1

    def keyPressEvent(self, event):
        if event.key() == QtCore.Qt.Key_Escape:
            self.close()
        if event.key() == QtCore.Qt.Key_Space:
            item = selself.gridLayout.itemAtPosition(1,1)
            w = item.widget()
            w.setText("test")

if __name__ == "__main__":
    app = QtWidgets.QApplication(sys.argv)
    mainWin = HelloWindow()
    mainWin.show()
    sys.exit( appself..exec_() )