サンプル
3Dグラフィックスの描画
ここではMascotCapsuleを用いて3Dグラフィックスを描画するための構成要素と、 3Dグラフィックスを描画するための基本的な手順について解説します。
目次
1. 構成要素
MascotCapsuleを用いた3Dグラフィックスは以下の要素から構成されています。 各要素の詳しい解説は該当するチュートリアルを参照してください。
ディスプレイに描画される実体です。3Dモデルデータはさらにモデルデータ、アニメーションデータ、
プリミティブ、テクスチャから構成されており、DoJaではそれぞれ、Figure、ActionTable、Primitive、
Textureクラスとして扱います。
モデルデータはモデルの形状を保持する、モデルの骨組みのようなものです。このモデルデータに
アニメーションデータを設定したり、テクスチャを貼り付けることで3Dモデルを作成します。
アニメーションデータはモデルの動きを保持します。アニメーションデータを設定することで、
モデルが設定されたアニメーションを行うことができます。プリミティブは三角形や四角形などの
基本的な図形やポイントスプライトを描画します。テクスチャはモデルやプリミティブに貼り付ける
画像に関するデータを保持します。TextureオブジェクトはBMPファイルを読み込むことで取得します。
モデルデータやアニメーションデータはMBAC・MTRA、またはD4Dと呼ばれるファイルを読み込むことによって
使用します。MBACはモデルデータ、MTRAはアニメーションデータを保持しています。
D4DデータはMascotCapsule V4から扱うことのできるデータで、複数の構成要素をシーングラフとよばれる
木構造としてまとめて扱うことができます。D4DデータはMBAC・MTRA、またはH3Tと呼ばれるファイルから
作ることができ、DoJaでは読み込まれたD4DデータはGroupクラスとして扱います。
描画された3Dオブジェクトをディスプレイに表示します。最初3Dオブジェクトはワールド座標系上に 描画されています。それをカメラ座標系に変換し、さらにスクリーン座標系に変換したのち、 各オブジェクトを表示します。また、カメラの投影法には平行投影と透視投影の2種類があります。
ライトMascotCapsuleでは3Dオブジェクトを照らすための光源として、環境光・平行光・点光源・スポットライトの 4種類が用意されています。それぞれ位置や方向、色、輝度(明るさ)などの設定が可能です。
エフェクトMasucotCapsuleではフォグやブレンドモードなどの視覚効果を利用することができます。 フォグは霧が立ちこめたような様子を表現できるエフェクトで、遠くにある物体をぼやかして 表示することができます。ブレンドモードは3Dモデルを半透明で表示できるエフェクトです。 その他にもモデルデータにテクスチャを貼り付けたり、パースペクティブコレクション (遠近法補正)などの設定を行うことができます。
アフィン変換による移動MascotCapsuleでは3Dモデルやカメラを配置、移動させるのにアフィン変換と呼ばれる 4×4行列を用いた座標変換を行います。MascotCapsuleには、この変換を行うために アフィン変換用行列を保持するTransformクラスが用意されています。
2. 3Dグラフィックスの描画手順
ここではサンプルプログラムSample01Canvas.javaを用いて 3Dグラフィックスを描画する基本的な手順について解説します。
2.1.データの読み込み
まず、3Dモデルデータを作成するために、モデルデータ・アニメーションデータ・テクスチャを読み込みます。
Figure figure;
// アニメーションデータ
ActionTable aTable;
// テクスチャ
Texture texture;
・・・
// Sample01Canvas.java 85行
figure = ( Figure )loadData( "figure.mbac" );
//アニメーションデータの読み込み
aTable = ( ActionTable )loadData( "figure.mtra" );
//テクスチャの読み込み
texture = ( Texture )loadData( "figure.bmp" );
・・・
// Sample01Canvas.java 165行
Object3D loadData( String dataName ){
各データの読み込みには、Object3Dクラス内のcreateInstanceメソッドを使います。 読み込んだデータの型はObject3Dですので、各クラスにキャストして扱います。
2.2.モデルデータの設定
次に読み込んだFigureオブジェクトにアニメーションデータとテクスチャを設定して モデルデータを作成します。
figure.setAction( aTable, 0 );
// Figureにテクスチャを貼り付ける
figure.setTexture( texture );
Figureオブジェクトにアニメーションとテクスチャを設定するにはそれぞれ Figureクラス内のsetActionおよびsetTextureメソッドを使います。 setActionメソッドの2番目の引数はアクションデータの番号です。
2.3. カメラの設定
描画したモデルをディスプレイに表示するにはカメラが必要です。 カメラは位置・参照方向・頭頂部の向きをそれぞれ3次元ベクトルで 設定することによって行います。その後Transformクラス内のlookAtメソッドを 使うことによってカメラを設定した通りに配置します。
Transform vTrans;
// カメラの位置
Vector3D position = new Vector3D( 0, 10.f, 20.f );
// 参照方向
Vector3D lookAt = new Vector3D( 0, 0, 0 );
// カメラの頭頂部の向き
Vector3D up = new Vector3D( 0, 1.f, 0 );
・・・
// Sample01Canvas.java 70行
vTrans = new Transform();
// カメラの設定
vTrans.lookAt( position, lookAt, up );
2.4. ライトの設定
モデルを描画しても、ライトがなければ描画されたモデルは 真っ暗になってしまいます。ここではライトの設定例を示します。
Light ambLight;
・・・
// Sample01Canvas.java 79行
ambLight.setMode( Light.AMBIENT );
// ライトの明るさの設定
ambLight.setIntensity( 1.0f );
ライトは種類や方向、明るさなどを設定することができます。 サンプルでは環境光を設定しています。環境光はワールド内を 一定の明るさで照らす光源ですので、明るさだけを設定します。
2.5. Graphics3D オブジェクトの設定
今まで設定してきたモデルデータやライトをGraphics3Dオブジェクトに レンダリングします。まず、GraphicsオブジェクトをGraphics3Dクラスに キャストすることによって、Graphics3Dオブジェクトを取得します。
// Sample01Canvas.java 132行
Graphics3D g3 = ( Graphics3D )g;
次に、投影法を設定します。
g3.setPerspectiveView( 1.0f, 50.0f, 45.0f );
サンプルでは透視投影に設定しています。
最後に作成したモデルデータやライトなどの3Dオブジェクトを
Graphics3Dオブジェクトに追加(レンダリング)します。
int frame;
・・・
Primitive basePrim;
・・・
// Sample01Canvas.java 128行
figure.setTime( frame );
frame = frame < aTable.getMaxFrame( 0 ) ?
・・・
// Sample01Canvas.java 138行
g3.addLight( ambLight, null );
// Graphics3Dオブジェクトにプリミティブを追加
g3.renderObject3D( basePrim, vTrans )
// Graphics3DオブジェクトにFigureを追加
g3.renderObject3D( figure, vTrans );
Figureクラス内のsetTimeメソッドを設定するとFigureに対して現在時刻を 設定することができます。これによってFigureは設定された時刻をフレーム値として この時刻での外見状態に設定されます。サンプルではアニメーションの最大フレーム数を 200等分していますので、200回再描画されるとアニメーションが1周することになります。
2.6. ディスプレイに描画
オブジェクトをレンダリングするだけではディスプレイには何も描画されません。 ディスプレイにモデルを描画するには、Graphics3Dインターフェース内の flushBufferメソッドを使用します。
g3.flushBuffer();
flushBufferメソッドを使用することで、レンダリングバッファに蓄積された結果が すべて描画されます。このメソッドの使用後はレンダリング用バッファの中身は空になります。

Sample01.java 描画結果


