source: trunk/doc/src/examples/multipleinheritance.qdoc@ 330

Last change on this file since 330 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 4.5 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information (qt-info@nokia.com)
5**
6** This file is part of the documentation of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at qt-sales@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42/*!
43 \example uitools/multipleinheritance
44 \title Multiple Inheritance Example
45
46 The Multiple Inheritance Example shows how to use a form created with \QD
47 in an application by subclassing both QWidget and the user interface
48 class, which is \c{Ui::CalculatorForm}.
49
50 \image multipleinheritance-example.png
51
52 To subclass the \c calculatorform.ui file and ensure that \c qmake
53 processes it with the \c uic, we have to include \c calculatorform.ui
54 in the \c .pro file, as shown below:
55
56 \snippet examples/uitools/multipleinheritance/multipleinheritance.pro 0
57
58 When the project is compiled, the \c uic will generate a corresponding
59 \c ui_calculatorform.h.
60
61 \section1 CalculatorForm Definition
62
63 In the \c CalculatorForm definition, we include the \c ui_calculatorform.h
64 that was generated earlier.
65
66 \snippet examples/uitools/multipleinheritance/calculatorform.h 0
67
68 As mentioned earlier, the class is a subclass of both QWidget and
69 \c{Ui::CalculatorForm}.
70
71 \snippet examples/uitools/multipleinheritance/calculatorform.h 1
72
73 Two slots are defined according to the \l{Automatic Connections}
74 {automatic connection} naming convention required by \c uic. This is
75 to ensure that \l{QMetaObject}'s auto-connection facilities connect
76 all the signals and slots involved automatically.
77
78 \section1 CalculatorForm Implementation
79
80 In the constructor, we call \c setupUi() to load the user interface file.
81 Note that we do not need the \c{ui} prefix as \c CalculatorForm is a
82 subclass of the user interface class.
83
84 \snippet examples/uitools/multipleinheritance/calculatorform.cpp 0
85
86 We include two slots, \c{on_inputSpinBox1_valueChanged()} and
87 \c{on_inputSpinBox2_valueChanged()}. These slots respond to the
88 \l{QSpinBox::valueChanged()}{valueChanged()} signal that both spin boxes
89 emit. Whenever there is a change in one spin box's value, we take that
90 value and add it to whatever value the other spin box has.
91
92 \snippet examples/uitools/multipleinheritance/calculatorform.cpp 1
93 \codeline
94 \snippet examples/uitools/multipleinheritance/calculatorform.cpp 2
95
96 \section1 \c main() Function
97
98 The \c main() function instantiates QApplication and \c CalculatorForm.
99 The \c calculator object is displayed by invoking the \l{QWidget::show()}
100 {show()} function.
101
102 \snippet examples/uitools/multipleinheritance/main.cpp 0
103
104 There are various approaches to include forms into applications. The
105 Multiple Inheritance approach is just one of them. See
106 \l{Using a Designer .ui File in Your Application} for more information on
107 the other approaches available.
108*/
Note: See TracBrowser for help on using the repository browser.