2 single: RingQt アプリケーション用のオブジェクトライブラリ; はじめに
4 =================================================
5 RingQt アプリケーション用のオブジェクトライブラリ
6 =================================================
8 RingQt アプリケーション用のオブジェクトライブラリを学びます。
10 Ring には RingQt アプリケーション用のオブジェクトライブラリが付属しています。
11 ウィンドウオブジェクトへのグローバル変数の使用、
12 およびオブジェクト名でイベントをオブジェクトへ接続するのではなく、
13 オブジェクトライブラリは GUI オブジェクトの管理を行います。また、同一クラスから複数ウィンドウを手軽に作成するために、普遍的な API を実装しています。
14 さらにライブラリでは、イベントが発行されたときに実行されるメソッドを手軽に設定する方法があります。
15 同じく子またはサブウィンドウから親または呼び出し元のウィンドウを手軽に使える違和感のないインタフェースを実装しています。
17 オブジェクトライブラリは MVC デザインパターンで設計しています。
19 オブジェクトライブラリは RingQt へ統合されており RingQt から使えます。
23 pair: RingQt アプリケーション用のオブジェクトライブラリ; ライブラリの用法
28 * Open_Window(cWindowControllerClassName) 関数で新しいウィンドウを開きます。
29 * 最低でも Controller と View のクラス二本を各ウィンドウごとに作成してください。
30 * WindowsControllerParent クラスから各 Controller クラスを作成します。
31 * WindowsViewParent クラスから各 View クラスを作成します。
32 * Last_Window() 関数は最後に作成されたウィンドウのオブジェクト (Controller オブジェクト) を取得します。
33 * サブウィンドウを呼び出すときは SetParentObject() メソッドの使用、および Self オブジェクトを渡します。
34 * View クラスでは、イベントメソッドを決定するために Method(cMethodName) 関数を使用します。
35 * Method(cMethodName) 関数を実行することで Controller クラスでメソッドを決定します。
36 * 各 Controller クラスはデフォルトで CloseAction() クラスがあり、呼び出すことでウィンドウを閉じます。
37 * ウィンドウごとの Show() メソッドの呼び出しは不要です。 Open_Window() の使用時に呼び出します。
38 * View クラスでは GUI ウィンドウオブジェクトを win 属性で定義します。
39 * Open_WindowNoShow() 関数はウィンドウが表示されるのを回避します。
40 * Open_WindowAndLink() を使うとメソッドからウィンドウへ手軽にアクセスできます。
44 pair: RingQt アプリケーション用のオブジェクトライブラリ; 用例
49 この用例では、二種類のウィンドウを作成します。
51 * メインウィンドウにはボタンがあります。ユーザがボタンをクリックしたときにサブウィンドウが開かれます。
52 * ユーザは複数のサブウィンドウを開くためにボタンを何回もクリックできます。
53 * サブウィンドウごとに二つのボタンがあります。
54 * 最初のボタンはサブウィンドウにありメイン、およびサブウィンドウのタイトルのタイトルを変更します。
55 * 次のボタンはサブウィンドウにありサブウィンドウを閉じます。
62 open_window( :MainWindowController )
66 class MainWindowController from WindowsControllerParent
67 oView = new MainWindowView
69 Open_window( :SubWindowController )
70 Last_Window().SetParentObject(self)
72 class MainWindowView from WindowsViewParent
74 SetWindowTitle("Main Window")
75 btnSub = new qPushButton(win) {
77 setClickEvent( Method( :SubWindowAction ) )
82 class SubWindowController from WindowsControllerParent
83 oView = new SubWindowView
84 func SetMainWindowTitleAction
85 Parent().oView.win.SetWindowTitle("Message from the Sub Window")
86 oView.win.SetWindowTitle("Click Event Done!")
88 class SubWindowView from WindowsViewParent
90 SetWindowTitle("Sub Window")
91 btnMsg = new qPushButton(win) {
92 setText("Set Main Window Title")
93 setClickEvent( Method( :SetMainWindowTitleAction ) )
95 btnClose = new qPushButton(win) {
98 setClickEvent( Method( :CloseAction ) )
103 このスクリーンショットはサブウィンドウを三枚作成しています。
105 .. image:: objectslib1.png
106 :alt: オブジェクトライブラリの用例 - スクリーンショット 1
108 このスクリーンショットはサブウィンドウごとにボタンをクリックしています。
110 .. image:: objectslib2.png
111 :alt: オブジェクトライブラリの用例 - スクリーンショット 2
114 pair: RingQt アプリケーション用のオブジェクトライブラリ; Open_WindowAndLink() 関数
116 Open_WindowAndLink() 関数
117 =========================
119 Open_WindowAndLink() 関数はアプリケーションウィンドウとの間を接続することにより、オブジェクトとの間でメッセージ (メッセージの呼び出し) を渡せます。
121 この関数は、ほかのウィンドウの作成で動的オブジェクトを使うために、メタプログラミングによる呼び出し元クラスで動的メソッドの定義で使用します。
123 用例 : (フォームデザイナーを使用しています)
127 (1) https://github.com/ring-lang/ring/blob/master/applications/formdesigner/tests/twowindowspart5/firstwindowView.ring
129 (2) https://github.com/ring-lang/ring/blob/master/applications/formdesigner/tests/twowindowspart5/firstwindowController.ring
133 (1) https://github.com/ring-lang/ring/blob/master/applications/formdesigner/tests/twowindowspart5/secondwindowView.ring
135 (2) https://github.com/ring-lang/ring/blob/master/applications/formdesigner/tests/twowindowspart5/secondwindowController.ring
137 このコードの用例では (FirstWindowController.ring より引用)
139 Open_WindowAndLink() は SecondWindowController クラスからオブジェクトを作成します。
141 そしてメソッドを追加します : FirstWindowController クラスへ
142 SecondWindow(), IsSecondWindow() メソッドを追加
144 さらにメソッドを追加します : SecondWindowController クラスへ
145 FirstWindow(), IsFirstWindow() メソッドを追加
147 よって FirstWindowController クラスにある SendMessage() メソッドは
148 SecondWindow() メソッドでオブジェクトにアクセスするために使えます。
150 これは Last_Window(), Parent() および
151 SetParentObject() メソッドを使用するより、もっと簡単です。
155 class firstwindowController from windowsControllerParent
157 oView = new firstwindowView
159 func OpenSecondWindow
160 Open_WindowAndLink(:SecondWindowController,self)
164 SecondWindow().setMessage("Message from the first window")
167 func setMessage cMessage
168 oView.Label1.setText(cMessage)
171 pair: RingQt アプリケーション用のオブジェクトライブラリ; Open_WindowInPackages() 関数
173 Open_WindowInPackages() 関数
174 ============================
176 Open_WindowInPackages() 関数は Open_Window() と同じですが、
177 ウィンドウを開く前にインポートを行うパッケージの追加リストを決定します。
183 Open_WindowInPackages(cClassName,aPackagesList)
187 この用例はフォームデザイナーのソースコードからの引用です。
188 open_windowInPackages() 関数でウィンドウフラグのウィンドウを開きます。
190 クラス名 “WindowFlagsController” とパッケージの名前を決定します。
192 ウィンドウフラグのウィンドウでは FormDesigner および System.GUI パッケージを使用しています。
196 open_windowInPackages(:WindowFlagsController,[
202 pair: RingQt アプリケーション用のオブジェクトライブラリ; オブジェクトライブラリのソースコード
205 ====================================
207 ライブラリのソースコードは非常に単純です。ソースコードファイルを確認できます。
209 * https://github.com/ring-lang/ring/blob/master/extensions/ringqt/guilib/objectslib/objects.ring
210 * https://github.com/ring-lang/ring/blob/master/extensions/ringqt/guilib/objectslib/subwindows.ring
211 * https://github.com/ring-lang/ring/blob/master/extensions/ringqt/guilib/objectslib/objectslib.ring