This file is indexed.

/usr/share/qt5/doc/qtqml/qtqml-syntax-signals.html is in qtdeclarative5-doc-html 5.2.1-3ubuntu15.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en_US" lang="en_US">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!-- signals.qdoc -->
  <title>Signal and Handler Event System | QtQml 5.2</title>
  <link rel="stylesheet" type="text/css" href="style/offline.css" />
</head>
<body>
<div class="header" id="qtdocheader">
    <div class="main">
    <div class="main-rounded">
        <div class="navigationbar">
        <ul>
<li>Qt 5.2</li>
<li><a href="qtqml-index.html">Qt QML</a></li>
<li>Signal and Handler Event System</li>
<li id="buildversion">
Qt 5.2.1 Reference Documentation</li>
    </ul>
    </div>
</div>
<div class="content">
<div class="line">
<div class="content mainContent">
<div class="toc">
<h3><a name="toc">Contents</a></h3>
<ul>
<li class="level1"><a href="#receiving-signals-with-signal-handlers">Receiving Signals with Signal Handlers</a></li>
<li class="level2"><a href="#property-change-signal-handlers">Property Change Signal Handlers</a></li>
<li class="level2"><a href="#using-the-connections-type">Using the Connections Type</a></li>
<li class="level2"><a href="#attached-signal-handlers">Attached Signal Handlers</a></li>
<li class="level1"><a href="#adding-signals-to-custom-qml-types">Adding Signals to Custom QML Types</a></li>
<li class="level1"><a href="#connecting-signals-to-methods-and-signals">Connecting Signals to Methods and Signals</a></li>
<li class="level3"><a href="#signal-to-signal-connect">Signal to Signal Connect</a></li>
</ul>
</div>
<h1 class="title">Signal and Handler Event System</h1>
<span class="subtitle"></span>
<!-- $$$qtqml-syntax-signals.html-description -->
<div class="descr"> <a name="details"></a>
<p>Application and user interface components need to communicate with each other. For example, a button needs to know that the user has clicked on it. The button may change colors to indicate its state or perform some logic. As well, application needs to know whether the user is clicking the button. The application may need to relay this clicking event to other applications.</p>
<p>QML has a signal and handler mechanism, where the <i>signal</i> is the event and the signal is responded to through a <i>signal handler</i>. When a signal is emitted, the corresponding signal handler is invoked. Placing logic such as scripts or other operations in the handler allows the component to respond to the event.</p>
<a name="qml-signals-and-handlers"></a><a name="receiving-signals-with-signal-handlers"></a>
<h2>Receiving Signals with Signal Handlers</h2>
<p>To receive a notification when a particular signal is emitted for a particular object, the object definition should declare a signal handler named <i>on&lt;Signal&gt;</i> where <i>&lt;Signal&gt;</i> is the name of the signal, with the first letter capitalized. The signal handler should contain the JavaScript code to be executed when the signal handler is invoked.</p>
<p>For example, the MouseArea type from the <tt>QtQuick</tt> module has a <tt>clicked</tt> signal that is emitted whenever the mouse is clicked within the area. Since the signal name is <tt>clicked</tt>, the signal handler for receiving this signal should be named <tt>onClicked</tt>. In the example below, whenever the mouse area is clicked, the <tt>onClicked</tt> handler is invoked, applying a random color to the Rectangle:</p>
<pre class="qml">import QtQuick 2.0

<span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">rect</span>
    <span class="name">width</span>: <span class="number">100</span>; <span class="name">height</span>: <span class="number">100</span>

    <span class="type">MouseArea</span> {
        <span class="name">anchors</span>.fill: <span class="name">parent</span>
        <span class="name">onClicked</span>: {
            <span class="name">rect</span>.<span class="name">color</span> <span class="operator">=</span> <span class="name">Qt</span>.<span class="name">rgba</span>(<span class="name">Math</span>.<span class="name">random</span>(), <span class="name">Math</span>.<span class="name">random</span>(), <span class="name">Math</span>.<span class="name">random</span>(), <span class="number">1</span>);
        }
    }
}</pre>
<p>Looking at the MouseArea documentation, you can see the clicked signal is emitted with a parameter named <tt>mouse</tt> which is a MouseEvent object that contains further details about the mouse click event. This name can be referred to in our <tt>onClicked</tt> handler to access this parameter. For example, the MouseEvent type has <tt>x</tt> and <tt>y</tt> coordinates that allows us to print out the exact location where the mouse was clicked:</p>
<pre class="qml">import QtQuick 2.0

<span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">rect</span>
    <span class="name">width</span>: <span class="number">100</span>; <span class="name">height</span>: <span class="number">100</span>

    <span class="type">MouseArea</span> {
        <span class="name">anchors</span>.fill: <span class="name">parent</span>
        <span class="name">onClicked</span>: {
            <span class="name">rect</span>.<span class="name">color</span> <span class="operator">=</span> <span class="name">Qt</span>.<span class="name">rgba</span>(<span class="name">Math</span>.<span class="name">random</span>(), <span class="name">Math</span>.<span class="name">random</span>(), <span class="name">Math</span>.<span class="name">random</span>(), <span class="number">1</span>);

            <span class="comment">// access 'mouse' parameter</span>
            <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;Clicked mouse at&quot;</span>, <span class="name">mouse</span>.<span class="name">x</span>, <span class="name">mouse</span>.<span class="name">y</span>)
        }
    }
}</pre>
<a name="property-change-signal-handlers"></a>
<h3>Property Change Signal Handlers</h3>
<p>A signal is automatically emitted when the value of a QML property changes. This type of signal is a <i>property change signal</i> and signal handlers for these signals are written in the form <i>on&lt;Property&gt;Changed</i> where <i>&lt;Property&gt;</i> is the name of the property, with the first letter capitalized.</p>
<p>For example, the MouseArea type has a pressed property. To receive a notification whenever this property changes, write a signal handler named <tt>onPressedChanged</tt>:</p>
<pre class="qml">import QtQuick 2.0

<span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">rect</span>
    <span class="name">width</span>: <span class="number">100</span>; <span class="name">height</span>: <span class="number">100</span>

    <span class="type">MouseArea</span> {
        <span class="name">anchors</span>.fill: <span class="name">parent</span>
        <span class="name">onPressedChanged</span>: {
            <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;Mouse area is pressed?&quot;</span>, <span class="name">pressed</span>)
        }
    }
}</pre>
<p>Even though the MouseArea documentation does not document a signal handler named <tt>onPressedChanged</tt>, the signal is implicitly provided by the fact that the <tt>pressed</tt> property exists.</p>
<a name="using-the-connections-type"></a>
<h3>Using the Connections Type</h3>
<p>In some cases it may be desirable to access a signal outside of the object that emits it. For these purposes, the <tt>QtQuick</tt> module provides the <a href="qml-qtqml-connections.html">Connections</a> type for connecting to signals of arbitrary objects. A <a href="qml-qtqml-connections.html">Connections</a> object can receive any signal from its specified <a href="qml-qtqml-connections.html#target-prop">target</a>.</p>
<p>For example, the <tt>onClicked</tt> handler in the earlier example could have been received by the root Rectangle instead, by placing the <tt>onClicked</tt> handler in a <a href="qml-qtqml-connections.html">Connections</a> object that has its <a href="qml-qtqml-connections.html#target-prop">target</a> set to the MouseArea:</p>
<pre class="qml">import QtQuick 2.0

<span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">rect</span>
    <span class="name">width</span>: <span class="number">100</span>; <span class="name">height</span>: <span class="number">100</span>

    <span class="type">MouseArea</span> {
        <span class="name">id</span>: <span class="name">mouseArea</span>
        <span class="name">anchors</span>.fill: <span class="name">parent</span>
    }

    <span class="type"><a href="qml-qtqml-connections.html">Connections</a></span> {
        <span class="name">target</span>: <span class="name">mouseArea</span>
        <span class="name">onClicked</span>: {
            <span class="name">rect</span>.<span class="name">color</span> <span class="operator">=</span> <span class="name">Qt</span>.<span class="name">rgba</span>(<span class="name">Math</span>.<span class="name">random</span>(), <span class="name">Math</span>.<span class="name">random</span>(), <span class="name">Math</span>.<span class="name">random</span>(), <span class="number">1</span>);
        }
    }
}</pre>
<a name="attached-signal-handlers"></a>
<h3>Attached Signal Handlers</h3>
<p>An <a href="qtqml-syntax-objectattributes.html#attached-properties-and-attached-signal-handlers">attached signal handler</a> is a signal handler that receives a signal from an <i>attaching type</i> rather than the object within which the handler is declared.</p>
<p>For example, <tt>\l</tt> {Component::isCompleted}{Component.isCompleted} is an attached signal handler. This handler is often used to execute some JavaScript code when its creation process has been completed, as in the example below:</p>
<pre class="qml">import QtQuick 2.0

<span class="type">Rectangle</span> {
    <span class="name">width</span>: <span class="number">200</span>; <span class="name">height</span>: <span class="number">200</span>
    <span class="name">color</span>: <span class="name">Qt</span>.<span class="name">rgba</span>(<span class="name">Qt</span>.<span class="name">random</span>(), <span class="name">Qt</span>.<span class="name">random</span>(), <span class="name">Qt</span>.<span class="name">random</span>(), <span class="number">1</span>)

    <span class="name">Component</span>.onCompleted: {
        <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;The rectangle's color is&quot;</span>, <span class="name">color</span>)
    }
}</pre>
<p>The <tt>onCompleted</tt> handler is not responding to some <tt>completed</tt> signal from the Rectangle type. Instead, an object of the <tt>Component</tt> <i>attaching type</i> with a <tt>completed</tt> signal has automatically been <i>attached</i> to the Rectangle object by the QML engine, and the engine emits this signal when the object is fully created, thus triggering the <tt>Component.onCompleted</tt> signal handler.</p>
<p>Attached signal handlers allow objects to be notified of particular signals that are significant to each individual object. If there was no <tt>Component.onCompleted</tt> attached signal handler, for example, then an object could not receive this notification without registering for some special signal from some special object. The <i>attached signal handler</i> mechanism enables objects to receive particular signals without these extra processes.</p>
<p>See <a href="qtqml-syntax-objectattributes.html#attached-properties-and-attached-signal-handlers">Attached properties and attached signal handlers</a> for more information on attached signal handlers.</p>
<a name="adding-signals-to-custom-qml-types"></a>
<h2>Adding Signals to Custom QML Types</h2>
<p>Signals can be added to custom QML types through the <tt>signal</tt> keyword.</p>
<p>The syntax for defining a new signal is:</p>
<p><tt>signal &lt;name&gt;[([&lt;type&gt; &lt;parameter name&gt;[, ..&#x2e;]])]</tt></p>
<p>A signal is emitted by invoking the signal as a method.</p>
<p>For example, say the code below is defined in a file named <tt>SquareButton.qml</tt>. The root Rectangle object has an <tt>activated</tt> signal. When the child MouseArea is clicked, it emits the parent's <tt>activated</tt> signal with the coordinates of the mouse click:</p>
<pre class="qml"><span class="comment">// SquareButton.qml</span>
<span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">root</span>

    signal <span class="type">activated</span>(real xPosition, real yPosition)

    <span class="name">width</span>: <span class="number">100</span>; <span class="name">height</span>: <span class="number">100</span>

    <span class="type">MouseArea</span> {
        <span class="name">anchors</span>.fill: <span class="name">parent</span>
        <span class="name">onPressed</span>: <span class="name">root</span>.<span class="name">activated</span>(<span class="name">mouse</span>.<span class="name">x</span>, <span class="name">mouse</span>.<span class="name">y</span>)
    }
}</pre>
<p>Now any objects of the <tt>SquareButton</tt> can connect to the <tt>activated</tt> signal using an <tt>onActivated</tt> signal handler:</p>
<pre class="qml"><span class="comment">// myapplication.qml</span>
<span class="type">SquareButton</span> {
    <span class="name">onActivated</span>: <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;Activated at &quot;</span> <span class="operator">+</span> <span class="name">xPosition</span> <span class="operator">+</span> <span class="string">&quot;,&quot;</span> <span class="operator">+</span> <span class="name">yPosition</span>)
}</pre>
<p>See <a href="qtqml-syntax-objectattributes.html#signal-attributes">Signal Attributes</a> for more details on writing signals for custom QML types.</p>
<a name="qml-connect-signals-to-method"></a><a name="connecting-signals-to-methods-and-signals"></a>
<h2>Connecting Signals to Methods and Signals</h2>
<p>Signal objects have a <tt>connect()</tt> method to a connect a signal either to a method or another signal. When a signal is connected to a method, the method is automatically invoked whenever the signal is emitted. This mechanism enables a signal to be received by a method instead of a signal handler.</p>
<p>Below, the <tt>messageReceived</tt> signal is connected to three methods using the <tt>connect()</tt> method:</p>
<pre class="qml"><span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">relay</span>

    signal <span class="type">messageReceived</span>(string person, string notice)

    <span class="name">Component</span>.onCompleted: {
        <span class="name">relay</span>.<span class="name">messageReceived</span>.<span class="name">connect</span>(<span class="name">sendToPost</span>)
        <span class="name">relay</span>.<span class="name">messageReceived</span>.<span class="name">connect</span>(<span class="name">sendToTelegraph</span>)
        <span class="name">relay</span>.<span class="name">messageReceived</span>.<span class="name">connect</span>(<span class="name">sendToEmail</span>)
        <span class="name">relay</span>.<span class="name">messageReceived</span>(<span class="string">&quot;Tom&quot;</span>, <span class="string">&quot;Happy Birthday&quot;</span>)
    }

    <span class="keyword">function</span> <span class="name">sendToPost</span>(<span class="name">person</span>, notice) {
        <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;Sending to post: &quot;</span> <span class="operator">+</span> <span class="name">person</span> <span class="operator">+</span> <span class="string">&quot;, &quot;</span> <span class="operator">+</span> <span class="name">notice</span>)
    }
    <span class="keyword">function</span> <span class="name">sendToTelegraph</span>(<span class="name">person</span>, notice) {
        <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;Sending to telegraph: &quot;</span> <span class="operator">+</span> <span class="name">person</span> <span class="operator">+</span> <span class="string">&quot;, &quot;</span> <span class="operator">+</span> <span class="name">notice</span>)
    }
    <span class="keyword">function</span> <span class="name">sendToEmail</span>(<span class="name">person</span>, notice) {
        <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;Sending to email: &quot;</span> <span class="operator">+</span> <span class="name">person</span> <span class="operator">+</span> <span class="string">&quot;, &quot;</span> <span class="operator">+</span> <span class="name">notice</span>)
    }
}</pre>
<p>In many cases it is sufficient to receive signals through signal handlers rather than using the connect() function. However, using the <tt>connect</tt> method allows a signal to be received by multiple methods as shown above, which would not be possible with signal handlers as they must be uniquely named. Also, the <tt>connect</tt> method is useful when connecting signals to <a href="qtqml-javascript-dynamicobjectcreation.html">dynamically created objects</a>.</p>
<p>There is a corresponding <tt>disconnect()</tt> method for removing connected signals:</p>
<pre class="qml"><span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">relay</span>
    <span class="comment">//...</span>

    <span class="keyword">function</span> <span class="name">removeTelegraphSignal</span>() {
        <span class="name">relay</span>.<span class="name">messageReceived</span>.<span class="name">disconnect</span>(<span class="name">sendToTelegraph</span>)
    }
}</pre>
<a name="signal-to-signal-connect"></a>
<h4>Signal to Signal Connect</h4>
<p>By connecting signals to other signals, the <tt>connect()</tt> method can form different signal chains.</p>
<pre class="qml"><span class="type">Rectangle</span> {
    <span class="name">id</span>: <span class="name">forwarder</span>
    <span class="name">width</span>: <span class="number">100</span>; <span class="name">height</span>: <span class="number">100</span>

    signal <span class="type">send</span>()
    <span class="name">onSend</span>: <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;Send clicked&quot;</span>)

    <span class="type">MouseArea</span> {
        <span class="name">id</span>: <span class="name">mousearea</span>
        <span class="name">anchors</span>.fill: <span class="name">parent</span>
        <span class="name">onClicked</span>: <span class="name">console</span>.<span class="name">log</span>(<span class="string">&quot;MouseArea clicked&quot;</span>)
    }

    <span class="name">Component</span>.onCompleted: {
        <span class="name">mousearea</span>.<span class="name">clicked</span>.<span class="name">connect</span>(<span class="name">send</span>)
    }
}</pre>
<p>Whenever the MouseArea <tt>clicked</tt> signal is emitted, the <tt>send</tt> signal will automatically be emitted as well.</p>
<pre class="cpp">output:
    MouseArea clicked
    Send clicked</pre>
</div>
<!-- @@@qtqml-syntax-signals.html -->
        </div>
       </div>
   </div>
   </div>
</div>
<div class="footer">
   <p>
   <acronym title="Copyright">&copy;</acronym> 2013 Digia Plc and/or its
   subsidiaries. Documentation contributions included herein are the copyrights of
   their respective owners.<br>    The documentation provided herein is licensed under the terms of the    <a href="http://www.gnu.org/licenses/fdl.html">GNU Free Documentation    License version 1.3</a> as published by the Free Software Foundation.<br>    Digia, Qt and their respective logos are trademarks of Digia Plc     in Finland and/or other countries worldwide. All other trademarks are property
   of their respective owners. </p>
</div>
</body>
</html>