2012-10-10 45 views
1

我试图通过pyside设置QGridLayout小部件的背景图像(它位于与应用程序相同的文件夹中)我无法看到所有的内容,文档和论坛帖子关于样式表“,但我仍然无法弄清楚我做错了什么。pyside设置背景图像通过样式表不工作

from PySide.QtCore import * 
from PySide.QtGui import * 
import sys 

class Main(QWidget): 

    def __init__(self, parent=None): 
     super(Main, self).__init__(parent) 

     j = 0 
     pos = [(0, 0), (0, 1), (0, 2), (0, 3), 
       (1, 0), (1, 1), (1, 2), (1, 3), 
       (2, 0), (2, 1), (2, 2), (2, 3), 
       (3, 0), (3, 1), (3, 2), (3, 3), 
       (4, 0), (4, 1), (4, 2), (4, 3), 
       (5, 0), (5, 1), (5, 2), (5, 3)] 

     grid = QGridLayout(self) 
     items = ["one", "Two", 'Three','four','five'] 

     for e in items: 
      picture = ImageLabel("Book.png", self) 
      picture.name = e 
      picture.setFixedSize(128,128) 
      picture.mousepos = str(picture.pos()) 
      picture.imageClicked.connect(self.anotherSlot) 
      grid.addWidget(picture, pos[j][0], pos[j][1]) 
      j = j + 1 
      picture.setToolTip('This is' + str(e) + ' widget') 
      picture.imageHovered.connect(self.Item_Hovered) 

     self.setStyleSheet("QGridLayout {background-image: url(./image.jpg) }"); 


    def anotherSlot(self): 
     sender = self.sender() 
     print "I clicked item " + str(sender.name) 

    def Item_Hovered(self): 
     sender = self.sender() 
     print "I'm Hovering over " + str(sender.name) 

class ImageLabel(QLabel): 

    imageClicked = Signal(str) # can be other types (list, dict, object...) 
    imageHovered = Signal(str) 
    imageLeave = Signal(str) 

    def __init__(self, image, parent=None): 
     super(ImageLabel, self).__init__(parent)   
     self.setPixmap(image) 
     # self.setMouseTracking(True) 

    def mousePressEvent(self, event): 
     print "from ImageLabel.mousePressEvent()" 
     self.imageClicked.emit("Image Clicked") 

    def enterEvent(self, event): 
     print "from ImageLabel.enterEvent()" 
     self.imageHovered.emit("Hovering") 

    def leaveEvent(self, event): 
     print "from ImageLabel.leaveEvent()" 
     self.imageLeave.emit("Hovering No More") 


a = QApplication([]) 
m = Main() 
m.show() 
sys.exit(a.exec_()) 

任何意见,将不胜感激。

回答

1

即使它的作品,你会不会得到预期的结果,只有这样,我获得正确的背景油漆覆盖的paintEvent

tile = QtGui.QPixmap("x.png") 

def paintEvent(self, pe): 
    painter = QtGui.QPainter(self) 
    painter.drawTiledPixmap(self.rect(), tile) 
    super(Console, self).paintEvent(pe) 

控制台是我class Console(QtGui.QMainWindow):类 的例子适用于整个窗口。

我不知道画家的构造可以从paintEvent

更新移开:貌似每个paintEvent

要创建QPainter需要我找到了一个最简单的方法,而不覆盖paintEvent

palette = QtGui.QPalette() 
palette.setBrush(QtGui.QPalette.Background, tile) 
self.setPalette(palette) 
+0

谢谢sherpya,帮助花了一点时间来包裹我的头,但我得到它的工作。你的解释让我困惑的是self.tile,它的实现是实际的pix-map图像变量 –

+0

,它肯定会读得更好!添加到我的片段! –

0

作为sherpya解释来实现微件的背景图像中的最简单的方法上面/窗口是丘斯托使所讨论的特定小部件的paintEvent处理程序变暗,所以这里是基于上述解释的代码,它终于有效。

def paintEvent(self, event): 
    self.tile= QPixmap("bookshelf.png") 
    painter = QPainter(self) 
    painter.drawTiledPixmap(self.rect(), self.tile) 
    super(Main, self).paintEvent(event) 

didnt解释什么sherpyas代码(这实际上帮助我了解的paintEvent)是self.tile变量包含了如果油漆变量本身中引用的实际像素映射图像。

self.tile= QPixmap("bookshelf.png") 

将绘制图像样式表创建错误的窗口小部件/窗口的背景!

+0

我已经用替代setPalette()方法更新了答案 – sherpya

1

检查Qt Stylesheet Reference,它列出了可以使用样式表自定义的小部件。

QGridLayout继承自QLayout,QLayoutItem和QObject。根据参考资料,这些都不能使用样式表进行样式设计。

不是自定义paintEvent处理程序,只是尝试将您的布局放在QFrame中。 QFrame支持CSS盒子模型,因此您可以使用QFrame上的background-image属性。