0

はい、私はこれがクレイジーに聞こえることを知っています. しかし、これが状況です。

バグを再現する最小限のコードを作成しました。このコードは でメイン ウィンドウを作成し、これにはと ボタンのあるQTabWidget1 つのタブがあります。QListViewリスト ビューは に接続されていQAbstractListModelます。初期状態では、リスト モデルには空のリストが含まれています。ユーザーがボタンをクリックすると、3 つの要素が取り込まれ、対応する信号が発せられます。このシグナルで、タブ ウィジェットは新しいタイトルのシグナルを発行します。これは、QMainWindowタブ タイトルをキャッチして変更するために使用されます。

したがって、問題は、setTabText()この新しいタイトルで呼び出すと、クリックするまでリストビューが空のままになることです (その後、新しいアイテムがすぐに表示されます)。代わりに新しいタイトルを使用setWindowTitle()すると、ボタンを押した直後に新しいアイテムがリスト ビューに表示されます。私は何か間違ったことをしていますか、それともQTabWidget(または Python マッピングに) バグがありますか?

コードは次のとおりです。

from PyQt4 import QtGui, QtCore
import sys


class MainWindow(QtGui.QMainWindow):

    def __init__(self):
        QtGui.QMainWindow.__init__(self)

        self.setWindowTitle("Test")
        self._tabbar = QtGui.QTabWidget()
        self.setCentralWidget(self._tabbar)

        tab = SearchWindow(self)
        tab.titleChanged.connect(self._refreshTabTitle)
        self._tabbar.addTab(tab, "Initial title")

    def _refreshTabTitle(self, title):
        # if line 1 is commented - no bug, if line 2 is commented - bug exists
        self._tabbar.setTabText(0, title) # line 1
        #self.setWindowTitle(title) # line 2


class SearchWindow(QtGui.QSplitter):

    titleChanged = QtCore.pyqtSignal(str)

    def __init__(self, parent):
        QtGui.QSplitter.__init__(self, QtCore.Qt.Vertical, parent)

        results_model = ResultsModel(self)

        results_view = QtGui.QListView()
        results_view.setModel(results_model)
        self.addWidget(results_view)

        search_button = QtGui.QPushButton(">>")
        search_button.clicked.connect(results_model.refreshResults)
        self.addWidget(search_button)

        results_model.searchFinished.connect(self._refreshTitle)

    def _refreshTitle(self):
        self.titleChanged.emit("New title")


class ResultsModel(QtCore.QAbstractListModel):

    searchFinished = QtCore.pyqtSignal()

    def __init__(self, parent):
        QtCore.QAbstractListModel.__init__(self, parent)
        self._results = []

    def rowCount(self, parent):
        return len(self._results)

    def data(self, index, role=QtCore.Qt.DisplayRole):
        if not index.isValid():
            return None
        elif index.row() = len(self._results):
            return None
        elif role == QtCore.Qt.DisplayRole:
            return self._results[index.row()]

    def refreshResults(self):
        self._results = ['result1', 'result2', 'result3']
        self.reset()
        self.searchFinished.emit()


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

Mac OS 10.6.2、Qt SDK 2009.04 (4.5)、pyQt 4.6.1 (これが問題で、4.5 を使用する必要があるのでしょうか?)、Python 3.1 でテスト済み。

4

1 に答える 1

0

Linux、Qt 4.5.3、pyQt 4.5.4、python 2.5.2 を使用して問題を再現できませんでした。

これは間違いなくバージョン/プラットフォームに依存していると思います。MacOS では Qt 4.5.3 + pyQt 4.5.4 + python 2.5.2 を試す必要があります。問題を再現できる場合は、MacOS qt ポートのバグに似ています。できない場合は、Windows または Linux で新しい qt バージョンを試してください。

于 2009-12-06T08:13:32.330 に答える