[ 前へ | 目次 | 次へ ]

基盤の準備

3DCGプログラミングを行うには、グラフィックスデータやレンダラー(描画エンジン)、表示画面などが最低限必要となります。ここでは、それら必須基盤の準備を一括して行います。

スポンサーリンク


グラフィックスデータの生成

まず、3DCGの描画内容を保持しておくデータ領域 (イメージ、バッファ、コンテキストなど)が必要です。 これらはVCSSLではまとめて「グラフィックスデータ」として扱います。 詳細は2DCGで述べた通りです。グラフィックスデータは、 GraphicsライブラリのnewGraphics関数で生成できます。

- 関数仕様 -

int newGraphics( )

この関数は、空白のグラフィックスデータ領域を確保し、 それに固有のグラフィックスデータID(識別番号)を割り振って返します。

3DCGレンダラー(描画エンジン)の生成

続いて、グラフィックスデータに 3DCG映像を描き込むレンダラー(描画エンジン)も生成します。 これにはnewGraphics3DRenderer関数を使用します。

- 関数仕様 -

int newGraphics3DRenderer ( int width, int height, int graphicsID )

引数のwidthとheightで描画するグラフィックスの大きさを、 graphicsIDで描画対象のグラフィックスIDを指定します。 このgraphicsIDには、newGraphics関数で確保したものを指定します。

この関数は、3DCG描画機能を持つレンダラーを生成し、 それに固有のレンダラーIDを返します。 これ以降、様々な3DCGの制御関数を扱いますが、 その引数にこのレンダラーIDを指定します。

3DCGレンダラーの各種設定と基本操作

3DCGレンダラーは生成したままの状態でも使用できますが、 必要に応じて各種設定を行いましょう。 生成後によく行う設定としては、以下のようなものが挙げられます。 加えて、毎回必ず使用する基本操作についても挙げておきます。

背景色の設定

背景色を設定するには、setGraphics3DColor関数を使用します。

- 関数仕様 -

void setGraphics3DColor (
  int rendererID,
  int red, int green, int blue, int alpha
)

最初の引数rendererIDでは、設定対象のレンダラーIDを指定します。 続く引数では、背景の色成分を指定します。色成分はそれぞれ0〜255の範囲で指定します。 色成分の形式は、RGBA形式(※)をサポートしています。

※ RGBA形式とは
RGBA形式とは、色の三原色である赤(Red)、緑(Green)、青(Blue)の色成分に、アルファ値(Alpha)を加えた形式です。アルファ値は色の透明度を表す数値で、0で完全透明になり、最大にすると不透明になります。
RGBA形式の混色図
それぞれの色成分からの色の合成は、加法混色によって行われます。これは光の重ね合わせと同じ混色方式であり、絵の具の混ぜ合わせ(減法混色)では無い事にご注意ください。例として、(赤, 緑, 青)=( 255, 255, 255 )は、黒ではなく白になります。また、( 255, 255, 0 )は黄色に、( 0, 255, 255 )は水色に、( 255, 0, 255 )はマゼンタになります。

表示倍率の設定

表示倍率を設定するには、setGraphics3DMagnification関数を使用します。

- 関数仕様 -

void setGraphics3DMagnification ( int rendererID, float magnification )

最初の引数rendererIDでは、設定対象のレンダラーIDを指定します。 続く引数magnificationでは、表示倍率を指定します。

なお、表示倍率とカメラ距離の設定はワンセットですが、 カメラ距離の設定については、後の章で扱う座標系の操作を用います(ワールド座標系を移動させる)。

3DCGの描画

レンダラーを駆動させて、グラフィックスデータに3DCG映像を描画するには、 paintGraphics3D関数を使用します。

- 関数仕様 -

void paintGraphics3D ( int rendererID )

最初の引数rendererIDでは、描画を行うレンダラーのIDを指定します。

3DCGの基本的な処理は、まず全ての立体などを配置登録し、 続いて位置や角度などを調整し、そして描画を行うといった流れとなります。 この描画のタイミングで、このpaintGraphics3D関数をコールします。

表示画面の生成

これまでに述べた事項だけで、3DCGの描画は可能です。 しかし実用上は、その描画結果を何らかの形で出力する必要があります。 最も一般的なのが、表示画面に直接グラフィックスを表示する形態でしょう。

実際に800×600サイズの表示画面を生成するには、プログラム中で以下のように記述します。

こういったGUIの制御に関する詳しい解説は、ここでは割愛します。 詳しくはVCSSL GUIライブラリのガイドをご参照ください。 とりあえず、上記のように即席の表示画面でも、これから扱う3DCGの内容は十分にこなせます。 より高度な表示画面を工夫するのでなければ、これだけで十分です。

画像ファイル出力

グラフィックスデータは、画面に表示するだけでなく、 GraphicsライブラリのexportGraphics関数を使用し、 BMP/PNG/JPEG形式の画像ファイルに出力する事も可能です。

- 関数仕様 -

void exportGraphics( int graphicsID, string fileName, string format )

最初の引数graphicsIDには出力するグラフィックスデータのIDを、 続いてfileNameにファイル名、formatにファイル形式を指定します。 ファイル形式には "BMP", "PNG", "JPEG" のどれかを指定します。

プログラム例

それでは実際にウィンドウを生成し、3DCGを画面に表示してみましょう。 ついでに、「Test.png」という名前のPNG形式画像ファイルにも出力してみます。 以下のようにプログラムを記述し、実行してみてください。

このプログラムを実行すると、ウィンドウが立ち上がり、真っ黒な画面が表示されます。 何も表示されていないように見えるのは、 単にまだ立体を配置していないからであって、紛れも無く3D仮想空間が見えています。

実行結果、黒い画面が表示される。
実行結果
真っ黒な画面が出現。



スポンサーリンク



この階層の目次
[ 前へ | 目次 | 次へ ]
RINEARN からのお知らせ
※ VCSSL は RINEARN が開発しています。

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

Exevalator 2.2 をリリース、TypeScript 対応によりWebブラウザ上で動作可能に
2024-10-22 - オープンソースの式計算ライブラリ「Exevalator(エグゼバレータ)」の2.1をリリースしました。新たに TypeScript に対応し、Webブラウザ上での式計算にも使えるようになりました。詳細を解説します。

アシスタントAI作成の舞台裏(その2、作成編)
2024-10-12 - アシスタントAIの作成方法解説の後編です。実際にChatGPTの「GPTs」機能を用いて、アシスタントAIを作成する手順や、独自の知識をもたせたり、精度を出すためのノウハウなどを解説しています。

アシスタントAI作成の舞台裏(その1、基礎知識編)
2024-10-07 - アシスタントAI作成方法解説の前編です。今回はまず、アシスタントAIを作る前に抑えておきたい、基礎知識を延々と解説しています。そもそもLLM型AIとはどんな存在か? RAGとは何か? 等々です。

ソフトの利用をサポートしてくれるアシスタントAIを提供開始!
2024-09-20 - RINEARN製ソフトの使い方の質問応答や、一部作業のお手伝いをしてくれる、アシスタントAIを提供開始しました。ChatGPTアカウントさえあれば、誰でも無料で使用できます。使い方を解説します。

Exevalator 2.1 をリリース、新たに Visual Basic に対応
2024-07-28 - オープンソースの式計算ライブラリ「Exevalator(エグゼバレータ)」の2.1をリリースしました。今回から、新たに Visual Basic(VB.NET)でも使用できるようになりました。詳細を解説します。

関数電卓 RINPn(りんぷん)、Esc キーで計算式の一発クリアが可能に
2024-07-20 - 関数電 RINPn の Ver.1.0.2 をリリースしました。今回から、キーボードの「 Esc 」キーを押すと、入力中の計算式を一発でクリアできるようになりました。詳細を解説します。

Exevalator 2.0 をリリース、互換性に注意が必要なバグ修正が 1 件
2024-07-14 - オープンソースの式計算ライブラリ「Exevalator (エグゼバレータ)」の2.0をリリースしました。今回の更新では、互換性に注意を要する 1 件のバグ修正があります。詳細を解説します。

各ソフトウェアをアップデート、リニアングラフのコマンド拡張やVCSSLの英語対応など
2024-02-05 - 各ソフトの一斉アップデートの内容をお知らせします。今回は、リニアングラフのコマンド機能を大幅拡張したのがメインです。また、VCSSLのメッセージ類の英語対応も行いました。

Vnano の Ver.1.1 で実装した反復計算高速化の内側
2024-01-17 - 前回のお知らせ記事の続編です。スクリプトエンジン Vnano の Ver.1.1 において実施した高速化を、エンジン内部の実装面から掘り下げて解説します。

新着
[公式ガイドサンプル] 各種の図形や画像を描画する

「VCSSL 2DCG開発ガイド」内のサンプルコードです。図形や画像などを描画します。
2022-12-16
角度の「度」とラジアンとを相互変換し、図示もするツール

45度などの「度」の値と、ラジアンの値とを相互に変換できるツールです。対応する角度の図示もできます。
2022-11-22
[公式ガイドサンプル] 立体モデルを回転させるアニメーション

「VCSSL 3DCG開発ガイド」内のサンプルコードです。立体モデルを、アニメーションで回転させ続けます
2022-11-18
[公式ガイドサンプル] 立体モデルを回転させる

「VCSSL 3DCG開発ガイド」内のサンプルコードです。立体モデルを、指定した角度だけ回転させます。
2022-11-17
[公式ガイドサンプル] 四則演算の計算順序や、カッコを使った順序指定

「VCSSLスタートアップガイド」内のサンプルコードです。四則演算が計算される順序や、カッコを使って順序を指定する方法を例示します。
2022-10-31