File: script-calculator.html

package info (click to toggle)
qt4-x11 4%3A4.8.2%2Bdfsg-11
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 701,696 kB
  • sloc: cpp: 2,686,179; ansic: 375,485; python: 25,859; sh: 19,349; xml: 17,091; perl: 14,765; yacc: 5,383; asm: 5,038; makefile: 1,259; lex: 555; ruby: 526; objc: 347; cs: 112; pascal: 112; php: 54; sed: 34
file content (162 lines) | stat: -rw-r--r-- 16,654 bytes parent folder | download
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
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.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" />
<!-- qtscriptcalculator.qdoc -->
  <title>Qt 4.8: QtScript Calculator Example</title>
  <link rel="stylesheet" type="text/css" href="style/offline.css" />
</head>
<body>
<div class="header" id="qtdocheader">
  <div class="content"> 
    <a href="index.html" class="qtref"><span>Qt Reference Documentation</span></a>
  </div>
  <div class="breadcrumb toolblock">
    <ul>
      <li class="first"><a href="index.html">Home</a></li>
      <!--  Breadcrumbs go here -->
<li><a href="all-examples.html">Examples</a></li>
<li>QtScript Calculator Example</li>
    </ul>
  </div>
</div>
<div class="content mainContent">
<h1 class="title">QtScript Calculator Example</h1>
<span class="subtitle"></span>
<!-- $$$script/calculator-description -->
<div class="descr"> <a name="details"></a>
<p>Files:</p>
<ul>
<li><a href="script-calculator-calculator-js.html">script/calculator/calculator.js</a></li>
<li><a href="script-calculator-calculator-ui.html">script/calculator/calculator.ui</a></li>
<li><a href="script-calculator-main-cpp.html">script/calculator/main.cpp</a></li>
<li><a href="script-calculator-calculator-pro.html">script/calculator/calculator.pro</a></li>
<li><a href="script-calculator-calculator-qrc.html">script/calculator/calculator.qrc</a></li>
</ul>
<p>In the <a href="qtscript.html">QtScript</a> Calculator example, we show how to implement the functionality of a calculator widget.<p class="centerAlign"><img src="images/qtscript-calculator-example.png" alt="" /></p><p>The program logic in this example is a fairly straight port of the logic in the C++ <a href="widgets-calculator.html">Calculator Example</a>. The graphical user interface is defined in a UI file.</p>
<p>The C++ part of the example consists of four steps:</p>
<ul>
<li>Evaluate the script code that defines the <tt>Calculator</tt> class.<pre class="cpp">     <span class="type"><a href="qscriptengine.html">QScriptEngine</a></span> engine;
     <span class="type"><a href="qstring.html">QString</a></span> scriptFileName(<span class="string">&quot;:/calculator.js&quot;</span>);
     <span class="type"><a href="qfile.html">QFile</a></span> scriptFile(scriptFileName);
     scriptFile<span class="operator">.</span>open(<span class="type"><a href="qiodevice.html">QIODevice</a></span><span class="operator">::</span>ReadOnly);
     engine<span class="operator">.</span>evaluate(scriptFile<span class="operator">.</span>readAll()<span class="operator">,</span> scriptFileName);
     scriptFile<span class="operator">.</span>close();</pre>
</li>
<li>Create a widget from the UI file using <a href="quiloader.html">QUiLoader</a>.<pre class="cpp">     <span class="type"><a href="quiloader.html">QUiLoader</a></span> loader;
     <span class="type"><a href="qfile.html">QFile</a></span> uiFile(<span class="string">&quot;:/calculator.ui&quot;</span>);
     uiFile<span class="operator">.</span>open(<span class="type"><a href="qiodevice.html">QIODevice</a></span><span class="operator">::</span>ReadOnly);
     <span class="type"><a href="qwidget.html">QWidget</a></span> <span class="operator">*</span>ui <span class="operator">=</span> loader<span class="operator">.</span>load(<span class="operator">&amp;</span>uiFile);
     uiFile<span class="operator">.</span>close();</pre>
</li>
<li>Call the Calculator constructor function to create a new <tt>Calculator</tt> script object, passing the widget as argument.<pre class="cpp">     <span class="type"><a href="qscriptvalue.html">QScriptValue</a></span> ctor <span class="operator">=</span> engine<span class="operator">.</span>evaluate(<span class="string">&quot;Calculator&quot;</span>);
     <span class="type"><a href="qscriptvalue.html">QScriptValue</a></span> scriptUi <span class="operator">=</span> engine<span class="operator">.</span>newQObject(ui<span class="operator">,</span> <span class="type"><a href="qscriptengine.html">QScriptEngine</a></span><span class="operator">::</span>ScriptOwnership);
     <span class="type"><a href="qscriptvalue.html">QScriptValue</a></span> calc <span class="operator">=</span> ctor<span class="operator">.</span>construct(<span class="type">QScriptValueList</span>() <span class="operator">&lt;</span><span class="operator">&lt;</span> scriptUi);</pre>
</li>
<li>Show the widget and start the application event loop.<pre class="cpp">     ui<span class="operator">-</span><span class="operator">&gt;</span>show();
     <span class="keyword">return</span> app<span class="operator">.</span>exec();</pre>
</li>
</ul>
<p>On the script side, the <tt>Calculator</tt> constructor function initializes the instance variables of the new <tt>Calculator</tt> object, and connects the clicked() signal of the form's buttons to corresponding functions defined in the <tt>Calculator</tt> prototype object; the effect is that when a button is clicked, the proper script function will be invoked to carry out the operation.</p>
<pre class="js"> <span class="keyword">function</span> <span class="name">Calculator</span>(<span class="name">ui</span>)
 {
     this.<span class="name">ui</span> <span class="operator">=</span> <span class="name">ui</span>;

     this.<span class="name">pendingAdditiveOperator</span> <span class="operator">=</span> <span class="name">Calculator</span>.<span class="name">NO_OPERATOR</span>;
     this.<span class="name">pendingMultiplicativeOperator</span> <span class="operator">=</span> <span class="name">Calculator</span>.<span class="name">NO_OPERATOR</span>;
     this.<span class="name">sumInMemory</span> <span class="operator">=</span> <span class="number">0</span>;
     this.<span class="name">sumSoFar</span> <span class="operator">=</span> <span class="number">0</span>;
     this.<span class="name">factorSoFar</span> <span class="operator">=</span> <span class="number">0</span>;
     this.<span class="name">waitingForOperand</span> <span class="operator">=</span> <span class="number">true</span>;

     <span class="keyword">with</span> (<span class="name">ui</span>) {
         <span class="name">display</span>.<span class="name">text</span> <span class="operator">=</span> <span class="string">&quot;0&quot;</span>;

         <span class="name">zeroButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">0</span>));
         <span class="name">oneButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">1</span>));
         <span class="name">twoButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">2</span>));
         <span class="name">threeButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">3</span>));
         <span class="name">fourButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">4</span>));
         <span class="name">fiveButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">5</span>));
         <span class="name">sixButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">6</span>));
         <span class="name">sevenButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">7</span>));
         <span class="name">eightButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">8</span>));
         <span class="name">nineButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">digitClicked</span>.<span class="name">bind</span>(this, <span class="number">9</span>));

         <span class="name">pointButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;pointClicked&quot;</span>);
         <span class="name">changeSignButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;changeSignClicked&quot;</span>);

         <span class="name">backspaceButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;backspaceClicked&quot;</span>);
         <span class="name">clearButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;clear&quot;</span>);
         <span class="name">clearAllButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;clearAll&quot;</span>);

         <span class="name">clearMemoryButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;clearMemory&quot;</span>);
         <span class="name">readMemoryButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;readMemory&quot;</span>);
         <span class="name">setMemoryButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;setMemory&quot;</span>);
         <span class="name">addToMemoryButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;addToMemory&quot;</span>);

         <span class="name">divisionButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">multiplicativeOperatorClicked</span>.<span class="name">bind</span>(this, <span class="name">Calculator</span>.<span class="name">DIVISION_OPERATOR</span>));
         <span class="name">timesButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">multiplicativeOperatorClicked</span>.<span class="name">bind</span>(this, <span class="name">Calculator</span>.<span class="name">TIMES_OPERATOR</span>));
         <span class="name">minusButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">additiveOperatorClicked</span>.<span class="name">bind</span>(this, <span class="name">Calculator</span>.<span class="name">MINUS_OPERATOR</span>));
         <span class="name">plusButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">additiveOperatorClicked</span>.<span class="name">bind</span>(this, <span class="name">Calculator</span>.<span class="name">PLUS_OPERATOR</span>));

         <span class="name">squareRootButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">unaryOperatorClicked</span>.<span class="name">bind</span>(this, <span class="name">Calculator</span>.<span class="name">SQUARE_OPERATOR</span>));
         <span class="name">powerButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">unaryOperatorClicked</span>.<span class="name">bind</span>(this, <span class="name">Calculator</span>.<span class="name">POWER_OPERATOR</span>));
         <span class="name">reciprocalButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this.<span class="name">unaryOperatorClicked</span>.<span class="name">bind</span>(this, <span class="name">Calculator</span>.<span class="name">RECIPROCAL_OPERATOR</span>));
         <span class="name">equalButton</span>.<span class="name">clicked</span>.<span class="name">connect</span>(this, <span class="string">&quot;equalClicked&quot;</span>);
     }
 }</pre>
<p>A <tt>Calculator</tt> object is just a plain script object; it is not a widget. Instead, it stores a reference to the calculator form (the widget) in an instance variable, <tt>ui</tt>. The calculator script functions can access components of the form by referring to the proper children of the <tt>ui</tt> member.</p>
<pre class="js"> <span class="name">Calculator</span>.<span class="name">prototype</span>.<span class="name">digitClicked</span> <span class="operator">=</span> <span class="keyword">function</span>(<span class="name">digitValue</span>)
 {
     <span class="keyword">if</span> ((<span class="name">digitValue</span> <span class="operator">==</span> <span class="number">0</span>) <span class="operator">&amp;&amp;</span> (this.<span class="name">ui</span>.<span class="name">display</span>.<span class="name">text</span> <span class="operator">==</span> <span class="string">&quot;0&quot;</span>))
         <span class="keyword">return</span>;
     <span class="keyword">if</span> (this.<span class="name">waitingForOperand</span>) {
         this.<span class="name">ui</span>.<span class="name">display</span>.<span class="name">clear</span>();
         this.<span class="name">waitingForOperand</span> <span class="operator">=</span> <span class="number">false</span>;
     }
     this.<span class="name">ui</span>.<span class="name">display</span>.<span class="name">text</span> <span class="operator">+=</span> <span class="name">digitValue</span>;
 }</pre>
<p>The digitClicked() function is called when a digit button is clicked, with the input digit as argument.</p>
<pre class="js"> <span class="name">Calculator</span>.<span class="name">prototype</span>.<span class="name">changeSignClicked</span> <span class="operator">=</span> <span class="keyword">function</span>()
 {
     var <span class="name">text</span> = this.<span class="name">ui</span>.<span class="name">display</span>.<span class="name">text</span>;
     var <span class="name">value</span> = <span class="name">text</span> <span class="operator">-</span> <span class="number">0</span>;

     <span class="keyword">if</span> (<span class="name">value</span> <span class="operator">&gt;</span> <span class="number">0</span>) {
         <span class="name">text</span> <span class="operator">=</span> <span class="string">&quot;-&quot;</span> <span class="operator">+</span> <span class="name">text</span>;
     } else <span class="keyword">if</span> (<span class="name">value</span> <span class="operator">&lt;</span> <span class="number">0</span>) {
         <span class="name">text</span> <span class="operator">=</span> <span class="name">text</span>.<span class="name">slice</span>(<span class="number">1</span>);
     }
     this.<span class="name">ui</span>.<span class="name">display</span>.<span class="name">text</span> <span class="operator">=</span> <span class="name">text</span>;
 }</pre>
<p>The changeSign() function shows how we retrieve the text property of the calculator's display, change it appropriately, and write back the new value.</p>
</div>
<!-- @@@script/calculator -->
  <div class="ft">
    <span></span>
  </div>
</div> 
<div class="footer">
    <p>
      <acronym title="Copyright">&copy;</acronym> 2012 Nokia Corporation and/or its
      subsidiaries. Documentation contributions included herein are the copyrights of
      their respective owners.</p>
    <br />
    <p>
      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.</p>
    <p>
      Documentation sources may be obtained from <a href="http://www.qt-project.org">
      www.qt-project.org</a>.</p>
    <br />
    <p>
      Nokia, Qt and their respective logos are trademarks of Nokia Corporation 
      in Finland and/or other countries worldwide. All other trademarks are property
      of their respective owners. <a title="Privacy Policy"
      href="http://en.gitorious.org/privacy_policy/">Privacy Policy</a></p>
</div>
</body>
</html>