座標系の原点位置指定
< 前へ [ トップへ ] 次へ >

 座標系を移動させるのに、これまでは move メソッドを使用してきました。
 しかし、追加移動である move メソッドを何度も呼び出していると、座標系がどこに在るのかを把握するのが困難になります。従って、move メソッドは決まった軌道に沿って座標系を動かしたい場合などには向きません。
 そこで、ここではもう一つの位置指定方法である、原点位置指定について解説します。


 原点位置の指定

・move メソッドは追加移動
 これまでにも既に、座標系を平行移動する方法として move メソッドを扱いましたが、move メソッドは現在の位置から追加移動させるための機能でした。これはその場その場で、逐次的に次の動き方が決定されるような運動を扱うには便利です。しかし逆に、あらかじめ定まった軌道に沿って、座標系を正確に移動させる必要がある場合などには不向きと言えるでしょう。

・原点位置指定
 このような場合は追加移動では無く、座標系の原点の位置を直接指定するほうが便利です。それには
CoordinateSystem3DEG クラスの setOrigin メソッドを用います。引数には原点位置ベクトルの中身を double 値で指定します。

setOrigin( double 原点X, double 原点Y, double 原点Z )

 それでは、例としてローカル座標系をワールド座標系に配置し、原点位置を( 1, 2, 3 )に指定してみましょう。なお、これは当然ながら move メソッドを使用した場合と全く同じ結果になります。


import rxvesapi.system3d.geometry.*;
import rxvesapi.system3d.renderer.*;
import rxvesapi.system3d.model.*;


import java.awt.Color;


public class Test{

  public static void main(String[] args){

    /*3D仮想空間*/
    Realtime3DFrame frame = new Realtime3DFrame();

    /*frameのワールド座標系を取得*/
    CoordinateSystem3DEG world = frame.getWorldSystem();

    /*frameのワールド座標系を取得*/
    ScreenSystem3DEG screen = frame.getScreenSystem();


    /*ローカル座標系を用意*/
    CoordinateSystem3DEG local
      = new CoordinateSystem3DEG();
    double angle = Math.PI*60.0/180.0; // 60度のラジアン角
    local.setOrigin( 1.0, 2.0, 3.0 ); // 原点位置指定
    world.add( local ); // ワールド座標系上に配置


    /*座標軸モデル1*/
    AxisModel3DEG axis1 = new AxisModel3DEG();
    world.add( axis1 ); /*ワールド座標系上に配置*/
    screen.request( axis1 ); // 描画リクエスト

    /*座標軸モデル2*/
    AxisModel3DEG axis2 = new AxisModel3DEG();
    local.add( axis2 ); // ローカル座標系上に配置
    screen.request( axis2 ); // 描画リクエスト

  }
}

▼実行結果




 原点位置の取得

・現在の原点位置を取得する
 move メソッドによる追加移動を繰り返し行わせている際などで、時として現在の座標原点の正確な位置情報が必要になる場合があるかもしれません。その場合は getOriginX、 getOriginY、 getOriginZ メソッドを使用します。これらのメソッドは、それぞれ座標原点のX位置、Y位置、Z位置を double 値で返します。


原点のX値を取得する場合:
getOriginX( )

原点のY値を取得する場合:
getOriginY( )

原点のZ値を取得する場合:
getOriginZ( )
< 前へ [ トップへ ] 次へ >

この階層の目次
新しいお知らせ

Vnanoの公式サイトがオープン、チュートリアルやAPI仕様書等も掲載
2019年08月07日 - オープンソースのアプリケーション組み込み用スクリプトエンジン「 Vnano 」の公式サイトを開設しました。チュートリアルや、スクリプトエンジンのAPI仕様書などが参照できます。その概要をお知らせします。

リニアングラフ3D/2Dが連番ファイルのアニメーションに標準で対応
2019年07月17日 - リニアングラフ3D/2Dでは、7月17日公開の最新版より、連番ファイルを連続的に読み込みながらアニメーション描画するプログラムを同梱し、メニューから標準で使用可能になりました。その概要をお知らせします。

Vnanoのスクリプトエンジンアーキテクチャ解説2: コンパイラ
2019年07月03日 - オープンソースで開発中のスクリプトエンジン「 Vnano 」のアーキテクチャを解説する連載の第2回です。今回は、スクリプトを中間コードへと変換する、コンパイラ部分の内部をクローズアップして解説します。

コードアーカイブ新着
[公式ガイドサンプル] ユーザーのGUI操作に対して処理を行う

「VCSSL GUI開発ガイド」内のサンプルコードです。ユーザーがGUIを操作した際に行う処理を実装します。
2019年07月28日
[公式ガイドサンプル] 各種GUIコンポーネントを画面上に配置する

「VCSSL GUI開発ガイド」内のサンプルコードです。色々な種類のGUI部品を画面上に配置します。
2019年07月28日
連番ファイルから3Dグラフをアニメーション描画するツール

フォルダ内の連番データファイルを読み込み、3Dグラフを高速で連続描画して、アニメーションさせるツールです。グラフを連番の画像ファイルに保存する事もできます。
2019年06月03日
連番ファイルから2Dグラフをアニメーション描画するツール

フォルダ内の連番データファイルを読み込み、2Dグラフを高速で連続描画して、アニメーションさせるツールです。グラフを連番の画像ファイルに保存する事もできます。
2019年05月24日
[公式ガイドサンプル] 立体モデルを生成して3D空間に配置する

「VCSSL 3DCG開発ガイド」内のサンプルコードです。立体モデルを生成し、3D空間に配置します。
2019年05月21日
公式Twitterアカウント