QGraphicsView не отображает QGraphicsItems - PullRequest
0 голосов
/ 10 сентября 2010

Использование PyQt4.

Моя цель - загрузить «части» .png, назначить их в QGraphicsItems, добавить их в сцену и заставить QGraphicsView отображать их. (Прямо сейчас меня не волнуют их координаты, все, что меня волнует, - заставить эту чертову штуку работать).

В настоящее время ничего не отображается. Сначала я подумал, что это проблема с добавлением элементов, а QGraphicsView не обновляется, но после прочтения немного больше о окнах просмотра это не имело смысла. Поэтому я протестировал добавление элементов QGraphicsView еще до того, как установил представление (поэтому я знаю, что это не будет проблемой обновления), и он все равно ничего не отображал. Путь определенно правильный. Вот код, который показывает, что происходит ...

Игнорировать проблемы с пробелами, макет испортился при вставке

class MainWindow(QtGui.QMainWindow):
 def __init__(self, parent = None):
  QtGui.QMainWindow.__init__(self, parent)

  self.setWindowTitle('NT State Editor')

  winWidth = 1024
  winHeight = 768

  screen = QtGui.QDesktopWidget().availableGeometry()
  screenCenterX = (screen.width() - winWidth) / 2
  screenCenterY = (screen.height() - winHeight) / 2
  self.setGeometry(screenCenterX, screenCenterY, winWidth, winHeight)

  self.tileMap = tilemap.TileMap()
  self.tileBar = tilebar.TileBar()

  mapView = QtGui.QGraphicsView(self.tileMap)
  tileBarView = QtGui.QGraphicsView(self.tileBar)

  button = tilebar.LoadTilesButton()
  QtCore.QObject.connect(button, QtCore.SIGNAL('selectedFile'),
      self.tileBar.loadTiles)

  hbox = QtGui.QHBoxLayout()
  hbox.addWidget(mapView)
  hbox.addWidget(self.tileBarView)
  hbox.addWidget(button)

  mainWidget = QtGui.QWidget()
  mainWidget.setLayout(hbox)

  self.setCentralWidget(mainWidget)


 app = QtGui.QApplication(sys.argv)
 mainWindow = MainWindow()
 mainWindow.show()
 sys.exit(app.exec_())

-

class Tile(QtGui.QGraphicsPixmapItem):
    def __init__(self, parent = None):
        QtGui.QGraphicsPixmapItem(self, parent)
        self.idAttr = -1


class TileBar(QtGui.QGraphicsScene):
    def __init__(self, parent = None):
    QtGui.QGraphicsScene.__init__(self, parent)

    def loadTiles(self, filename):
    tree = ElementTree()
    tree.parse(filename)
    root = tree.getroot()

    sheets = root.findall('sheet')

    for sheet in sheets:
        sheetPath = sheet.get('path')
        sheetImg = QtGui.QImage(sheetPath)

        strips = sheet.findall('strip')
        for strip in strips:
            tile = Tile()
            tile.idAttr = strip.get('id')

            clip = strip.find('clip')
            x = clip.get('x')
            y = clip.get('y')
            width = clip.get('width')
            height = clip.get('height')

            subImg = sheetImg.copy(int(x), int(y), int(width), int(height))
            pixmap = QtGui.QPixmap.fromImage(subImg)
            tile.setPixmap(pixmap)

            self.addItem(tile)

Я пробовал кое-что с подключением сигнала TileBar 'change ()' к различным функциям 'view', но ни одна из них не работала. У меня возникли некоторые проблемы с поиском хороших примеров использования Graphics View Framework (большинство из них очень очень мелкого масштаба), поэтому дайте мне знать, если я делаю это совершенно неправильно.

Любая помощь приветствуется. Спасибо.

1 Ответ

1 голос
/ 11 сентября 2010

Трудно сказать, что не так с вашим кодом, так как он не завершен и не хватает некоторых частей для его компиляции. Хотя есть несколько мест, которые потенциально могут вызвать проблему:

  1. Ваш конструктор класса Title; Я считаю, что вы должны вызывать конструктор базового класса, выполнив: QtGui.QGraphicsPixmapItem .__ init __ (self, parent) .
  2. Похоже, объекты вашей графической сцены создаются в сигнале нажатия кнопки. Могут быть проблемы с подключением вашего сигнала к соответствующему слоту, вы должны видеть предупреждения в выходных данных, если в вашем виджете есть такие проблемы.
  3. Похоже, вы загружаете имена файлов изображений из XML-файла, довольно сложно проверить, является ли логика прямой, но потенциально у вас там тоже может быть проблема.

Ниже приведена упрощенная версия вашего кода, которая загружает изображение в заголовок и добавляет его в графическую сцену:

import sys
from PyQt4 import QtGui, QtCore

class Tile(QtGui.QGraphicsPixmapItem):
    def __init__(self, parent=None):
        QtGui.QGraphicsPixmapItem.__init__(self, parent)
        self.idAttr = -1

class TileBar(QtGui.QGraphicsScene):
    def __init__(self, parent=None):
        QtGui.QGraphicsScene.__init__(self, parent)

    #def loadTiles(self, filename):
    def loadTiles(self):

        sheetImg = QtGui.QImage("put_your_file_name_here.png")
        pixmap = QtGui.QPixmap.fromImage(sheetImg)

        tile = Tile()
        tile.setPixmap(pixmap)

        self.addItem(tile)

        # skipping your ElementTree parsing logic here

class MainWindow(QtGui.QMainWindow):
    def __init__(self, parent=None):
        QtGui.QMainWindow.__init__(self, parent)

        self.setWindowTitle('NT State Editor')

        winWidth = 1024
        winHeight = 768

        screen = QtGui.QDesktopWidget().availableGeometry()
        screenCenterX = (screen.width() - winWidth) / 2
        screenCenterY = (screen.height() - winHeight) / 2
        self.setGeometry(screenCenterX, screenCenterY, winWidth, winHeight)

        #self.tileMap = Tiletilebar.Map()
        self.tileBar = TileBar()

        #mapView = QtGui.QGraphicsView(self.tileMap)
        self.tileBarView = QtGui.QGraphicsView(self.tileBar)

        #button = self.tilebar.LoadTilesButton()
        button = QtGui.QPushButton() 
        QtCore.QObject.connect(button, QtCore.SIGNAL("clicked()"), 
                               self.tileBar.loadTiles)

        #self.tileBar.loadTiles('some_file_name')

        hbox = QtGui.QHBoxLayout()
        #hbox.addWidget(mapView)
        hbox.addWidget(self.tileBarView)
        hbox.addWidget(button)

        mainWidget = QtGui.QWidget()
        mainWidget.setLayout(hbox)

        self.setCentralWidget(mainWidget)

app = QtGui.QApplication([])
exm = MainWindow()
exm.show()
app.exec_()

надеюсь, это поможет, с уважением

...