PyQt4 を使用して、Qlabel を使用して別のウィンドウに Web ベースの画像を表示するフォームを作成しています。フォームのボタンをクリックすると、フォームのテーブル セルから新しい画像の URL を読み取って、Qlabel が新しい画像で更新されるはずです。
私が抱えている問題は、setPixmap() プロパティを設定することで更新できるクラス オブジェクトとして Qlabel を作成する方法を理解していないことです。これまでに書いたものは次のとおりです。
import sys
from PyQt4.QtGui import *
from PyQt4.QtCore import *
from PyQt4.QtNetwork import QNetworkAccessManager, QNetworkRequest
CAT_PICS = ["http://static.tumblr.com/ce35b04e242c6b8073f3ff7801147e9f/sz5wgey/obSmpcvso/tumblr_static_o-cats-kill-billions-facebook.jpg",
"http://jasonlefkowitz.net/wp-content/uploads/2013/07/cats-16140154-1920-1080.jpg",
"http://4.bp.blogspot.com/-MzZCzWI_6Xc/UIUQp1qPfzI/AAAAAAAAHpA/OTwHCJSWFAY/s1600/cats_animals_kittens_cat_kitten_cute_desktop_1680x1050_hd-wallpaper-753974.jpeg"]
class ImageLabel(QLabel):
def __init__(self, parent=None):
QLabel.__init__(self, parent)
url = self.text()
nam = QNetworkAccessManager()
def finishRequest(reply):
img = QImage()
img.loadFromData(reply.readAll())
myImage = QPixmap(img)
self.setFixedSize(myImage.size())
self.setPixmap(QPixmap(myImage))
nam.finished.connect(finishRequest)
nam.get(QNetworkRequest(QUrl(url)))
class MainForm(QDialog):
index = 0
def __init__(self):
super(MainForm, self).__init__()
changePhotoButton = QPushButton("Next Photo")
layout = QHBoxLayout()
layout.addWidget(changePhotoButton)
self.setLayout(layout)
self.connect(changePhotoButton, SIGNAL("clicked()"),
self.updatePhoto)
def updatePhoto(self):
url = CAT_PICS[self.index]
imageLabel = ImageLabel(url)
imageLabel.show()
self.index += 1
def main():
app = QApplication(sys.argv)
form = MainForm()
form.show()
app.exec_()
main()
コードは実行されますが、ImageLabel クラスが呼び出されると、URL からの初期テキストで QLabel が作成されますが、画像は取得されず、Qlabel はすぐにビューから削除されます。
これを機能させる方法についてのヒントをいただければ幸いです。