Как кодировать кнопку изображения в PyQt? - PullRequest
8 голосов
/ 26 апреля 2010

Я пытаюсь сделать простой аудиоплеер, но я хочу использовать изображение (значок) в качестве кнопки.

Ответы [ 5 ]

19 голосов
/ 26 апреля 2010

Вы можете создать подкласс QAbstractButton и создать собственную кнопку. Вот простой простой пример:

import sys
from PyQt4.QtGui import *

class PicButton(QAbstractButton):
    def __init__(self, pixmap, parent=None):
        super(PicButton, self).__init__(parent)
        self.pixmap = pixmap

    def paintEvent(self, event):
        painter = QPainter(self)
        painter.drawPixmap(event.rect(), self.pixmap)

    def sizeHint(self):
        return self.pixmap.size()

app = QApplication(sys.argv)
window = QWidget()
layout = QHBoxLayout(window)

button = PicButton(QPixmap("image.png"))
layout.addWidget(button)

window.show()
sys.exit(app.exec_())

Это не супер легкий способ, но он дает вам много контроля. Вы можете добавить второе растровое изображение и нарисовать его, только когда указатель мыши находится над кнопкой. Вы можете изменить текущее поведение растяжения на центрирующее. Вы можете сделать так, чтобы он не имел прямоугольную форму и так далее ...

Кнопка, которая изменяет изображения при наведении курсора мыши и при нажатии:

from PyQt4.QtGui import *
from PyQt4.QtCore import *

class PicButton(QAbstractButton):
    def __init__(self, pixmap, pixmap_hover, pixmap_pressed, parent=None):
        super(PicButton, self).__init__(parent)
        self.pixmap = pixmap
        self.pixmap_hover = pixmap_hover
        self.pixmap_pressed = pixmap_pressed

        self.pressed.connect(self.update)
        self.released.connect(self.update)

    def paintEvent(self, event):
        pix = self.pixmap_hover if self.underMouse() else self.pixmap
        if self.isDown():
            pix = self.pixmap_pressed

        painter = QPainter(self)
        painter.drawPixmap(event.rect(), pix)

    def enterEvent(self, event):
        self.update()

    def leaveEvent(self, event):
        self.update()

    def sizeHint(self):
        return QSize(200, 200)
4 голосов
/ 29 июня 2011

Вы можете использовать QToolButton с установленным свойством автоподнятия true и там вы также можете установить свое изображение.

4 голосов
/ 06 мая 2010

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

class ExtendedQLabel(QLabel):

    def __init__(self, parent):
        QLabel.__init__(self, parent)

    def mouseReleaseEvent(self, ev):
        self.emit(SIGNAL('clicked()'))

Надеюсь, это поможет!

3 голосов
/ 26 апреля 2010

Как то так, может быть?

import sys

from PyQt4.QtGui import *
from PyQt4.QtCore import *

app = QApplication(sys.argv)
widget = QWidget()
layout = QHBoxLayout()
widget.setLayout(layout)
button = QPushButton()
layout.addWidget(button)
icon = QIcon("image.png")
button.setIcon(icon)
widget.show()
app.exec_()
1 голос
/ 27 апреля 2010

Другой вариант - использовать таблицы стилей. Что-то вроде:

from PyQt4 import QtCore, QtGui
import os
...

path = os.getcwd()
self.myButton.setStyleSheet("background-image: url(" + path + "/myImage.png);")
...