Как правильно обрабатывать события в PyQt 4? - PullRequest
2 голосов
/ 15 декабря 2009

Я видел такие примеры:

self.connect(self.ui.add_button, QtCore.SIGNAL('clicked()'),self.printer)

И примеры, подобные этому:

self.ui.add_button.clicked.connect(self.printer)

Я только начинаю изучать Qt; на каком я должен сосредоточиться?

Ответы [ 3 ]

3 голосов
/ 15 декабря 2009

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

0 голосов
/ 16 марта 2012

Я знаю, что этот пост довольно старый, но я наткнулся на него, может быть, вы тоже, и теперь это спасет ваш день;) хорошо ... кстати, это мой первый пост здесь на SO, да!

ВНИМАНИЕ, я не тестировал этот код, я просто скопировал некоторые фрагменты кода, которые я написал некоторое время назад, поэтому может быть какая-то ошибка, но я надеюсь, что она все равно поможет

Кратко о новых стилях PyQt:

# notice that the signal declarations are at class level (not inside some method)

class MyClass(QObject):    # must subclass QObject (or subclass)

    # declaring signals
    mySimpleSignal = pyqtSignal()
    mySignalWithArguments = pyqtSignal(int, list)
    myOverloadedSignal = ([int, object],[str,object])

    def __init__(self, parent=None):
        super(MyClass,self).__init__(parent=parent)    # remember to init the super class
        [...]

    # methods
    [...]

    # connecting signals
    def connectSignalsMethod(self):
        # connecting simple signal
        self.mySimpleSignal.connect(self.mySlot)
        # connecting signal with arguments
        self.mySignalWithArguments.connect(self.mySlotWithArguments)
        # connecting overloaded signals
        self.myOverloadedSignal[int, object].connect(self.mySlot1)
        self.myOverloadedSignal[str, object].connect(self.mySLot2)

        # same syntax for disconnect()


    # emitting signals
    def emitSignalsMethod(self):
        # emitting simple signal
        self.mySimpleSignal.emit()
        # emitting signal with arguments
        self.mySignalWithArguments.emit(123,['this','is','a','list'])
        # emitting overloaded signal
        myOverloadedSignal[str,object].emit('this is a string', myObject)


    # my slots
    @pyqtSlot()
    def mySlot(self):
        print('hey!')

    @pyqtSlot(int, list)
    def mySlotWithArguments(self, someNumber, someList):
        print('got a number: %d and a list: %s' % (someNumber, someList))

    @pyqtSlot(int, object)
    def mySlot1(self, intArg, objectArg):
        print('got an int and an object')

    @pyqtSlot(str, object)
    def mySlot2(self, str, object):
        print('got a string and an object')

    # an overloaded slot
    @pyqtSignal(int)
    @pyqtSignal(str)
    def overloadedSlot(someArgument)
        print('got something: %s' % someArgument)

в противном случае попробуйте это http://www.harshj.com/2010/05/06/pyqt-faq-custom-signals-jpeg-mouse-hovers-and-more/#custom

Edit: события и сигналы не совпадают, вы видите выше о сигналах

0 голосов
/ 22 июля 2011

AFAIK, новый стиль не работает, если есть перегруженные сигналы, поэтому

self.ui.add_button.clicked.connect(self.printer)

нельзя использовать, если есть, скажем,

clicked(float, float)

так что вам придется вернуться к старому стилю. Всегда хорошо знать и то, и другое.

...