[ 前へ | 目次 | 次へ ]
Japanese English

GUIコンポーネントの状態設定と取得

GUIコンポーネントは、ただ作成して配置しただけではあまり意味がありません。 ここではテキストフィールドから文字を取得したり、 グラフィックスを変更したりするなど、 配置後のGUIコンポーネントの状態設定・取得方法を解説します。

色の変更 / 取得

色の変更

GUIコンポネントの色を変更するにはsetComponentColor関数を呼び出します。 この関数の形式は以下の通りです:

- 関数の形式 -
void setComponentColor (
  int id,
  int fgRed, int fgGreen, int fgBlue, int fgAlpha,
  int bgRed, int bgGreen, init bgBlue, int bgAlpha
)

引数は以下の通りです:

  • id: 色を変更する対象のGUIコンポーネントIDを指定します。
  • fgRed, fgGreen, fgBlue, fgAlpa: 前景色のRGBA(赤/緑/青/α)成分をそれぞれ0〜255の範囲で指定します。
  • bgRed, bgGreen, bgBlue, bgAlpa: 背景色のRGBA(赤/緑/青/α)成分をそれぞれ0〜255の範囲で指定します。

ここで色成分は、赤(R)、緑(G)、青(B)成分で表現する「RGBカラー」形式に、 不透明度の「α(A)成分」を加えた「RGBAカラー」形式で指定します。各値の範囲については、以下の通りです:

  • 各色成分はそれぞれ 0 から 255 の範囲の値をとります。
  • α成分も同様ですが、 0 で完全な透明、255 で不透明を表します。

ところで、各色成分の合成は、下図のように、光の混色ルールである「加法混色」によって処理される事にご注意ください。日常で馴染みの深い、絵の具の混色ルールである「減法混色」とは結果がかなり異なります。

色成分の合成の様子
色成分の合成の様子
色成分の合成は、絵の具のような減法混色では無く、光のような加法混色により行われます。

色の取得

なお、GUIコンポーネントに設定済みの色を取得するには、getComponentColor関数を呼び出します この関数の形式は以下の通りです:

- 関数の形式 -
int[ ][ ] getComponentColor ( int id )

引数idには、色を取得する対象のGUIコンポーネントIDを指定します。

この関数は要素数が[2][4]のint型配列を戻り値に返します。その配列内には、

  • 要素[0][0]〜[0][3]にそれぞれ前景色のRGBA値
  • 要素[1][0]〜[1][3]にそれぞれ背景色のRGBA値

が格納されています。

使用可能なコンポーネント

setComponentColorおよびgetComponentCoIor関数は、以下のGUIコンポーネントなどに対して使用できます。

ウィンドウ / ボタン / テキストフィールド / テキストエリア / チェックボックス / セレクトフィールド / テキストラベル / 画像ラベル

位置の変更 / 取得

位置の変更

GUIコンポネントの位置を変更するにはsetComponentLocation関数を呼び出します。 この関数の形式は以下の通りです:

- 関数の形式 -
void setComponentLocation ( int id, int x, int y )

引数は以下の通りです:

  • id: サイズを変更する対象のGUIコンポーネントIDを指定します。
  • x, y: 変更後の左上頂点の座標を指定します。

位置の取得

GUIコンポネントの位置を取得するには、getComponentLocation関数を呼び出します。 この関数の形式は以下の通りです:

- 関数の形式 -
int[ ] getComponentLocation ( int id )

引数 id には、取得対象のコンポーネントのIDを指定します。

この関数は要素数が2のint型配列を戻り値に返します。 戻り値の配列には、要素[0]にx値、要素 [1]にy値が格納されています。

使用可能なコンポーネント

setComponentLocationおよびgetComponentLocation関数は、 以下のGUIコンポーネントなどに対して使用できます。

ウィンドウ / ボタン / テキストフィールド / テキストエリア / チェックボックス / セレクトフィールド / テキストラベル / 画像ラベル

サイズの変更 / 取得

サイズの変更

GUIコンポネントのサイズを変更するにはsetComponentSize関数を呼び出します。 この関数の形式は以下の通りです:

- 関数の形式 -
void setComponentSize ( int id, int width, int height )

引数は以下の通りです:

  • id: サイズを変更する対象のGUIコンポーネントIDを指定します。
  • width, height: それぞれ変更後の幅、高さを指定します。

サイズの取得

GUIコンポネントのサイズを取得するにはgetComponentSize関数を呼び出します。 この関数の形式は以下の通りです:

- 関数の形式 -
int[ ] getComponentSize ( int id )

引数 id には、取得対象のコンポーネントのIDを指定します。

この関数は要素数が2のint型配列を戻り値に返します。 戻り値の配列には、要素[0]に幅、要素 [1]に高さの値が格納されています。

使用可能なコンポーネント

setComponentSizeおよびgetComponentSize関数は、以下のGUIコンポーネントなどに対して使用できます。

ウィンドウ / ボタン / テキストフィールド / テキストエリア / チェックボックス / セレクトフィールド / テキストラベル / 画像ラベル

テキスト値の変更 / 取得

テキスト値の変更

GUIコンポーネントのテキストを変更するにはsetComponentText関数を呼び出します。 この関数の形式は以下の通りです:

- 関数の形式 -
void setComponentText( int id, string text )

引数は以下の通りです:

  • id: テキストを変更する対象のGUIコンポーネントIDを指定します。
  • text: 変更後に表示するテキストを指定します。

テキスト値の取得

GUIコンポネントからテキストを取得するには、 getComponentText関数を呼び出します。この関数の形式は以下の通りです:

- 関数の形式 -
string getComponentText( int id )

引数 id には、取得対象のコンポーネントのIDを指定します。

この関数は、取得したテキストをstring型の戻り値として返します。

使用可能なコンポーネント

getComponentTextおよびsetComponentText関数は、 以下のGUIコンポーネントに対して使用できます。

ボタン / テキストフィールド / テキストエリア / チェックボックス / セレクトフィールド / テキストラベル

グラフィックスデータの変更 / 取得

グラフィックスデータの変更

画像ラベルなど、グラフィックスデータを扱うGUIコンポーネントにおいて、 表示するグラフィックスデータを変更するにはsetComponentGraphics関数を呼び出します。 この関数の形式は以下の通りです:

- 関数の形式 -
void setComponentGraphics( int componentID, int graphicsID )

引数は以下の通りです:

  • グラフィックスデータを変更する対象のGUIコンポーネントIDを指定します。
  • 変更後に表示するグラフィックスデータIDを指定します。

グラフィックスデータの取得

GUIコンポーネントの表示するグラフィックリソースIDを取得するには、 getComponentGraphics関数を呼び出します。この関数の形式は以下の通りです:

- 関数の形式 -
int getComponentGraphics( int componentID )

引数componentIDには、 グラフィックスデータを取得する対象のGUIコンポーネントIDを指定します。 この関数は、表示しているグラフィックスのリソースIDを返します。

使用可能なコンポーネント

setComponentGraphicsおよびgetComponentGraphics関数は、 以下のGUIコンポーネントに対して使用できます。

画像ラベル

論理値など、その他の値の変更 / 取得

論理値の変更

チェックボックスのように、ON/OFFの論理値(二択値)を持つGUIコンポーネントの値は、 setComponentBool関数で変更できます。この関数の形式は以下の通りです:

- 関数の形式 -
void setComponentBool ( int id, bool state )

引数は以下の通りです:

  • id: 論理値を変更する対象のGUIコンポーネントIDを指定します。
  • state: 変更後の論理値を指定します。

論理値の取得

GUIコンポーネントの論理値を取得するには、 getComponentBool関数を呼び出します。この関数の形式は以下の通りです:

- 関数の形式 -
bool getComponentBool ( int id )

引数idには、論理値を取得する対象のGUIコンポーネントIDを指定します。 この関数は、論理値をbool型変数で返します。例えばチェックボックスなら、 選択されているとtrueを、されていなければfalseを返します。

使用可能なコンポーネント

setComponentBoolおよびgetComponentBool関数は、以下のGUIコンポーネントに対して使用できます。

チェックボックス

その他の種類の値

なお、このガイドでは扱いませんが、論理値(bool)以外にもint値やfloat値のパラメータを操作するような GUIコンポーネント(スライダーなど)も存在します。

そういったGUIコンポーネントについては、 ここで扱った setComponentBool / getComponentBool と同様に:

  • setComponentInt / getComponentInt
  • setComponentFloat / getComponentFloat

といった関数でパラメータの設定・取得を行えます。 詳細はGUIライブラリの仕様書をご参照ください。


この記事の著者

松井 文宏
[ RINEARN代表, 博士(理学), 応用情報技術者 ]
VCSSLやリニアングラフ3D、その他諸々を開発しています。ガイド類や記事も書いています。


スポンサーリンク



Japanese English
この階層の目次
RINEARN からのお知らせ
※ VCSSL は RINEARN が開発しています。

ExevalatorのVer.2.4をリリース—MCPをサポートし、AI用の計算ツールとしても使用可能に
2025-11-15 - 式計算ライブラリExevalatorのVer.2.4をリリースしました。今回から、AIとやり取りするためのプロトコルである「MCP」をサポートし、AI用の計算ツールとしても使用可能になりました!

Exevalatorの最新版Ver.2.3をリリース、新たにPythonで使用可能に
2025-11-04 - 式計算ライブラリExevalatorのVer.2.3をリリースしました。今回から、新たにPython製のプログラムでも使用可能になりました!AI用ツール開発需要などの背景も踏まえて、詳細をお知らせします。

Exevalatorをアップデート、エラーメッセージの日本語化が手軽に
2025-10-31 - 式計算ライブラリExevalatorのVer.2.2.2をリリースしました。今回から、エラーメッセージを手軽に日本語化できるようになりました。数件のバグ修正&微調整も作んでいます。詳細をお知らせします。

関数電卓RINPn(りんぷん)オンライン版の内部構造を解説
2025-10-22 - 先日登場した、関数電卓ソフトRINPn(りんぷん)のオンライン版の内部構造を解説します。オープンソースなので、自由に改造・流用して、自分だけのWeb電卓を作る事も可能!(かもしれない)

関数電卓RINPn(りんぷん)、どこでもすぐ使えるオンライン版が登場!
2025-10-21 - フリー関数電卓ソフトRINPn(りんぷん)に、Web上でどこでもすぐ使える「オンライン版」が新登場しました!PCだけでなく、スマホでも利用可能です。詳細をお知らせします!

VCSSLのサポートAIが登場!ただし実用品質にはChatGPT有料アカウント(Plus)での利用推奨
2025-08-19 - プログラミング言語VCSSLについての質問対応や、コーディング作業を手伝ってくれるAIさんが登場しました!使用までの流れや推奨事項を解説し、実際の回答例や生成コード例などもたくさん紹介します!

各ソフトやVCSSLの英語版ドキュメント整備がほぼ完了
2025-06-30 - RINEARNでは2年前から、AIの補助による英語版ドキュメントの大幅拡充計画を進めてきました。今回、主要ドキュメント&コンテンツの英訳がほぼ完了し、一応の目標水準に達しました。詳細をお知らせします。

VCSSLの最新版をリリース:外部プログラムとの連携機能を少し強化、他
2025-05-25 - VCSSL3.4.52をリリースしました。外部プログラム(C言語製の実行ファイル等)との連携機能を少し強化し、文字化け対策やOS判別などを可能にしました。他にも細かい機能追加があります。詳細をお知らせします。

VCSSLの最新版をリリース、Java24上での非互換な挙動を対処
2025-04-22 - VCSSL3.4.50をリリースしました。Java24環境上でのネットワークドライブ関連のファイルパス解決で、従来環境とは異なる挙動が生じていたのを解消しました。詳細をお知らせします。

リニアングラフやVCSSLの最新版をリリース、目盛りの位置や内容を自由に指定可能に!
2024-11-24 - リニアングラフ3D/2Dを更新し、自由な位置に、自由な表記内容の目盛りを描けるようになりました!併せて、Java言語やVCSSLでの、プログラム制御用APIも拡張しています。詳細をお知らせします。