Qt Signal Slot Connect Example

  1. Qt Signal Slot Connect Example Online
  2. Qt Signal Slot Connect
  3. Qt Disconnect Signal Slot

Signals and slots are loosely coupled: A class which emits a signal neither knows nor cares which slots receive the signal. Qt's signals and slots mechanism ensures that if you connect a signal to a slot, the slot will be called with the signal's parameters at the right time. Signals and slots can take any number of arguments of any type. The PunchingBag inherits from QObject so it can emit signals; it has a signal called punched, which carries no data; and it has a punch method which does nothing but emit the punched signal. To make our PunchingBag useful, we need to connect its punched signal to a slot that does something.

Overview

This program demonstrates how QML and C++ can be connected through Qt signalsand slots. It does this through embedding C++ code as a context property in QMLrather than explicitly connecting signals and slots.

Qt Signal Slot Connect Example Online

When the program is started, the C++ part send a signal to QML, including aparameter. This signal is only sent once. When the user clicks on the windowarea, a signal is sent from QML to a C++ slot.

Qt Signal Slot Connect Example

Watch the console output to see if it works.

Installation

This program requires a working Qt5 installation. It was tested with version 5.3 and 5.4.

In order to compile and run the program, execute the following commands.

Alternatively, the project can be loaded into Qt Creator and started from there.

More Documentation

This source code belongs to an article on our website.

Home > Articles > Programming > C/C++

  1. Signals and Slots in Depth
< BackPage 2 of 6Next >
This chapter is from the book
C++ GUI Programming with Qt4, 2nd Edition

This chapter is from the book

This chapter is from the book

Signals and Slots in Depth

The signals and slots mechanism is fundamental to Qt programming. It enables the application programmer to bind objects together without the objects knowing anything about each other. We have already connected some signals and slots together, declared our own signals and slots, implemented our own slots, and emitted our own signals. Let's take a moment to look at the mechanism more closely.

Slots are almost identical to ordinary C++ member functions. They can be virtual; they can be overloaded; they can be public, protected, or private; they can be directly invoked like any other C++ member functions; and their parameters can be of any types. The difference is that a slot can also be connected to a signal, in which case it is automatically called each time the signal is emitted.

The connect() statement looks like this:

where sender and receiver are pointers to QObjects and where signal and slot are function signatures without parameter names. The SIGNAL() and SLOT() macros essentially convert their argument to a string.

In the examples we have seen so far, we have always connected different signals to different slots. There are other possibilities to consider.

  • One signal can be connected to many slots:

    When the signal is emitted, the slots are called one after the other, in an unspecified order.

  • Many signals can be connected to the same slot:

    When either signal is emitted, the slot is called.

  • A signal can be connected to another signal:

    When the first signal is emitted, the second signal is emitted as well. Apart from that, signal–signal connections are indistinguishable from signal–slot connections.

  • Connections can be removed:

    This is rarely needed, because Qt automatically removes all connections involving an object when that object is deleted.

To successfully connect a signal to a slot (or to another signal), they must have the same parameter types in the same order:

Exceptionally, if a signal has more parameters than the slot it is connected to, the additional parameters are simply ignored:

If the parameter types are incompatible, or if the signal or the slot doesn't exist, Qt will issue a warning at run-time if the application is built in debug mode. Similarly, Qt will give a warning if parameter names are included in the signal or slot signatures.

So far, we have only used signals and slots with widgets. But the mechanism itself is implemented in QObject and isn't limited to GUI programming. The mechanism can be used by any QObject subclass:

Notice how the setSalary() slot is implemented. We emit the salaryChanged() signal only if newSalary != mySalary. This ensures that cyclic connections don't lead to infinite loops.

Related Resources

Example
  • Book $31.99

Qt Signal Slot Connect

  • Book $35.99

Qt Disconnect Signal Slot

  • Book $43.99