blob: 585af166a25e53a005f2bc83547f6467a8ebaef2 (
plain)
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
|
/****************************************************************************
**
** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (qt-info@nokia.com)
**
** This file is part of the documentation of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:LGPL$
** No Commercial Usage
** This file contains pre-release code and may not be distributed.
** You may use this file in accordance with the terms and conditions
** contained in the Technology Preview License Agreement accompanying
** this package.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights. These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** If you have questions regarding the use of this file, please contact
** Nokia at qt-info@nokia.com.
**
**
**
**
**
**
**
**
** $QT_END_LICENSE$
**
****************************************************************************/
/*!
\page designer-quick-start.html
\title Qt Designer クイックガイド
\QD を使うための基本的な手順は、以下の\bold{四つ}です。
\list 1
\o フォームとオブジェクトを選択する
\o フォームにオブジェクトを配置する
\o スロットにシグナルを接続する
\o フォームをプレビューする
\endlist
\image rgbController-screenshot.png
Red、Green、Blue(RGB)の値を操作するために必要なコントロールを含む
小さなウィジェット(上記スクリーンショット参照)を設計する場合を想定します。
このウィジェットは、画像処理プログラム内のどこからでも表示できるウィジェットです。
\table
\row
\i \inlineimage designer-choosing-form.png
\i \bold{フォームを選択する}
\gui{新しいフォーム} ダイアログから \gui Widget を選択して開始します。
\endtable
\table
\row
\i \inlineimage rgbController-arrangement.png
\i \bold{フォームにウィジェットを配置する}
3つのラベル(Label)、スピンボックス(Spin Box)、垂直方向のスライダ(Vertical Slider)をフォーム上へドラッグします。
ラベルの既定の文字列を変更するには、文字列をダブルクリックします。
希望するレイアウトに合わせて配置します。
\endtable
画像のようにこれらのウィジェットを配置するには、
レイアウトにウィジェットを配置する必要があります。
これを3つグループに対して行います。
まず "RED" ラベルを選択します。
次に、\key Ctrl (Mac OS X では \key Command)キーを押したまま、対応するスピンボックスとスライダを選択します。
\gui{フォーム} メニューで、\gui{格子状に並べる}を選択します。
\table
\row
\i \inlineimage rgbController-form-gridLayout.png
\i \inlineimage rgbController-selectForLayout.png
\endtable
他の2つのラベルに対しても、対応するスピンボックスとスライダごとにこの手順を繰り返します。
次の手順は、これら3つのレイアウトを組み合わせて、1つの\bold{メインレイアウト}を作成することです。
メインレイアウトとは、トップレベルウィジェット(この場合は QWidget)のレイアウトです。
トップレベルウィジェットにレイアウトを配置することは重要です。
そうでなければ、ウィンドウをサイズ変更したときにウィンドウ上のウィジェットのサイズが変更されません。
レイアウトを設定するには、フォーム上の3つのレイアウト以外の任意の場所で\gui{右クリック}し、\gui{水平に並べる}を選択します。
または、\gui{格子状に並べる}を選択することもできます。
そのどちらでも同じ配置(以下を参照)で表示されます。
\image rgbController-final-layout.png
\note メインレイアウトはフォームに表示できません。
メインレイアウトがインストールされているかどうかを確認するには、
フォームをサイズ変更してみます。
インストールされている場合は、各ウィジェットのサイズが適宜変更されます。
または、\QD の \gui{Object Inspector} で確認することもできます。
トップレベルウィジェットにレイアウトが配置されていない場合、
その横に崩れたレイアウトのアイコン \inlineimage rgbController-no-toplevel-layout.png
が表示されます。
スライダをクリックして特定の値までドラッグするときに、
スピンボックスにスライダの位置を反映させます。
この操作を行うには、スライダの \l{QAbstractSlider::}{valueChanged()}
シグナルをスピンボックスの \l{QSpinBox::}{setValue()}
スロットに接続する必要があります。
また、逆方向、すなわちスピンボックスの \l{QSpinBox::}{valueChanged()}
シグナルをスライダの \l{QAbstractSlider::value()}{setValue()} スロットに接続する必要があります。
この操作を行うには、\key{F4} キーを押すか、\gui{編集|シグナル/スロットの編集} を選択し、
\gui{シグナル/スロットの編集}モードに切り替える必要があります。
\table
\row
\i \inlineimage rgbController-signalsAndSlots.png
\i \bold{シグナルをスロットに接続する}
スライダをクリックし、カーソルをスピンボックスまでドラッグします。
以下のような \gui{シグナルスロットを設定} ダイアログがポップアップ表示されます。
適切なシグナルとスロットを選択し、\gui OK をクリックします。
\endtable
\image rgbController-configure-connection1.png
手順を(逆の順序で)繰り返し、
スピンボックスをクリックしてカーソルをスライダまでドラッグし、
スピンボックスの \l{QSpinBox::}{valueChanged()} シグナルを、
スライダの \l{QAbstractSlider::value()}{setValue()} スロットに接続します。
以下のスクリーンショットは、適切なシグナルとスロットを選択するためのガイドとして利用できます。
\image rgbController-configure-connection2.png
RGBコントローラーの "RED" コンポーネントのオブジェクトが正常に接続されたので、
"GREEN" および "BLUE" コンポーネントにも同じ手順を繰り返します。
RGB値の範囲は 0 ~ 255 であるため、
スピンボックスとスライダを特定の範囲に制限する必要があります。
\table
\row
\i \inlineimage rgbController-property-editing.png
\i \bold{ウィジェットのプロパティを設定する}
最初のスピンボックスをクリックします。
\gui{プロパティエディタ}に \l{QSpinBox} のプロパティが表示されます。
\l{QSpinBox::}{maximum} のプロパティに、"255" と入力します。
次に、最初の垂直方向のスライダをクリックすると、
\l{QAbstractSlider} のプロパティが表示されます。
\l{QAbstractSlider::}{maximum} のプロパティにも、"255" と入力します。
残りのスピンボックスとスライダに対しても、この処理を繰り返します。
\endtable
ここで、フォームをプレビューし、アプリケーションの外観を確認します。
この操作を行うには、\key{Ctrl + R} を押すか、
\gui{フォーム}メニューから\gui{プレビュー}を選択します。
スライダをドラッグすると、
スピンボックスにその値が反映されます(逆の場合も同じ)。
またサイズを変更し、子ウィジェットの管理に使用するレイアウトが
どのようにウィンドウのさまざまなサイズに対応しているか確認します。
*/
|