JOGL-クイックガイド
この章では、OpenGL、その関数、JavaでのOpenGLバインディング(GL4java、LWJGL、JOGL)、および他のOpenGLバインディングに対するJOGLの利点を紹介します。
Jのavaバインディング OペンGL(JOGL)は、JavaでのOpenGLグラフィックスAPIの最近のバインディングです。これは、OpenGL APIにアクセスできるラッパーライブラリであり、Javaでコード化された2Dおよび3Dグラフィックアプリケーションを作成するように設計されています。JOGLは、元MITの大学院生であるKenRussellとChrisKlineによって最初に開発されたオープンソースライブラリです。その後、Sun Microsystemsのゲームグループに採用され、現在はJava on Graphics Audio and Processing(JOGAMP)によって保守されています。JOGLは、Windows、Solaris、Mac OS X、Linux(x86)などのさまざまなオペレーティングシステムで機能します。
OpenGLとは何ですか?
OpenGLは、Open Graphics Libraryの略で、2Dおよび3Dグラフィックを作成するためのコマンドのコレクションです。OpenGLを使用すると、ポイント、ライン、ポリゴン、ビットマップ、画像などの非常に基本的なプリミティブを使用して、複雑な3D形状を作成できます。
ここにOpenGLのいくつかの機能があります-
複数のプラットフォームで動作します。
C ++、Pythonなどのいくつかの言語でバインディングがあります
2Dおよび3Dのベクターグラフィックスをレンダリングできます。
グラフィックプロセッシングユニット(GPU)と相互作用して、高速で高品質のレンダリングを実現します。レンダリングは、2Dまたは3Dモデルから画像を作成するプロセスです。
これは、3Dグラフィックスアプリケーションを作成するための業界標準のAPIです。たとえば、ゲーム、スクリーンセーバーなど。
プログラマーがアプリケーションを開発するためのオブジェクトと操作を指定するために使用できる約150のコマンドが含まれています。
二次曲面やNURBSカーブなど、さまざまなモデリング機能を提供するOpenGLユーティリティライブラリ(GLU)が含まれています。GLUはOpenGLの標準コンポーネントです。
OpenGLの設計は、効率、有効性、および複数の言語を使用する複数のプラットフォームでの実装に重点を置いています。OpenGL APIの単純さを維持するために、ウィンドウ処理タスクは含まれていません。
したがって、OpenGLは、ウィンドウ処理タスクを他のプログラミング言語に依存しています。
OpenGLAPIのJavaバインディング
これは、JavaプラットフォームでOpenGLを使用できるようにするJava Specification Request(JSR)API仕様です。
仕様 | 詳細 |
---|---|
JSR 231 | このJavaバインディングパッケージは、JavaSEプラットフォームをサポートします。 |
JSR 239 | このJavaバインディングパッケージは、JavaMEプラットフォームをサポートします。 |
JavaにはさまざまなOpenGLバインディングがあります。それらについては以下で説明します
GL4java
これは、Javaテクノロジ用のOpenGLとして知られています。OpenGL1.3およびほぼすべてのベンダー拡張機能へのリンクがあります。また、Abstract Window Toolkit(AWT)およびSwingsで使用することもできます。これはゲームに焦点を合わせたOpenGLバインディングであり、フルスクリーンアプリケーションを表示する単一のウィンドウです。
LWJGL
軽量Javaゲームライブラリ(LWJGL)は、OpenGL 1.5を使用し、最新バージョンのJavaで動作します。
JSE1.4のフルスクリーン機能を使用できます。AWT / Swingsのサポートは制限されています。
携帯電話や組み込み機器などの軽量機器に適しています。
JOGL
JOGLは、2Dおよび3Dレンダリングのみに焦点を当てています。サウンドと入出力を処理するインターフェースは、JOGLには含まれていません。
これには、グラフィックユーティリティライブラリ(GLU)、GLユーティリティツールキット(GLUT)、および独自のAPIであるNative Windowing Toolkit(NEWT)が含まれています。
なぜJOGLなのか?
OpenGL API(バージョン1.0、4.3、ES 1、ES 2、およびES 3)と、ほぼすべてのベンダー拡張機能へのフルアクセスを提供します。したがって、OpenGLのすべての機能がJOGLに含まれています。
JOGLは、AWT、Swing、およびStandard Widget Toolkit(SWT)と統合されています。また、独自のNative Windowing Toolkit(NEWT)も含まれています。したがって、ウィンドウ処理を完全にサポートします。
JOGLの歴史
1992-Silicon GraphicsInc。は最初のOpenGL仕様をリリースしました。
2003-Java.net Webサイトが新機能で立ち上げられ、JOGLが同じWebサイトで初めて公開されました。
2010 − 2010年以来、コンピュータソフトウェアのリベラルライセンスであるBSDライセンスの下で独立したオープンソースプロジェクトとなっています。
この章では、さまざまな統合開発環境(IDE)を使用してシステムでJOGLを使用するための環境のセットアップについて説明します。
JOGLのインストール
JOGLインストールの場合、次のシステム要件が必要です-
システム要求
最初の要件は、Java Development Kit(JDK)をマシンにインストールすることです。
要件 | 説明 |
---|---|
JDKバージョン | 1.4以上 |
記憶 | 最小要件はありません |
ディスクスペース | 最小要件はありません |
オペレーティング・システム | 最小要件はありません |
JOGLアプリケーション開発を開始するには、指定された手順に従って環境をセットアップする必要があります。
ステップ1-マシンへのJavaインストールの確認
システムのコンソールを開き、次のJavaコマンドを実行します-
プラットホーム | 仕事 | コマンド |
---|---|---|
ウィンドウズ | コマンドコンソールを開く | C:\> javaバージョン |
Linux | コマンドターミナルを開く | $ java -version |
マック | オープンターミナル | マシン:〜joseph $ java -version |
それぞれのオペレーティングシステムで出力を確認します。
プラットホーム | 出力 |
---|---|
ウィンドウズ | Java “1.6.0.21” java(TM)SEランタイム環境(ビルド1..6.0_21-b07)Java HotSpot(TM)クライアントVM(ビルド17.0-b7、混合モード、共有) |
Linux | Java “1.6.0.21” java(TM)SEランタイム環境(ビルド1..6.0_21-b07)Java HotSpot(TM)クライアントVM(ビルド17.0-b7、混合モード、共有) |
マック | Java “1.6.0.21” java(TM)SEランタイム環境(ビルド1..6.0_21-b07)Java HotSpot(TM)クライアントVM(ビルド17.0-b7、混合モード、共有) |
ステップ2– Java Development Kit(JDK)のセットアップ
マシンにJavaがインストールされていない場合は、OracleのWebサイトであるOracleからJavaSDKをインストールする必要があります。ダウンロードしたファイルからJDKのインストール手順を見つけることができます。セットアップをインストールして構成するには、所定の手順に従う必要があります。最後に、PATHおよびJAVA_HOME環境変数を設定して、java.exeファイルおよびjavac.exeファイルを含むディレクトリ(通常はそれぞれjava_install_dir / binおよびjava_install_dir)を参照します。
セットする Java-home Javaがマシンにインストールされている同じパス上のベースディレクトリの場所を指す環境変数。
プラットホーム | コマンド |
---|---|
ウィンドウズ | 環境変数JAVA_HOMEをC:\ ProgramFiles \ Java \ Jdk1.6.0_21に設定します |
Linux | JAVA_HOME = / usr / local / java-currentをエクスポートします |
マック | JAVA_HOME = / Library / Java / Homeをエクスポートします |
次のように、Javaコンパイラの場所をシステムパスに追加します-
プラットホーム | コマンド |
---|---|
ウィンドウズ | システム変数とパスの最後に文字列;%JAVA_HOME%binを追加します |
Linux | PATH = $ PATH:$ JAVA_HOME / bin /をエクスポートします |
マック | 不要 |
ステップ3–JOGLのダウンロード
JOGLの最新バージョンは、Webサイトwww.jogamp.orgからダウンロードできます。
www.jogamp.orgのホームページに移動します
[ビルド/ダウンロード]> [現在(zip)]をクリックします。
これにより、Webサイトで管理されているすべてのAPIの.jarファイルのリストが表示されます。
ライブラリの.jarファイルをダウンロードします jogamp-all-platforms.7z、OpenGLネイティブライブラリのJavaドキュメント glugen-javadoc.7z、およびJOGL jogl-javadocs.7z.
ダウンロードした.jarファイルをzip抽出ソフトウェアを使用して抽出します。
解凍したフォルダを開くと、jarフォルダやソースコードなどのファイルがあります。
ソースコードを入手する gluegen-java-src.zip そして jogl-java-src.zipIDEをサポートするため。これはオプションです。
jarフォルダー内には、複数の.jarファイルがあります。このファイルのコレクションは、GlugenとJOGLに属しています。
JOAMPは、Windows、Solaris、Linux、Androidなどのさまざまなオペレーティングシステムをサポートするネイティブライブラリを提供します。したがって、目的のプラットフォームで実行できる適切なjarファイルを取得する必要があります。たとえば、Windows 64ビットオペレーティングシステムを使用している場合は、jarフォルダーから次の.jarファイルを取得します-
- gluegenrt.jar
- jogl-all.jar
- gluegen-rt-natives-windows-amd64.jar
- jogl-all-natives-windowsamd64.jar
Eclipse4.4用のJOGLのセットアップ
JOGLを設定するための所定の手順に従ってください-
ライブラリの追加
Step 1 −Eclipseを開きます。
Step 2 −新しいプロジェクトを作成します。
Step 3−プロジェクトフォルダにlibという名前の新しいフォルダを作成します。
Step 4−ファイルgluegen-rt-natives-windows-amd64.jar、gluegenrt.jar、jogl-all-natives-windowsamd64.jarおよびjogl-all.jarlibのフォルダ。
Step 5−これらのファイルを選択し、マウスボタンを右クリックします。ショートカットメニューが表示されます。Build Path > Add to Build Path.
Step 6−すべての.jarファイルを他のプロジェクトで使用できるようにするには、メインメニューに移動します。[ウィンドウ]> [設定]を選択します。「設定」ウィンドウが表示されます。
環境設定ウィンドウの左側のドロップダウンメニューで、階層(Java→ビルドパス→ユーザーライブラリ)に従います。
「新規…」ボタンをクリックしてください。
ダイアログボックスが開きます。ライブラリ名をjogl2.1として入力します。
jarファイルを追加する glugen-rt.jar そして jogl-all.jar 「外部JARの追加...」ボタンを使用します。
名前の付いた新しいユーザーライブラリを作成します jogl2.1.
同様に、added.jarファイルのJavaドキュメントとソースコードを追加できます。
ネイティブライブラリの追加
Step 1 − jogl-all.jarノードを展開し、Javadocの場所(なし)を選択します。
Step 2−「新規…」ボタンをクリックします。JOGLJavaドキュメントの名前を入力します。
Step 3 −「外部JARの追加…」ボタンをクリックします。
Step 4 −以前にダウンロードしたJOGLJavaドキュメントの場所を選択する必要があるダイアログボックスが開きます。
ソースコードの追加
Step 1 −ノードのネイティブライブラリの場所を選択します:(なし)。
Step 2 −「新規…」ボタンをクリックします。
Step 3 −ネイティブライブラリの名前を入力し、「OK」ボタンをクリックします。
Step 4 −「外部JARの追加…」ボタンをクリックします。
Step 5−ネイティブライブラリファイル( 'gluegen-rt-natives-windows-amd64.jarおよびjoglall-natives-windows-amd64.jar')が配置されているパスを選択します。
Step 6 −ソースコードに対して同じ手順を繰り返します。
Step 7 −両方のネイティブライブラリファイルについて、上記と同じ方法でJavadoc、ソースコード、およびjarファイルの場所を設定できます。 glegen-rt.jar そして glugen-natives-windows-amd64.jar.
NetBeans4.4用のJOGLの設定
NetBeans4.4用のJOGLを設定する手順を見ていきましょう。
ライブラリの追加
Step 1 −メインメニューで、 Tools > Libraries。
Step 2 −それはあなたを Ant Library Manager。
Step 3 −の下で Classpath タブをクリックします New Library左下隅にあるボタン。小さなダイアログボックスが開きます。
Step 4 −ライブラリ名を次のように入力します JoGl2.0.
Step 5 −「OK」ボタンをクリックします。
Step 6 −「JAR /フォルダの追加…」ボタンをクリックします。
Step 7 −.jarファイルが保存されるパスを選択します jogl.all.jar そして gluegen-rt.jar にあります。
各プロジェクトにJOGLライブラリを含めるには、以下の手順に従います。
Step 1 −を右クリックします project name。ショートカットメニューが表示されます。
Step 2 −選択 Properties. 名前の付いたウィンドウが開きます Project properties。
Step 3 −選択 Libraries 左側のカテゴリから。
Step 4 −選択 Compile tab「ライブラリを追加...」ボタンをクリックします。[ライブラリの追加]ダイアログボックスが表示されます。
Step 5 −先ほど作成したJOGL2.0ライブラリを追加します。
各プロジェクトにネイティブライブラリを含める
所定の手順に従って、各プロジェクトにネイティブライブラリを含めます-
Step 1 −プロジェクトを右クリックします。
Step 2 −選択 Set Configuration > Customize…
それはあなたを Project Properties 窓。
Step 3 −右側の VM options, 「カスタマイズ」ボタンをクリックします。
Step 4 −JOGLネイティブライブラリを含むパスを参照します gluegen-rtnatives-windows-amd64.jar'' そして 'jogl-all-natives-windowsamd64.jar.
ネイティブライブラリのJavaドキュメントの追加
各プロジェクトでソースとJavadocを使用できるようにするには、Antライブラリマネージャーを再度開く必要があります。与えられた手順に従ってください-
Step 1 −オープン main menu。
Step 2 −選択 Tools > Libraries。これはあなたを導きますLibrary manager。
Step 3 −の下で JavaDoc タブで、「新しいライブラリ…」ボタンをクリックします。
Step 4 −入力 JOGLJavadoc名前。(任意の名前を入力できます。)
Step 5 −「jar /ライブラリの追加…」ボタンをクリックします。
Step 6 −解凍したパスを選択します JOGL documentation コードがあります。
ネイティブライブラリのソースコードの追加
Step 1 −下 Sourcesタブで、「新しいライブラリ…」ボタンをクリックします。入るJOGLsources 名前。
Step 2−「jar /ライブラリの追加…」ボタンをクリックします。解凍されたソースコードが配置されているパスを選択します。
JDKエディターのカスタマイズ
Step 1 −セット Classpath ファイル用 jogl.all.jar そして gluegen-rt.jar.
Step 2−ネイティブライブラリgluegen-rt-natives-windows-amd64.jarおよびjoglall-natives-windowsamd64.jarへのパスを設定するか、ダウンロードしたフォルダーからすべてのjarファイルをコピーして、に貼り付けます。jse lib フォルダ。
JOGLプログラミングを使用すると、直線、三角形、回転、照明、色などの特殊効果を含む3D形状など、さまざまなグラフィック形状を描画できます。まず、JOGLでオブジェクトを描画するには、基本的なJOGLフレームを作成する必要があります。 。以下に、基本的なフレームを構築するために必要なクラスを示します。
GLEventListenerインターフェース
プログラムでJOGLグラフィカルAPIを使用できるようにするには、実装する必要があります GLEventListenerインターフェース。あなたは見つけることができますGLEventListener のインターフェース javax.media.opengl パッケージ。
次の表に、さまざまな方法の詳細と説明を示します。 GLEventListener インターフェイス-
シニア番号 | メソッドと説明 |
---|---|
1 | Void display(GLAutoDrawable drawable) クライアントによるOpenGLレンダリングを開始するために、GLAutoDrawableインターフェイスのオブジェクトによって呼び出されます。つまり、このメソッドには、OpenGLAPIを使用してグラフィック要素を描画するために使用されるロジックが含まれています。 |
2 | Void dispose(GLAutoDrawable drawable) このメソッドは、メモリバッファやGLSLプログラムなど、各GLContextごとにすべてのOpenGLリソースの解放を実行するようにリスナーに通知します。 |
3 | Void init(GLAutoDrawble drawable) これは、OpenGLコンテキストが初期化された直後に、GLAutoDrawableインターフェイスのオブジェクトによって呼び出されます。 |
4 | Void reshape(GLAutoDrawble drawble, int x, int y, int width, int height) これは、コンポーネントのサイズが変更された後の最初の再描画中に、GLAutoDrawableインターフェイスのオブジェクトによって呼び出されます。また、ウィンドウ上のコンポーネントの位置が変更されるたびに呼び出されます。 |
のすべての方法 GLEventListener のオブジェクトが必要 GLAutoDrawable パラメータとしてのインターフェース。
GLAutoDrawableインターフェース
このインターフェイスは、イベントベースのメカニズムを提供します (GLEventListener) OpenGLレンダリングを実行するため。 GLAutoDrawable に関連付けられているプライマリレンダリングコンテキストを自動的に作成します GLAutoDrawable オブジェクトの存続期間中。
次の表に、さまざまな方法の詳細と説明を示します。 GLAutoDrawable インターフェイス-
シニア番号 | メソッドと説明 |
---|---|
1 | GL getGL() GLAutoDrawableインターフェースの現在のオブジェクトによって使用されているGLパイプラインオブジェクトを返します。 |
2 | void addGLEventListener(GLEventListener Listener) 指定されたリスナーを現在のドローアブルキューの最後に追加します。 |
3 | void addGLEventListener(int index, GLEventListener listener) このドローアブルキューの指定されたインデックスに指定されたリスナーを追加します。 |
4 | void destroy() Destroys GLContextを含む、GLAutoDrawableインターフェイスのこのオブジェクトに関連付けられているすべてのリソース。 |
Note−このパッケージには他のメソッドがあります。このインターフェースでは、テンプレートに関連するいくつかの重要なメソッドについてのみ説明します。
GLCanvasクラス
GLCanvas そして GLJpanel を実装するJOGLGUIの2つの主要なクラスです GLAutoDrawable OpenGLコマンドの描画面として利用できるインターフェイス。
GLCanvasは、OpenGLレンダリングサポートを提供する重量級のAWTコンポーネントです。これは、AWTAutoGLDrawableインターフェース。また、継承しますjava.awt.Canvasクラス。重量のある部品であるため、場合によっては、GLJCanvasスイングコンポーネントと正しく統合されない場合があります。したがって、Swingで使用する場合は注意が必要です。あなたが問題に直面するときはいつでもGLJCanvas、次に使用する必要があります GLJPanel クラス。
クラスの階層図 GLCanvas 以下のようになります-
GLEventistener インターフェースは GLCanvasクラス。の変化に対応しますGLCanvas クラスとそれらによって行われた描画要求に。
いつでも GLCanvas クラスがインスタンス化され、 init() の方法 GLEventListenerが呼び出されます。このメソッドをオーバーライドして、OpenGL状態を初期化できます。
いつでも GLCanvas 最初に描画(インスタンス化)またはサイズ変更され、 reshape() の方法 GLEventListener実行されます。これは、OpenGLビューポートと射影行列を初期化するために使用されます。コンポーネントの場所が変更されるたびに呼び出されます。
のdisplay()メソッド GLEventListener3Dシーンをレンダリングするためのコードが含まれています。display()メソッドがGLCanvas が呼び出されます。
以下に、GLCanvasクラスをインスタンス化するために必要なコンストラクターを示します。
シニア番号 | コンストラクターと説明 |
---|---|
1 | GLCanvas() デフォルトの画面デバイスで、デフォルトのOpenGL機能選択メカニズムを使用して、OpenGL機能のデフォルトセットを使用して新しいGLCanvasコンポーネントを作成します。 |
2 | GLCanvas(GLCapabilitiesImmutable) デフォルトの画面デバイスでデフォルトのOpenGL機能選択メカニズムを使用して、要求されたOpenGL機能のセットで新しいGLCanvasコンポーネントを作成します。 |
以下に、GLCanvasクラスのイベント処理に使用されるメソッドを示します。
シニア番号 | メソッドと説明 |
---|---|
1 | void addGLEventListener(GLEventListener listener) 指定されたリスナーをこのドローアブルキューの最後に追加します。 |
2 | void addGLEventListener(int indexGLEventListener listener) このドローアブルキューの指定されたインデックスに指定されたリスナーを追加します。 |
インスタンス化するには GLCanvas クラス、あなたはのオブジェクトが必要です GLCapabilitiesImmutable OpenGL機能の不変のセットを指定するインターフェース。
のオブジェクトを取得する方法の1つ CapabilitiesImmutable インターフェイスはインスタンス化することです GLCapabilitiesインターフェイスを実装するクラス。のインスタンスGLCapabilities クラスは目的を果たすために使用できます。
GLCapabilitiesクラス
このクラスは、OpenGL機能のセットを指定します。GLCapabilitiesオブジェクトをパラメーターとして受け取ります。ザ・GLCapabilities クラスは、OpenGLプロファイルなど、レンダリングコンテキストがサポートする必要のある必要な機能を記述します。
以下に、GLCapabilitiesクラスをインスタンス化するコンストラクターを示します。
シニア番号 | メソッドと説明 |
---|---|
1 | GLCapabilities(GLProfile glprofile) GLCapabilitiesオブジェクトを作成します。 |
インスタンス化するには GLCanvas クラスには、OpenGL機能の不変のセットを指定するGLCapabilitiesImmutableインターフェイスのオブジェクトが必要です。
のオブジェクトを取得する方法の1つ CapabilitiesImmutable インターフェイスはインスタンス化することです GLCapabilitiesインターフェイスを実装するクラス。のインスタンスGLCapabilities クラスは目的を果たすために使用できます。
ザ・ GLCapabilities クラスには順番に GLProfile オブジェクト。
GLProfileクラス
OpenGLAPIのいくつかのバージョンがリリースされたので; プログラムで使用されているOpenGLAPIの正確なバージョンをJava仮想マシン(JVM)に指定する必要があります。これは、GLProfile クラス。
ザ・ get() このクラスのメソッドは、異なる定義済みを受け入れます Stringパラメータとしてのオブジェクト。各Stringオブジェクトはインターフェースの名前であり、各インターフェースは特定のバージョンのOpenGLをサポートします。このクラスを静的およびシングルトンとして初期化すると、シングルトンが得られますGLProfile 使用可能な各JOGLプロファイルのオブジェクト。
以下は、GLProfileクラスのgetメソッドのプロトタイプです。
シニア番号 | 方法と説明 |
---|---|
1 | Static GLProfile get(String profile) デフォルトのデバイスを使用します。 |
これは静的メソッドであるため、クラス名を使用して呼び出す必要があり、パラメーターとして事前定義された静的文字列変数が必要です。このクラスには12個のそのような変数があり、それぞれがGLインターフェースの個別の実装を表します。
GLProfile.get(GLProfile.GL2);
get()メソッドのパラメーター
シニア番号 | 事前定義された文字列値(インターフェイス名)と説明 |
---|---|
1 | GL2 このインターフェイスには、すべてのOpenGL [1.0…3.0]メソッドと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
2 | GLES1 このインターフェイスには、すべてのOpenGL ES [1.0 ... 1.1]メソッドと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
3 | GLES2 このインターフェイスには、すべてのOpenGL ES 2.0メソッドと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
4 | GLES3 このインターフェイスには、すべてのOpenGL ES 3.0メソッドと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
5 | GL2ES1 このインターフェースには、GL2とGLES1の共通のサブセットが含まれています。 |
6 | GL2ES2 このインターフェースには、GL3、GL2、およびGLES2の共通サブセットが含まれています。 |
7 | GL2GL3 このインターフェイスには、コアGL3(OpenGL 3.1+)およびGL2の共通サブセットが含まれています。 |
8 | GL3 このインターフェイスには、すべてのOpenGL [3.1 ... 3.3]コアメソッドと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
9 | GL3bc このインターフェイスには、すべてのOpenGL [3.1 ... 3.3]互換性メソッドと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
10 | GL3ES3 このインターフェイスには、コアGL3(OpenGL 3.1+)およびGLES3(OpenGL ES 3.0)の共通サブセットが含まれています。 |
11 | GL4 このインターフェイスには、すべてのOpenGL [4.0 ... 4.3]コアメソッドと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
12 | GL4bc このインターフェイスには、すべてのOpenGL [4.0 ... 4.3]互換性プロファイルと、この仕様の時点で定義されているほとんどの拡張機能が含まれています。 |
13 | GL4ES3 コアGL4(OpenGL 4.0+)およびGLES3(OpenGL ES 3.0)の共通サブセットを含むインターフェース。 |
GLJPanelクラス
これは、OpenGLレンダリングサポートを提供する軽量のSwingコンポーネントです。Swingとの互換性のために提供されています。
GLJPanelクラス階層
以下の図は、GLJPanelクラスのクラス階層を表しています。
以下に、さまざまなコンストラクターGLJPanelクラスを示します。
シニア番号 | コンストラクターと説明 |
---|---|
1 | GJPanel() これは、OpenGL機能のデフォルトセットを使用して新しいGLJPanelコンポーネントを作成します。 |
2 | (GLCapabilitiesImmutable) 要求されたOpenGL機能のセットを使用して新しいGLJPanelコンポーネントを作成します。 |
3 | GLJPanel(GLCapabilitiesImmutable userCapsRequest, GLCapabilitiesChooser chooser) 新しいGLJPanelコンポーネントを作成します。 |
以下にGLJPanelクラスのメソッドを示します。
シニア番号 | メソッドと説明 |
---|---|
1 | void addGLEventListener(GLEventListener listener) このメソッドは、指定されたリスナーをこのドローアブルキューの最後に追加します。 |
2 | void addGLEventListener(int indexGLEventListener listener) このメソッドは、このドローアブルキューの指定されたインデックスに指定されたリスナーを追加します。 |
この章では、CanvasとAWTフレームを使用してJOGL基本フレームを描画する方法について説明します。ここでは、AWTフレームを作成し、を使用してキャンバスオブジェクトをAWTフレームに追加します。add() フレームクラスのメソッド。
以下に、JOGLのCanvasクラスとAWTのFrameクラスを組み合わせてJOGL基本フレームを作成するプログラムを作成する手順を示します。
ステップ1:クラスの作成
最初に、を実装するクラスを作成します GlEventListenerインターフェイスを作成し、パッケージjavax.media.openglをインポートします。4つのメソッドすべてを実装するdisplay(), dispose(), reshape(), init().これは基本的なフレームであるため、キャンバスクラスの作成、フレームへの追加などの基本的なタスクについて説明しました。全てのGLEVentListener インターフェイスメソッドは実装されていません。
ステップ2:キャンバスの準備
(a) の構築 GLCanvas クラスオブジェクト
final GLCanvas glcanvas = new GLCanvas( xxxxxxx );
//here capabilities obj should be passed as parameter
(b) のインスタンス化 GLCapabilities クラス
GLCapabilities capabilities = new GLCapabilities( xxxxx );
//here profile obj should be passed as parameter
(c) 生成 GLProfile オブジェクト
静的メソッドであるため、クラス名を使用して呼び出されます。このチュートリアルはJOGL2に関するものなので、GL2インターフェイスオブジェクトを生成しましょう。
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
// both, variable and method are static hence both are called using class name.
キャンバスのコードスニペットを見てみましょう。
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
(d) 今すぐ追加 GLEventListener メソッドを使用してキャンバスに addGLEventListener()。このメソッドには、GLEventListenerパラメータとしてのインターフェース。したがって、実装するクラスのオブジェクトを渡しますGLEventListener。
BasicFrame basicframe = newBasic Frame( );// class which implements
GLEventListener interface
glcanvas.addGLEventListener( basicframe );
(e) GLCanvasがjavax.media.opengl.awt.AWTGLAutoDrawableから継承したsetSize()メソッドを使用してフレームのサイズを設定します。
glcanvas.setSize( 400, 400 );
これで準備が整いました GLCanvas。
ステップ3:フレームを作成する
インスタンス化してフレームを作成します Frame JSEAWTフレームコンポーネントのクラスオブジェクト。
それにキャンバスを追加し、フレームを表示します。
//creating frame
final Frame frame = new frame( " Basic Frame" );
//adding canvas to frame
frame.add( glcanvas );
frame.setVisible( true );
ステップ4:フレームを全画面で表示する
フレームを全画面で表示するには、を使用してデフォルトの画面サイズを取得します java.awt.Toolkitクラス。次に、これらのデフォルトの画面サイズのサイズを使用して、を使用してフレームサイズを設定しますsetSize() 方法。
Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
frame.setSize(screenSize.width, screenSize.height);
AWTを使用して基本フレームを生成するプログラムを実行してみましょう-
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class BasicFrame implements GLEventListener {
@Override
public void display(GLAutoDrawable arg0) {
// method body
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
@Override
public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
// method body
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
BasicFrame b = new BasicFrame();
glcanvas.addGLEventListener(b);
glcanvas.setSize(400, 400);
//creating frame
final Frame frame = new Frame (" Basic Frame");
//adding canvas to frame
frame.add(glcanvas);
frame.setSize( 640, 480 );
frame.setVisible(true);
}
}
上記のプログラムをコンパイルして実行すると、以下の出力が生成されます。使用時に形成される基本的なフレームを示していますGLCanvas AWTのクラス-
この章では、を使用してJOGL基本フレームを描画する方法について説明します。 Canvas、および JFramejavax.swingパッケージのクラス。ここでは、JFrameをインスタンス化し、を使用してキャンバスオブジェクトをJFrameのインスタンスに追加します。add() 方法。
CanvasをAWTで使用すると、重量のある機能を備えたグラフィカルフレームが得られます。軽量のグラフィカルフレームを使用するには、次を使用する必要がありますGLCanvasスイングで。使用中GLCanvas Swingを使用すると、配置できます GLCanvas の中に JFrame ウィンドウを直接、または追加することができます JPanel。
以下は、JOGLの組み合わせでJOGL基本フレームを作成するプログラムです。 GLCanvas クラスと JFramejavax.swingパッケージのクラス。
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class BasicFrame implements GLEventListener {
@Override
public void display(GLAutoDrawable arg0) {
// method body
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
@Override
public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
// method body
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
BasicFrame b = new BasicFrame();
glcanvas.addGLEventListener(b);
glcanvas.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame (" Basic Frame");
//adding canvas to it
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
}//end of main
}//end of classimport
上記のプログラムをコンパイルして実行すると、以下の出力が生成されます。使用時に形成される基本的なフレームを示していますGLCanvas スイングウィンドウ付き。
この章では、GLJpanelクラスを使用してJOGL基本フレームを描画する方法について説明します。これは、OpenGLレンダリングサポートを提供する軽量のSwingコンポーネントです。Swingとの互換性のために提供されています。ここでは、JFrameをインスタンス化し、GLJpanelオブジェクトをJFrameのインスタンスに追加します。add() 方法。
次のプログラムは、を使用して基本的なフレームを生成します GLJPanel スイングウィンドウ付き-
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class BasicFrame implements GLEventListener {
@Override
public void display(GLAutoDrawable arg0) {
// method body
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
@Override
public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
// method body
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The GLJpanel class
GLJPanel gljpanel = new GLJPanel( glcapabilities );
BasicFrame b = new BasicFrame();
gljpanel.addGLEventListener(b);
gljpanel.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame (" Basic Frame");
//adding canvas to it
frame.getContentPane().add( gljpanel);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
}//end of main
}//end of classimport
上記のプログラムをコンパイルして実行すると、以下の出力が生成されます。使用時に形成される基本的なフレームを示していますGLJPanel スイングウィンドウ付き−
OpenGL APIは、点、頂点、線などの基本的なグラフィカル要素を描画するためのプリミティブメソッドを提供しています。これらのメソッドを使用して、三角形、多角形、円などの形状を開発できます。2Dと3Dの両方の次元で。この章では、JavaプログラムでJOGLを使用して基本的な線を引く方法について説明します。
オブジェクトの描画
ハードウェアおよびオペレーティングシステムプラットフォームに固有であり、ライブラリがCやC ++(ネイティブアプリケーション)などの他の言語で記述されているプログラムにアクセスするために、Javaは次のようなプログラミングフレームワークを使用します。 Java Native Interface (JNI)。次の図に示すように、JOGLはこのインターフェイスを内部的に使用してOpenGL関数にアクセスします。
の4つの方法すべて GLEventListenerインターフェイスには、OpenGL関数を内部的に呼び出すためのコード(Java JOGLメソッド)があります。これらのJOGLメソッドの命名も、OpenGLの命名規則に似ています。OpenGLの関数名がglBegin()、として使用されます gl.glBegin()。
いつでも gl.glBegin() java JOGLのメソッドが呼び出され、内部で glBegin()OpenGLのメソッド。これが、JOGLのインストール時にユーザーシステムにネイティブライブラリファイルをインストールする理由です。
Display()メソッド
これは、グラフィックを開発するためのコードを保持する重要な方法です。それは必要ですGLAutoDrawable パラメータとしてのインターフェイスオブジェクト。
ザ・ display()メソッドは、最初にGLインターフェイスのオブジェクトを使用してOpenGLコンテキストを取得します(GLは、すべてのOpenGLコンテキストオブジェクトを生成するメソッドを含むGLBaseインターフェイスを継承します)。このチュートリアルはJOGL2に関するものなので、GL2オブジェクトを生成しましょう。
次のコードスニペットは、GL2オブジェクトを生成する方法を示しています-
//Generating GL object
GL gl = drawable.getGL();
GL gl = drawable.getGL();
//Using this Getting the Gl2 Object
//this can be written in a single line like
final GL2 gl = drawable.getGL().getGL2();
GL2インターフェイスのオブジェクトを使用して、このインターフェイスのメンバーにアクセスできます。これにより、OpenGL [1.0 ... 3.0]関数へのアクセスが提供されます。
線を引く
GL2インターフェースにはメソッドの膨大なリストが含まれていますが、ここでは3つの主要なメソッドについて説明します。 glBegin()、 glVertex()、および glEnd()。
シニア番号 | メソッドと説明 |
---|---|
1 | glBegin() このメソッドは、線を引くプロセスを開始します。事前定義された文字列整数「GL_LINES」をパラメータとして受け取り、GLインターフェイスから継承されます。 |
2 | glVertex3f()/glVertex2f() このメソッドは頂点を作成し、座標をパラメーター3fおよび2fとして渡す必要があります。これらは、それぞれ3次元浮動小数点座標と2次元浮動小数点座標を示します。 |
3 | glEnd() 行を終了します |
以下は、JOGLを使用して基本的な線を引くプログラムです。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class Line implements GLEventListener{
@Override
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin (GL2.GL_LINES);//static field
gl.glVertex3f(0.50f,-0.50f,0);
gl.glVertex3f(-0.50f,0.50f,0);
gl.glEnd();
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
Line l = new Line();
glcanvas.addGLEventListener(l);
glcanvas.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame ("straight Line");
//adding canvas to frame
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
}//end of main
}//end of classimport javax.media.opengl.GL2;
前の章では、JOGLを使用して基本的な線を引く方法を学びました。事前定義されたフィールドを渡すことによって線を描画します。Gl_linesglBegin()メソッド。
この章では、glBegin()メソッドとGL_Linesを使用して、三角形、ひし形、家などの形状を描画する例を示します。
GL_LINES −を使用して三角形を描くプログラムを見てみましょう。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class Triangle implements GLEventListener{
@Override
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin (GL2.GL_LINES);
//drawing the base
gl.glBegin (GL2.GL_LINES);
gl.glVertex3f(-0.50f, -0.50f, 0);
gl.glVertex3f(0.50f, -0.50f, 0);
gl.glEnd();
//drawing the right edge
gl.glBegin (GL2.GL_LINES);
gl.glVertex3f(0f, 0.50f, 0);
gl.glVertex3f(-0.50f, -0.50f, 0);
gl.glEnd();
//drawing the lft edge
gl.glBegin (GL2.GL_LINES);
gl.glVertex3f(0f, 0.50f, 0);
gl.glVertex3f(0.50f, -0.50f, 0);
gl.glEnd();
gl.glFlush();
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
@Override
public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
// method body
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
Triangle l = new Triangle();
glcanvas.addGLEventListener(l);
glcanvas.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame ("Triangle");
//adding canvas to frame
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
}//end of main
}//end of classimport javax.media.opengl.GL2;
上記のプログラムをコンパイルして実行すると、以下の出力が生成されます。のGL_LINESを使用して描かれた三角形を示していますglBegin() 方法。
GL_LINES −を使用してひし形を描くプログラムを見てみましょう。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class Rhombus implements GLEventListener{
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
//edge1
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( 0.0f,0.75f,0 );
gl.glVertex3f( -0.75f,0f,0 );
gl.glEnd();
//edge2
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( -0.75f,0f,0 );
gl.glVertex3f( 0f,-0.75f, 0 );
gl.glEnd();
//edge3
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( 0f,-0.75f, 0 );
gl.glVertex3f( 0.75f,0f, 0 );
gl.glEnd();
//edge4
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( 0.75f,0f, 0 );
gl.glVertex3f( 0.0f,0.75f,0 );
gl.glEnd();
gl.glFlush();
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init(GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
// method body
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
Rhombus rhombus = new Rhombus();
glcanvas.addGLEventListener( rhombus );
glcanvas.setSize( 400, 400 );
//creating frame
final JFrame frame = new JFrame ( "Rhombus" );
//adding canvas to frame
frame.getContentPane().add( glcanvas );
frame.setSize(frame.getContentPane().getPreferredSize() );
frame.setVisible( true );
}
}
上記のプログラムをコンパイルして実行すると、次の出力が得られます。のGL_LINESを使用して生成されたひし形を示しています。glBegin() 方法。
GL_LINES −を使って家を描くプログラムを見てみましょう。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class House implements GLEventListener{
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
//drawing top
gl.glBegin ( GL2.GL_LINES );
gl.glVertex3f( -0.3f, 0.3f, 0 );
gl.glVertex3f( 0.3f,0.3f, 0 );
gl.glEnd();
//drawing bottom
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( -0.3f,-0.3f, 0 );
gl.glVertex3f( 0.3f,-0.3f, 0 );
gl.glEnd();
//drawing the right edge
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( -0.3f,0.3f, 0 );
gl.glVertex3f( -0.3f,-0.3f, 0 );
gl.glEnd();
//drawing the left edge
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( 0.3f,0.3f,0 );
gl.glVertex3f( 0.3f,-0.3f,0 );
gl.glEnd();
//building roof
//building lft dia
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( 0f,0.6f, 0 );
gl.glVertex3f( -0.3f,0.3f, 0 );
gl.glEnd();
//building rt dia
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( 0f,0.6f, 0 );
gl.glVertex3f( 0.3f,0.3f, 0 );
gl.glEnd();
//building door
//drawing top
gl.glBegin ( GL2.GL_LINES );
gl.glVertex3f( -0.05f, 0.05f, 0 );
gl.glVertex3f( 0.05f, 0.05f, 0 );
gl.glEnd();
//drawing the left edge
gl.glBegin ( GL2.GL_LINES );
gl.glVertex3f( -0.05f, 0.05f, 0 );
gl.glVertex3f( -0.05f, -0.3f, 0 );
gl.glEnd();
//drawing the right edge
gl.glBegin ( GL2.GL_LINES );
gl.glVertex3f( 0.05f, 0.05f, 0 );
gl.glVertex3f( 0.05f, -0.3f, 0 );
gl.glEnd();
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
// method body
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
House house = new House();
glcanvas.addGLEventListener( house );
glcanvas.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame( "House" );
//adding canvas to frame
frame.getContentPane().add( glcanvas );
frame.setSize(frame.getContentPane().getPreferredSize() );
frame.setVisible( true );
}//end of main
}//end of class
上記のプログラムをコンパイルして実行すると、次の出力が得られます。GL_LINES()メソッドを使用して生成された家の図を示しています。
前の章では、JOGLを使用して線、三角形、ひし形などの形状を描画する方法を学習しました。事前定義されたフィールドを渡すことによって線を描画します。Gl_linesglBegin()メソッド。
以外 GL_LINES、 glBegin()メソッドはさらに8つのパラメーターを受け入れます。それらを使用して、さまざまな形状を描くことができます。これらはGL_LINESと同じように使用されます。
次の表は、 glBegin() メソッドパラメータとその説明-
シニア番号 | パラメータと説明 |
---|---|
1 | GL_LINES 頂点の各ペアを独立した線分として作成します。 |
2 | GL_LINE_STRIP 最初の頂点から最後の頂点まで、接続された線分のグループを描画します。 |
3 | GL_LINE_LOOP 最初の頂点から最後の頂点まで、また最初の頂点まで、接続された線分のグループを描画します。 |
4 | GL_TRIANGLES 頂点の各トリプレットを独立した三角形として扱います。 |
5 | GL_TRIANGLE_STRIP 接続された三角形のグループを描画します。最初の2つの頂点の後に表示される頂点ごとに、1つの三角形が定義されます。 |
6 | GL_TRIANGLE_FAN 接続された三角形のグループを描画します。最初の2つの頂点の後に表示される頂点ごとに、1つの三角形が定義されます。 |
7 | GL_QUADS 4つの頂点の各グループを独立した四辺形として扱います。 |
8 | GL_QUAD_STRIP 四辺形の接続されたグループを描画します。最初のペアの後に表示される頂点のペアごとに、1つの四角形が定義されます。 |
9 | GL_POLYGON 単一の凸多角形を描画します。頂点1、…、nはこのポリゴンを定義します。 |
を使用していくつかの例を見てみましょう glBegin() パラメーター。
ラインストリップを描くプログラム
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class LineStrip implements GLEventListener{
@Override
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin (GL2.GL_LINE_STRIP);
gl.glVertex3f(-0.50f,-0.75f, 0);
gl.glVertex3f(0.7f,0.5f, 0);
gl.glVertex3f(0.70f,-0.70f, 0);
gl.glVertex3f(0f,0.5f, 0);
gl.glEnd();
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
@Override
public void reshape(GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4) {
// method body
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
LineStrip r = new LineStrip();
glcanvas.addGLEventListener(r);
glcanvas.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame ("LineStrip");
//adding canvas to frame
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
}//end of main
}//end of classimport javax.media.opengl.GL2;
上記のコードをコンパイルして実行すると、次の出力が生成されます-
ラインループを描画するためのdisplay()メソッドのコードスニペット
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin (GL2.GL_LINE_LOOP);
gl.glVertex3f( -0.50f, -0.75f, 0);
gl.glVertex3f(0.7f, .5f, 0);
gl.glVertex3f(0.70f, -0.70f, 0);
gl.glVertex3f(0f, 0.5f, 0);
gl.glEnd();
}
交換する場合 display() 上記のコードを使用した基本的なテンプレートプログラムのいずれかのメソッドをコンパイルして実行すると、次の出力が生成されます。
GL_TRIANGLESを使用して三角形を描画するdisplay()メソッドのコードスニペット
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin(GL2.GL_TRIANGLES); // Drawing Using Triangles
gl.glVertex3f(0.5f,0.7f,0.0f); // Top
gl.glVertex3f(-0.2f,-0.50f,0.0f); // Bottom Left
gl.glVertex3f(0.5f,-0.5f,0.0f); // Bottom Right
gl.glEnd();
}
交換する場合 display() 上記のコードを使用した基本的なテンプレートプログラムのいずれかのメソッドをコンパイルして実行すると、次の出力が生成されます。
三角ストリップを描画するためのdisplay()メソッドのコードスニペット
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin (GL2.GL_TRIANGLE_STRIP);
gl.glVertex3f(0f,0.5f,0);
gl.glVertex3f(-0.50f,-0.75f,0);
gl.glVertex3f(0.28f,0.06f,0);
gl.glVertex3f(0.7f,0.5f,0);
gl.glVertex3f(0.7f,-0.7f,0);
gl.glEnd();
}
交換する場合 display() 上記のコードを使用した基本的なテンプレートプログラムのいずれかのメソッドをコンパイルして実行すると、次の出力が生成されます-
四辺形を描画するdisplay()メソッドのコードスニペット
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin(GL2.GL_QUADS);
gl.glVertex3f( 0.0f,0.75f,0);
gl.glVertex3f(-0.75f,0f,0);
gl.glVertex3f(0f,-0.75f,0);
gl.glVertex3f(0.75f,0f,0);
gl.glEnd();
}
交換する場合 display() 上記のコードを使用した基本的なテンプレートプログラムのいずれかのメソッドをコンパイルして実行すると、次の出力が生成されます。
ポリゴンを描画するためのdisplay()メソッドのコードスニペット
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin(GL2.GL_POLYGON);
gl.glVertex3f(0f,0.5f,0f);
gl.glVertex3f(-0.5f,0.2f,0f);
gl.glVertex3f(-0.5f,-0.2f,0f);
gl.glVertex3f(0f,-0.5f,0f);
gl.glVertex3f(0f,0.5f,0f);
gl.glVertex3f(0.5f,0.2f,0f);
gl.glVertex3f(0.5f,-0.2f,0f);
gl.glVertex3f(0f,-0.5f,0f);
gl.glEnd();
}
交換する場合 display() 上記のコードを使用した基本的なテンプレートプログラムのいずれかのメソッドをコンパイルして実行すると、次の出力が生成されます。
OpenGLは、オブジェクトへの色の適用、スケーリング、ライティング、オブジェクトの回転など、より多くの機能を提供します。この章では、JOGLを使用したオブジェクトの変換の一部について説明します。
ウィンドウ上のオブジェクトの移動
前の章では、線を描画したり、単純な線を使用してさまざまな形状を描画したりするプログラムについて説明しました。この方法で作成された形状は、ウィンドウ内の任意の場所に表示できます。それは方法を使用して行われますglTranslatef (float x, float y, float z)。
このメソッドはに属します GLMatrixFunc にあるインターフェース javax.media.opengl.fixedfunc パッケージ。
GLMatrixFuncインターフェース
interface − GLMatrixFunc
package − javax.media.opengl.fixedfunc
次の表に、このインターフェイスのいくつかの重要なメソッドを示します。
シニア番号 | メソッドと説明 |
---|---|
1 | void glRotatef(float angle, float x, float y, float z) 現在のマトリックスを回転させます。 |
2 | void glScalef(float x, float y, float z) 現在の行列をスケーリングするために使用されます。 |
3 | void glTranslatef(float x, float y,float z) 現在の行列を変換するために使用されます。 |
4 | void glLoadIdentity() 現在の行列に単位行列をロードします。 |
ザ・ glTranslate() メソッドは、座標系の原点をパラメーター(x、y、z)で指定された点に移動し、 glTranslate() としての方法
引数。変換されていない座標系を保存および復元するには、glPushMatrix() そして glPopMatrix() メソッドが使用されます。
gl.glTranslatef(0f, 0f, -2.5f);
いつでも glTranslate()を使用すると、画面上のコンポーネントの位置が変更されます。従ってreshape() の方法 GLEventListener インターフェイスをオーバーライドし、OpenGLビューポートと射影行列を初期化する必要があります。
次のコードは、ビューポートと射影行列を初期化するためのテンプレートを示しています-
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
// TODO Auto-generated method stub
final GL2 gl = drawable.getGL().getGL2();
// get the OpenGL 2 graphics object
if(height <=0) height = 1;
//preventing devided by 0 exception height = 1;
final float h = (float) width / (float) height;
// display area to cover the entire window
gl.glViewport(0, 0, width, height);
//transforming projection matrix
gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(45.0f, h, 1.0, 20.0);
//transforming model view gl.glLoadIdentity();
gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
}
この章では、JOGLを使用してオブジェクトに色を適用する方法について説明します。オブジェクトに色を適用するには、メソッドを使用しますglColor() の GL2。以下に、glColorメソッドを使用するための構文を示します。
構文
gl.glColorXY(1f,0f,0f);
どこ、
Xは、使用される色の数を示し、3(赤、緑、青)または4(赤、緑、青、アルファ)です。さまざまな色の組み合わせを取得するために、これらの色の値がパラメーターとして渡されます。色パラメータの順序は、この順序で維持する必要があります。
Example
色の値を(1、0、0)として渡すと、赤い色になります。同様に、(1、1、0)は黄色になります。
Yは、byte(b)、double(d)、float(f)、int(i)、short(s)、ubyte(ub)、uint(ui)、ushort(us)などのパラメーターを受け入れるデータ型を示します。 。
gl.glColor3f(1f,0f,0f); //gives us red
gl.glColor3f(0f,1f,0f); //gives us green
gl.glColor3f(0f,0f,1f); //gives us blue
三角形の場合、頂点ごとに異なる色を適用できます。
三角形に色を適用するプログラムを見てみましょう-
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class TriangleColor implements GLEventListener {
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glBegin( GL2.GL_TRIANGLES );
// Drawing Using Triangles
gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
gl.glVertex3f( 0.5f,0.7f,0.0f ); // Top
gl.glColor3f( 0.0f,1.0f,0.0f ); // green
gl.glVertex3f( -0.2f,-0.50f,0.0f ); // Bottom Left
gl.glColor3f( 0.0f,0.0f,1.0f ); // blue
gl.glVertex3f( 0.5f,-0.5f,0.0f ); // Bottom Right
gl.glEnd();
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
// method body
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
TriangleColor triangle = new TriangleColor();
glcanvas.addGLEventListener( triangle );
glcanvas.setSize( 400, 400 );
//creating frame
final JFrame frame = new JFrame (" Colored Triangle");
//adding canvas to it
frame.getContentPane().add( glcanvas );
frame.setSize( frame.getContentPane().getPreferredSize());
frame.setVisible( true );
} //end of main
} //end of class
上記のプログラムをコンパイルして実行すると、次の色付きの三角形が表示されます-
ポリゴンに色を適用する
プログラムを実行して、ポリゴンに色を適用してみましょう-
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class PolygonColor implements GLEventListener {
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glColor3f( 1f,0f,0f ); //applying red
gl.glBegin( GL2.GL_POLYGON );
gl.glVertex3f( 0f,0.5f,0f );
gl.glVertex3f( -0.5f,0.2f,0f );
gl.glVertex3f( -0.5f,-0.2f,0f );
gl.glVertex3f( 0f,-0.5f,0f );
gl.glVertex3f( 0f,0.5f,0f );
gl.glVertex3f( 0.5f,0.2f,0f );
gl.glVertex3f( 0.5f,-0.2f,0f );
gl.glVertex3f( 0f,-0.5f,0f );
gl.glEnd();
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
// method body
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
PolygonColor polygon = new PolygonColor();
glcanvas.addGLEventListener( polygon );
glcanvas.setSize( 400, 400 );
//creating frame
final JFrame frame = new JFrame ( "Colored Polygon" );
//adding canvas to frame
frame.getContentPane().add( glcanvas );
frame.setSize(frame.getContentPane().getPreferredSize() );
frame.setVisible( true );
} //end of main
} //end of class
上記のプログラムをコンパイルして実行すると、次の色のポリゴンが表示されます-
この章では、オブジェクトをスケーリングする方法、つまりJOGLを使用してオブジェクトのサイズを拡大または縮小する方法について説明します。
オブジェクトのスケーリングは、 glScalef(float x, float y, float z) の方法 GLMatrixFuncインターフェース。このメソッドは、3つの浮動小数点パラメーターを受け入れます。これを使用して、x、y、およびz軸に沿ってそれぞれスケール係数を指定します。
たとえば、次のプログラムでは、三角形は50%に縮小されます。ここでは、値50がすべての軸に沿ってパラメータとして渡されます。
三角形をスケーリングするプログラムを実行してみましょう-
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
public class Scaling implements GLEventListener {
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glScalef( 0.50f,0.25f,0.50f );
gl.glBegin( GL2.GL_TRIANGLES );
// Drawing Using Triangles
gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
gl.glVertex3f( 0.5f,0.7f,0.0f ); // Top
gl.glColor3f( 0.0f,1.0f,0.0f ); // blue
gl.glVertex3f( -0.2f,-0.50f,0.0f ); // Bottom Left
gl.glColor3f( 0.0f,0.0f,1.0f ); // green
gl.glVertex3f( 0.5f,-0.5f,0.0f ); // Bottom Right
gl.glEnd();
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
// method body
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
Scaling scaling = new Scaling();
glcanvas.addGLEventListener( scaling );
glcanvas.setSize( 400, 400 );
//creating frame
final JFrame frame = new JFrame (" Dimnished Triangle (Scaling )");
//adding canvas to it
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
} //end of main
} //end of classimport javax.media.opengl.GL2;
上記のプログラムをコンパイルして実行すると、次の出力が得られます。ここでは、TriangleColor.javaによって生成された元の三角形と比較して減少した三角形を観察できます。
この章では、JOGLを使用してオブジェクトを回転させる方法について説明しました。オブジェクトの回転は、を使用して3つの軸のいずれかに沿って実行できます。glRotatef(float angle, float x, float y, float z) の方法 GLMatrixFuncインターフェース。このメソッドのパラメーターとして、回転角とx、y、z軸を渡す必要があります。
次の手順は、オブジェクトを正常に回転させるためのガイドです。
最初に使用してカラーバッファと深度バッファをクリアします gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT)方法。このメソッドは、オブジェクトの以前の状態を消去し、ビューを明確にします。
を使用して射影行列をリセットします glLoadIdentity() 方法。
アニメータークラスをインスタンス化し、を使用してアニメーターを開始します。 start() 方法。
FPSAnimatorクラス
以下に、FPSAnimatorクラスのさまざまなコンストラクターを示します。
シニア番号 | メソッドと説明 |
---|---|
1 | FPSAnimator(GLAutoDrawable drawable, int fps) これは、指定された1秒あたりのターゲットフレーム数とアニメーション化する初期ドローアブルを使用してFPSAnimatorを作成します。 |
2 | FPSAnimator(GLAutoDrawable drawable, int fps, boolean cheduleAtFixedRate) これは、指定された1秒あたりのターゲットフレーム値、アニメーション化する初期ドローアブル、および固定レートスケジューリングを使用するかどうかを示すフラグを使用してFPSAnimatorを作成します。 |
3 | FPSAnimator(int fps) 指定された1秒あたりのターゲットフレーム数でFPSAnimatorを作成します。 |
4 | これは、指定された1秒あたりのターゲットフレーム値と、固定レートスケジューリングを使用するかどうかを示すフラグを使用してFPSAnimatorを作成します。 |
これは、指定された1秒あたりのターゲットフレーム値と、固定レートスケジューリングを使用するかどうかを示すフラグを使用してFPSAnimatorを作成します。
start() そして stop()このクラスの2つの重要なメソッドです。次のプログラムは、FPSAnimatorクラスを使用して三角形を回転させる方法を示しています-
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
import com.jogamp.opengl.util.FPSAnimator;
public class TriangleRotation implements GLEventListener {
private float rtri; //for angle of rotation
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glClear (GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT );
// Clear The Screen And The Depth Buffer
gl.glLoadIdentity(); // Reset The View
//triangle rotation
gl.glRotatef( rtri, 0.0f, 1.0f, 0.0f );
// Drawing Using Triangles
gl.glBegin( GL2.GL_TRIANGLES );
gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
gl.glVertex3f( 0.5f,0.7f,0.0f ); // Top
gl.glColor3f( 0.0f,1.0f,0.0f ); // blue
gl.glVertex3f( -0.2f,-0.50f,0.0f ); // Bottom Left
gl.glColor3f( 0.0f,0.0f,1.0f ); // green
gl.glVertex3f( 0.5f,-0.5f,0.0f ); // Bottom Right
gl.glEnd();
gl.glFlush();
rtri +=0.2f; //assigning the angle
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) {
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities( profile );
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities);
TriangleRotation triangle = new TriangleRotation();
glcanvas.addGLEventListener( triangle );
glcanvas.setSize( 400, 400 );
// creating frame
final JFrame frame = new JFrame ("Rotating Triangle");
// adding canvas to it
frame.getContentPane().add( glcanvas );
frame.setSize(frame.getContentPane() .getPreferredSize());
frame.setVisible( true );
//Instantiating and Initiating Animator
final FPSAnimator animator = new FPSAnimator(glcanvas, 300,true);
animator.start();
}
} //end of main
} //end of class
上記のプログラムをコンパイルして実行すると、次の出力が生成されます。ここでは、x軸を中心に色付きの三角形を回転させるさまざまなスナップショットを観察できます。
この章では、JOGLを使用してオブジェクトに照明効果を適用する方法について説明します。
照明を設定するには、最初にを使用して照明を有効にします glEnable()方法。次に、を使用してオブジェクトに照明を適用しますglLightfv(int light, int pname, float[] params, int params_offset) の方法 GLLightingFuncインターフェース。このメソッドは4つのパラメーターを取ります。
次の表に、のパラメータを示します。 gllightfv() 方法。
シニア番号 | パラメータ名と説明 |
---|---|
1 | Light ライトを指定します。ライトの数は実装によって異なりますが、少なくとも8つのライトがサポートされています。10個の値を受け入れます。これらのパラメーターについては、以下に示す「光源パラメーター」という名前の別の表で説明します。 |
2 | Pname 単一値の光源パラメータを指定します。光源の場合、以下で説明するように10個のパラメータがあります。 |
3 | Params 光源ライトのパラメータpnameに設定されている1つまたは複数の値へのポインタを指定します。 |
4 | Light source parameter 以下に示す任意の光源パラメータを使用できます。 |
光源パラメータ
シニア番号 | パラメータと説明 |
---|---|
1 | GL_AMBIENT これには、光の周囲の強度を指定するパラメータが含まれています。 |
2 | GL_DIFFUSE これには、光の拡散強度を指定するパラメータが含まれています。 |
3 | GL_SPECULAR これには、光の鏡面反射強度を指定するパラメータが含まれています。 |
4 | GL_POSITION これには、均一なオブジェクト座標でのライトの位置を指定する4つの整数値または浮動小数点値が含まれています。 |
5 | GL_SPOT_DIRECTION これには、均一なオブジェクト座標での光の方向を指定するパラメータが含まれています。 |
6 | GL_SPOT_EXPONENT そのパラメータは、光の強度分布を指定します。 |
7 | GL_SPOT_CUTOFF この単一のパラメータは、ライトの最大拡散角度を指定します。 |
8 | GL_CONSTANT_ATTENUATION or GL_LINEAR_ATTENUATION or GL_QUADRATIC_ATTENUATION 単一の値で表されるこれらの減衰係数のいずれかを使用できます。 |
照明はを使用して有効または無効になります glEnable() そして glDisable ()引数を持つメソッド GL_LIGHTING。
次のテンプレートは照明用に提供されています-
gl.glEnable(GL2.GL_LIGHTING);
gl.glEnable(GL2.GL_LIGHT0);
gl.glEnable(GL2.GL_NORMALIZE);
float[] ambientLight = { 0.1f, 0.f, 0.f,0f }; // weak RED ambient
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambientLight, 0);
float[] diffuseLight = { 1f,2f,1f,0f }; // multicolor diffuse
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuseLight, 0);
回転するポリゴンに光を当てる
回転するポリゴンに光を適用するには、所定の手順に従います。
glRotate()メソッドを使用してポリゴンを回転します
gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
// Clear The Screen And The Depth Buffer
gl.glLoadIdentity();
// Reset The View
gl.glRotatef(rpoly, 0.0f, 1.0f, 0.0f);
回転するポリゴンに光を当てるプログラムを見てみましょう-
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.swing.JFrame;
import com.jogamp.opengl.util.FPSAnimator;
public class PolygonLighting implements GLEventListener {
private float rpoly;
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glColor3f(1f,0f,0f); //applying red
// Clear The Screen And The Depth Buffer
gl.glClear( GL2.GL_COLOR_BUFFER_BIT |
GL2.GL_DEPTH_BUFFER_BIT );
gl.glLoadIdentity(); // Reset The View
gl.glRotatef( rpoly, 0.0f, 1.0f, 0.0f );
gl.glBegin( GL2.GL_POLYGON );
gl.glVertex3f( 0f,0.5f,0f );
gl.glVertex3f( -0.5f,0.2f,0f );
gl.glVertex3f( -0.5f,-0.2f,0f );
gl.glVertex3f( 0f,-0.5f,0f );
gl.glVertex3f( 0f,0.5f,0f );
gl.glVertex3f( 0.5f,0.2f,0f );
gl.glVertex3f( 0.5f,-0.2f,0f );
gl.glVertex3f( 0f,-0.5f,0f );
gl.glEnd();
gl.glFlush();
rpoly += 0.2f; //assigning the angle
gl.glEnable( GL2.GL_LIGHTING );
gl.glEnable( GL2.GL_LIGHT0 );
gl.glEnable( GL2.GL_NORMALIZE );
// weak RED ambient
float[] ambientLight = { 0.1f, 0.f, 0.f,0f };
gl.glLightfv(GL2.GL_LIGHT0, GL2.GL_AMBIENT, ambient-Light, 0);
// multicolor diffuse
float[] diffuseLight = { 1f,2f,1f,0f };
gl.glLightfv( GL2.GL_LIGHT0, GL2.GL_DIFFUSE, diffuse-Light, 0 );
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable arg0, int arg1, int arg2, int arg3, int arg4 ) {
// method body
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities( profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
PolygonLighting polygonlighting = new PolygonLighting();
glcanvas.addGLEventListener( polygonlighting );
glcanvas.setSize( 400, 400 );
//creating frame
final JFrame frame = new JFrame (" Polygon lighting ");
//adding canvas to it
frame.getContentPane().add( glcanvas );
frame.setSize( frame.getContentPane().getPreferredSize());
frame.setVisible( true );
//Instantiating and Initiating Animator
final FPSAnimator animator = new FPSAnimator(glcanvas, 300,true );
animator.start();
} //end of main
} //end of class
上記のプログラムをコンパイルして実行すると、次の出力が生成されます。ここでは、回転するポリゴンのさまざまなスナップショットを照明で観察できます。
前の章では、2Dオブジェクトを作成し、それにエフェクトを適用し、オブジェクトを変換する方法を見てきました。この章では、3次元といくつかの形状で線を引く方法を説明します。
z軸で単純な線を描き、2D線と3D線の違いを見てみましょう。最初に単純な線を描き、次に2番目の線を3単位ウィンドウに描きます。
プログラムを実行して3D線を描画しましょう-
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;
import javax.swing.JFrame;
public class Line3d implements GLEventListener {
private GLU glu = new GLU();
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glTranslatef( 0f, 0f, -2.5f );
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( -0.75f,0f,0 );
gl.glVertex3f( 0f,-0.75f, 0 );
gl.glEnd();
//3d line
gl.glBegin( GL2.GL_LINES );
gl.glVertex3f( -0.75f,0f,3f );// 3 units into the window
gl.glVertex3f( 0f,-0.75f,3f );
gl.glEnd();
}
@Override
public void dispose( GLAutoDrawable arg0 ) {
//method body
}
@Override
public void init( GLAutoDrawable arg0 ) {
// method body
}
@Override
public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) {
GL2 gl = drawable.getGL().getGL2();
if( height <= 0 )
height = 1;
final float h = ( float ) width / ( float ) height;
gl.glViewport( 0, 0, width, height );
gl.glMatrixMode( GL2.GL_PROJECTION );
gl.glLoadIdentity();
glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
gl.glMatrixMode( GL2.GL_MODELVIEW );
gl.glLoadIdentity();
}
public static void main( String[] args ) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
Line3d line3d = new Line3d();
glcanvas.addGLEventListener( line3d );
glcanvas.setSize( 400, 400 );
//creating frame
final JFrame frame = new JFrame (" 3d line");
//adding canvas to it
frame.getContentPane().add( glcanvas );
frame.setSize(frame.getContentPane().getPreferredSize() );
frame.setVisible( true );
}//end of main
}//end of class
上記のプログラムをコンパイルして実行すると、次の出力が生成されます-
3D形状は、ゼロ以外の値をz象限に与えることで描画できます。 glVertex3f()上記のビューを生成するメソッド。残りの線を結合すると、3Dエッジになります。
同じように、3次元のエッジを作成しましょう。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;
import javax.swing.JFrame;
public class Edge1 implements GLEventListener {
private GLU glu = new GLU();
@Override
public void display(GLAutoDrawable drawable) {
// TODO Auto-generated method stub
final GL2 gl = drawable.getGL().getGL2();
gl.glTranslatef(0f, 0f, -2.5f);
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(-0.75f,0f,0);
gl.glVertex3f(0f,-0.75f, 0);
gl.glEnd();
//3d line
gl.glBegin(GL2.GL_LINES);
//3 units in to the window
gl.glVertex3f(-0.75f,0f,3f);
gl.glVertex3f(0f,-0.75f,3f);
gl.glEnd();
//top
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(-0.75f,0f,0);
gl.glVertex3f(-0.75f,0f,3f);
gl.glEnd();
//bottom
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0f,-0.75f, 0);
gl.glVertex3f(0f,-0.75f,3f);
gl.glEnd();
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
@Override
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
// TODO Auto-generated method stubfinal
GL2 gl = drawable.getGL().getGL2();
if(height <= 0)
height = 1;
final float h = (float) width / (float) height;
gl.glViewport(0, 0, width, height);
gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(45.0f, h, 1.0, 20.0);
gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
Edge1 b = new Edge1();
glcanvas.addGLEventListener(b);
glcanvas.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame (" 3d edge");
//adding canvas to it
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
}//end of main
}//end of class
上記のプログラムをコンパイルして実行すると、次の出力が生成されます-
同様に、2D四角形の対応する辺に3Dエッジを展開し、隣接する頂点を結合することで、3D四角形を取得できます。
以下は、JOGLを使用してひし形を描画するプログラムです。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;
import javax.swing.JFrame;
public class Rhombus implements GLEventListener {
private GLU glu = new GLU();
@Override
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glTranslatef(0f, 0f, -2.5f);
//drawing edge1.....
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(-0.75f,0f,0);
gl.glVertex3f(0f,-0.75f, 0);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(-0.75f,0f,3f); // 3 units into the window
gl.glVertex3f(0f,-0.75f,3f);
gl.glEnd();
//top
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(-0.75f,0f,0);
gl.glVertex3f(-0.75f,0f,3f);
gl.glEnd();
// bottom
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0f,-0.75f, 0);
gl.glVertex3f(0f,-0.75f,3f);
gl.glEnd();
// edge 2....
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0f,-0.75f, 0);
gl.glVertex3f(0.75f,0f, 0);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0f,-0.75f, 3f);
gl.glVertex3f(0.75f,0f, 3f);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0f,-0.75f, 0);
gl.glVertex3f(0f,-0.75f, 3f);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0.75f,0f, 0);
gl.glVertex3f(0.75f,0f, 3f);
gl.glEnd();
//Edge 3.............
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f( 0.0f,0.75f,0);
gl.glVertex3f(-0.75f,0f,0);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f( 0.0f,0.75f,3f);
gl.glVertex3f(-0.75f,0f,3f);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f( 0.0f,0.75f,0);
gl.glVertex3f( 0.0f,0.75f,3f);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(-0.75f,0f,0);
gl.glVertex3f(-0.75f,0f,3f);
gl.glEnd();
//final edge
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0.75f,0f, 0);
gl.glVertex3f( 0.0f,0.75f,0);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0.75f,0f,3f);
gl.glVertex3f( 0.0f,0.75f,3f);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f(0.75f,0f, 0);
gl.glVertex3f(0.75f,0f,3f);
gl.glEnd();
gl.glBegin(GL2.GL_LINES);
gl.glVertex3f( 0.0f,0.75f,0);
gl.glVertex3f( 0.0f,0.75f,3f);
gl.glEnd();
}
@Override
public void dispose(GLAutoDrawable arg0) {
//method body
}
@Override
public void init(GLAutoDrawable arg0) {
// method body
}
@Override
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
// TODO Auto-generated method stub final
GL2 gl = drawable.getGL().getGL2();
if(height lt;= 0)
height = 1;
final float h = (float) width / (float) height;
gl.glViewport(3, 6, width, height);
gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(45.0f, h, 1.0, 20.0);
gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
}
public static void main(String[] args) {
//getting the capabilities object of GL2 profile
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
Rhombus b = new Rhombus();
glcanvas.addGLEventListener(b);
glcanvas.setSize(400, 400);
//creating frame
final JFrame frame = new JFrame (" Rhombus 3d");
//adding canvas to it
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
}//end of main
}//end of classimport javax.media.opengl.GL2;
上記のプログラムをコンパイルして実行すると、次の出力が生成されます。3D線を使用して描かれたひし形を示しています。
の事前定義されたパラメータ glBegin() メソッドは、3D形状の描画に使用できます。
前の章では、3D形状を描画する方法を見てきましたが、この章では、3D三角形を描画して回転させる方法を説明します。
以下に示すのは、3D三角形を描画して回転させるプログラムです。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;
import javax.swing.JFrame;
import com.jogamp.opengl.util.FPSAnimator;
public class Triangle3d implements GLEventListener {
private GLU glu = new GLU();
private float rtri = 0.0f;
@Override
public void display(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
// Clear The Screen And The Depth Buffer
gl.glClear( GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT );
gl.glLoadIdentity(); // Reset The View
gl.glTranslatef( -0.5f, 0.0f, -6.0f ); // Move the triangle
gl.glRotatef( rtri, 0.0f, 1.0f, 0.0f );
gl.glBegin( GL2.GL_TRIANGLES );
//drawing triangle in all dimensions
// Front
gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Front)
gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Left Of Triangle (Front)
gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Right Of Triangle (Front)
// Right
gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Right)
gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Left Of Triangle (Right)
gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Right Of Triangle (Right)
// Left
gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Back)
gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Left Of Triangle (Back)
gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Right Of Triangle (Back)
//left
gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Red
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top Of Triangle (Left)
gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Left Of Triangle (Left)
gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Right Of Triangle (Left)
gl.glEnd(); // Done Drawing 3d triangle (Pyramid)
gl.glFlush();
rtri += 0.2f;
}
@Override
public void dispose( GLAutoDrawable drawable ) {
//method body
}
@Override
public void init( GLAutoDrawable drawable ) {
//method body
}
@Override
public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) {
// TODO Auto-generated method stub
final GL2 gl = drawable.getGL().getGL2();
if(height lt;=;)
height = 1;
final float h = ( float ) width / ( float ) height;
gl.glViewport( 0, 0, width, height );
gl.glMatrixMode( GL2.GL_PROJECTION );
gl.glLoadIdentity();
glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
gl.glMatrixMode( GL2.GL_MODELVIEW );
gl.glLoadIdentity();
}
public static void main( String[] args ) {
// TODO Auto-generated method stub
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities( profile );
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
Triangle3d triangle = new Triangle3d();
glcanvas.addGLEventListener( triangle );
glcanvas.setSize( 400, 400 );
final JFrame frame = new JFrame ( "3d Triangle (shallow)" );
frame.getContentPane().add( glcanvas );
frame.setSize( frame.getContentPane().getPreferredSize() );
frame.setVisible( true );
final FPSAnimator animator = new FPSAnimator(glcanvas,300,true);
animator.start();
}
}
上記のプログラムをコンパイルして実行すると、次の出力が生成されます。ここに、回転する3D三角形のスナップショットがあります。このプログラムには深度テストが含まれていないため、三角形は中空に生成されます。
三角形をソリッドにするには、を使用して深度テストを有効にする必要があります glEnable(GL_DEPTH_TEST)。デプスバッファを有効にすると、空白の画面が表示されます。これは、を使用して色をクリアすることでクリアできますglClear(GL_COLOR_BUFFERBIT | GL_DEPTH_BUFFER_BIT)方法。init()メソッドまたはで深度テストを有効にするにはglDisplay() メソッド、次のコードを記述します-
public void init(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glShadeModel(GL2.GL_SMOOTH);
gl.glClearColor(0f, 0f, 0f, 0f);
gl.glClearDepth(1.0f);
gl.glEnable(GL2.GL_DEPTH_TEST);
gl.glDepthFunc(GL2.GL_LEQUAL);
gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);
}
以下に、深度テストで3D三角形を描画するプログラムを示します。
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;
import javax.swing.JFrame;
import com.jogamp.opengl.util.FPSAnimator;
public class Triangledepthtest implements GLEventListener {
private GLU glu = new GLU();
private float rtri = 0.0f;
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glShadeModel( GL2.GL_SMOOTH );
gl.glClearColor( 0f, 0f, 0f, 0f );
gl.glClearDepth( 1.0f );
gl.glEnable( GL2.GL_DEPTH_TEST );
gl.glDepthFunc( GL2.GL_LEQUAL );
gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);
// Clear The Screen And The Depth Buffer
gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
gl.glLoadIdentity(); // Reset The View
gl.glTranslatef( -0.5f,0.0f,-6.0f ); // Move the triangle
gl.glRotatef( rtri, 0.0f, 1.0f, 0.0f );
gl.glBegin( GL2.GL_TRIANGLES );
//drawing triangle in all dimensions
//front
gl.glColor3f( 1.0f, 0.0f, 0.0f ); // Red
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
gl.glColor3f( 0.0f, 1.0f, 0.0f ); // Green
gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Left
gl.glColor3f( 0.0f, 0.0f, 1.0f ); // Blue
gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Right)
//right
gl.glColor3f( 1.0f, 0.0f, 0.0f );
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
gl.glColor3f( 0.0f, 0.0f, 1.0f );
gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Left
gl.glColor3f( 0.0f, 1.0f, 0.0f );
gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Right
//left
gl.glColor3f( 1.0f, 0.0f, 0.0f );
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
gl.glColor3f( 0.0f, 1.0f, 0.0f );
gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Left
gl.glColor3f( 0.0f, 0.0f, 1.0f );
gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Right
//top
gl.glColor3f( 0.0f, 1.0f, 0.0f );
gl.glVertex3f( 1.0f, 2.0f, 0.0f ); // Top
gl.glColor3f( 0.0f, 0.0f, 1.0f );
gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Left
gl.glColor3f( 0.0f, 1.0f, 0.0f );
gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Right
gl.glEnd(); // Done Drawing 3d triangle (Pyramid)
gl.glFlush();
rtri += 0.2f;
}
@Override
public void dispose( GLAutoDrawable drawable ) {
}
@Override
public void init( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glShadeModel( GL2.GL_SMOOTH );
gl.glClearColor( 0f, 0f, 0f, 0f );
gl.glClearDepth( 1.0f );
gl.glEnable( GL2.GL_DEPTH_TEST );
gl.glDepthFunc( GL2.GL_LEQUAL );
gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST );
}
@Override
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height ) {
// TODO Auto-generated method stub
final GL2 gl = drawable.getGL().getGL2();
if( height <= 0 )
height = 1;
final float h = ( float ) width / ( float ) height;
gl.glViewport( 0, 0, width, height );
gl.glMatrixMode( GL2.GL_PROJECTION );
gl.glLoadIdentity();
glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
gl.glMatrixMode( GL2.GL_MODELVIEW );
gl.glLoadIdentity();
}
public static void main( String[] args ) {
// TODO Auto-generated method stub
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities( profile );
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
Triangledepthtest triangledepthtest = new Triangledepthtest();
glcanvas.addGLEventListener( triangledepthtest );
glcanvas.setSize( 400, 400 );
final JFrame frame = new JFrame ( "3d Triangle (solid)" );
frame.getContentPane().add(glcanvas);
frame.setSize( frame.getContentPane().getPreferredSize() );
frame.setVisible( true );
final FPSAnimator animator = new FPSAnimator( glcanvas, 300,true);
animator.start();
}
}
上記のプログラムをコンパイルして実行すると、次の出力が生成されます。
ここでは、回転する3D三角形のスナップショットを見ることができます。このプログラムには深度テスト用のコードが含まれているため、三角形は実線で生成されます。
前の章では、3D三角形を描画して回転させる方法を見てきました。この章では、3D立方体の作成方法、回転方法、画像を添付する方法を学習できます。同様に、この章では、3D立方体を描画し、それに色を適用して画像を添付する例を示します。
以下は、3D立方体を描画し、それに色を適用するプログラムです。
import java.awt.DisplayMode;
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;
import javax.swing.JFrame;
import com.jogamp.opengl.util.FPSAnimator;
public class Cube implements GLEventListener {
public static DisplayMode dm, dm_old;
private GLU glu = new GLU();
private float rquad = 0.0f;
@Override
public void display( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT );
gl.glLoadIdentity();
gl.glTranslatef( 0f, 0f, -5.0f );
// Rotate The Cube On X, Y & Z
gl.glRotatef(rquad, 1.0f, 1.0f, 1.0f);
//giving different colors to different sides
gl.glBegin(GL2.GL_QUADS); // Start Drawing The Cube
gl.glColor3f(1f,0f,0f); //red color
gl.glVertex3f(1.0f, 1.0f, -1.0f); // Top Right Of The Quad (Top)
gl.glVertex3f( -1.0f, 1.0f, -1.0f); // Top Left Of The Quad (Top)
gl.glVertex3f( -1.0f, 1.0f, 1.0f ); // Bottom Left Of The Quad (Top)
gl.glVertex3f( 1.0f, 1.0f, 1.0f ); // Bottom Right Of The Quad (Top)
gl.glColor3f( 0f,1f,0f ); //green color
gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Top Right Of The Quad
gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Top Left Of The Quad
gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Bottom Left Of The Quad
gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Bottom Right Of The Quad
gl.glColor3f( 0f,0f,1f ); //blue color
gl.glVertex3f( 1.0f, 1.0f, 1.0f ); // Top Right Of The Quad (Front)
gl.glVertex3f( -1.0f, 1.0f, 1.0f ); // Top Left Of The Quad (Front)
gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Bottom Left Of The Quad
gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Bottom Right Of The Quad
gl.glColor3f( 1f,1f,0f ); //yellow (red + green)
gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Bottom Left Of The Quad
gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Bottom Right Of The Quad
gl.glVertex3f( -1.0f, 1.0f, -1.0f ); // Top Right Of The Quad (Back)
gl.glVertex3f( 1.0f, 1.0f, -1.0f ); // Top Left Of The Quad (Back)
gl.glColor3f( 1f,0f,1f ); //purple (red + green)
gl.glVertex3f( -1.0f, 1.0f, 1.0f ); // Top Right Of The Quad (Left)
gl.glVertex3f( -1.0f, 1.0f, -1.0f ); // Top Left Of The Quad (Left)
gl.glVertex3f( -1.0f, -1.0f, -1.0f ); // Bottom Left Of The Quad
gl.glVertex3f( -1.0f, -1.0f, 1.0f ); // Bottom Right Of The Quad
gl.glColor3f( 0f,1f, 1f ); //sky blue (blue +green)
gl.glVertex3f( 1.0f, 1.0f, -1.0f ); // Top Right Of The Quad (Right)
gl.glVertex3f( 1.0f, 1.0f, 1.0f ); // Top Left Of The Quad
gl.glVertex3f( 1.0f, -1.0f, 1.0f ); // Bottom Left Of The Quad
gl.glVertex3f( 1.0f, -1.0f, -1.0f ); // Bottom Right Of The Quad
gl.glEnd(); // Done Drawing The Quad
gl.glFlush();
rquad -= 0.15f;
}
@Override
public void dispose( GLAutoDrawable drawable ) {
// TODO Auto-generated method stub
}
@Override
public void init( GLAutoDrawable drawable ) {
final GL2 gl = drawable.getGL().getGL2();
gl.glShadeModel( GL2.GL_SMOOTH );
gl.glClearColor( 0f, 0f, 0f, 0f );
gl.glClearDepth( 1.0f );
gl.glEnable( GL2.GL_DEPTH_TEST );
gl.glDepthFunc( GL2.GL_LEQUAL );
gl.glHint( GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST );
}
@Override
public void reshape( GLAutoDrawable drawable, int x, int y, int width, int height ) {
// TODO Auto-generated method stub
final GL2 gl = drawable.getGL().getGL2();
if( height lt;= 0 )
height = 1;
final float h = ( float ) width / ( float ) height;
gl.glViewport( 0, 0, width, height );
gl.glMatrixMode( GL2.GL_PROJECTION );
gl.glLoadIdentity();
glu.gluPerspective( 45.0f, h, 1.0, 20.0 );
gl.glMatrixMode( GL2.GL_MODELVIEW );
gl.glLoadIdentity();
}
public static void main( String[] args ) {
final GLProfile profile = GLProfile.get( GLProfile.GL2 );
GLCapabilities capabilities = new GLCapabilities( profile );
// The canvas
final GLCanvas glcanvas = new GLCanvas( capabilities );
Cube cube = new Cube();
glcanvas.addGLEventListener( cube );
glcanvas.setSize( 400, 400 );
final JFrame frame = new JFrame ( " Multicolored cube" );
frame.getContentPane().add( glcanvas );
frame.setSize( frame.getContentPane().getPreferredSize() );
frame.setVisible( true );
final FPSAnimator animator = new FPSAnimator(glcanvas, 300,true);
animator.start();
}
}
上記のプログラムをコンパイルして実行すると、次の出力が生成されます。色付きの3Dキューブが表示されます。
立方体にテクスチャを適用する
立方体にテクスチャを適用するには、次の手順を実行します。
を使用して、必要なテクスチャをキューブにバインドできます。 gl.glBindTexture(GL2.GL_TEXTURE_2D.texture) Drawableインターフェースのメソッド。
このメソッドには、texture(int)引数と GL2.GL_TEXTURE_2D(int)。
実行する前に Display()、テクスチャ変数を作成する必要があります
の中に init() メソッドまたはの開始行 glDisplay() メソッド、テクスチャを有効にする using gl.glEnable(GL2.GL_TEXTURE_2D) 方法。
テクスチャオブジェクトを作成します。これには、パラメータとしてファイルオブジェクトが必要です。次に、オブジェクトへのテクスチャとして使用される画像のパスが必要です。
File file = new File(“c:\\pictures\\boy.jpg”);
Texture t = textureIO.newTexture(file, true);
texture = t.getTextureObject(gl);
- 「ファイルが見つかりません」例外を処理します
以下は、立方体に画像を添付するプログラムです。
import java.awt.DisplayMode;
import java.io.File;
import java.io.IOException;
import javax.media.opengl.GL2;
import javax.media.opengl.GLAutoDrawable;
import javax.media.opengl.GLCapabilities;
import javax.media.opengl.GLEventListener;
import javax.media.opengl.GLProfile;
import javax.media.opengl.awt.GLCanvas;
import javax.media.opengl.glu.GLU;
import javax.swing.JFrame;
import com.jogamp.opengl.util.FPSAnimator;
import com.jogamp.opengl.util.texture.Texture;
import com.jogamp.opengl.util.texture.TextureIO;
public class CubeTexture implements GLEventListener {
public static DisplayMode dm, dm_old;
private GLU glu = new GLU();
private float xrot,yrot,zrot;
private int texture;
@Override
public void display(GLAutoDrawable drawable) {
// TODO Auto-generated method stub
final GL2 gl = drawable.getGL().getGL2();
gl.glClear(GL2.GL_COLOR_BUFFER_BIT | GL2.GL_DEPTH_BUFFER_BIT);
gl.glLoadIdentity(); // Reset The View
gl.glTranslatef(0f, 0f, -5.0f);
gl.glRotatef(xrot, 1.0f, 1.0f, 1.0f);
gl.glRotatef(yrot, 0.0f, 1.0f, 0.0f);
gl.glRotatef(zrot, 0.0f, 0.0f, 1.0f);
gl.glBindTexture(GL2.GL_TEXTURE_2D, texture);
gl.glBegin(GL2.GL_QUADS);
// Front Face
gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, 1.0f);
gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, 1.0f);
gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, 1.0f);
gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, 1.0f);
// Back Face
gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, -1.0f);
gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, -1.0f);
gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, -1.0f);
gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, -1.0f);
// Top Face
gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, -1.0f);
gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f(-1.0f, 1.0f, 1.0f);
gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f( 1.0f, 1.0f, 1.0f);
gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, -1.0f);
// Bottom Face
gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f(-1.0f, -1.0f, -1.0f);
gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f( 1.0f, -1.0f, -1.0f);
gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, 1.0f);
gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, 1.0f);
// Right face
gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, -1.0f);
gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, -1.0f);
gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f( 1.0f, 1.0f, 1.0f);
gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f( 1.0f, -1.0f, 1.0f);
// Left Face
gl.glTexCoord2f(0.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, -1.0f);
gl.glTexCoord2f(1.0f, 0.0f); gl.glVertex3f(-1.0f, -1.0f, 1.0f);
gl.glTexCoord2f(1.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, 1.0f);
gl.glTexCoord2f(0.0f, 1.0f); gl.glVertex3f(-1.0f, 1.0f, -1.0f);
gl.glEnd();
gl.glFlush();
//change the speeds here
xrot += .1f;
yrot += .1f;
zrot += .1f;
}
@Override
public void dispose(GLAutoDrawable drawable) {
// method body
}
@Override
public void init(GLAutoDrawable drawable) {
final GL2 gl = drawable.getGL().getGL2();
gl.glShadeModel(GL2.GL_SMOOTH);
gl.glClearColor(0f, 0f, 0f, 0f);
gl.glClearDepth(1.0f);
gl.glEnable(GL2.GL_DEPTH_TEST);
gl.glDepthFunc(GL2.GL_LEQUAL);
gl.glHint(GL2.GL_PERSPECTIVE_CORRECTION_HINT, GL2.GL_NICEST);
//
gl.glEnable(GL2.GL_TEXTURE_2D);
try{
File im = new File("E:\\office\\boy.jpg ");
Texture t = TextureIO.newTexture(im, true);
texture= t.getTextureObject(gl);
}catch(IOException e){
e.printStackTrace();
}
}
@Override
public void reshape(GLAutoDrawable drawable, int x, int y, int width, int height) {
// TODO Auto-generated method stub
final GL2 gl = drawable.getGL().getGL2();
if(height lt;= 0)
height = 1;
final float h = (float) width / (float) height;
gl.glViewport(0, 0, width, height);
gl.glMatrixMode(GL2.GL_PROJECTION);
gl.glLoadIdentity();
glu.gluPerspective(45.0f, h, 1.0, 20.0);
gl.glMatrixMode(GL2.GL_MODELVIEW);
gl.glLoadIdentity();
}
public static void main(String[] args) {
// TODO Auto-generated method stub
final GLProfile profile = GLProfile.get(GLProfile.GL2);
GLCapabilities capabilities = new GLCapabilities(profile);
// The canvas
final GLCanvas glcanvas = new GLCanvas(capabilities);
CubeTexture r = new CubeTexture();
glcanvas.addGLEventListener(r);
glcanvas.setSize(400, 400);
final JFrame frame = new JFrame (" Textured Cube");
frame.getContentPane().add(glcanvas);
frame.setSize(frame.getContentPane().getPreferredSize());
frame.setVisible(true);
final FPSAnimator animator = new FPSAnimator(glcanvas, 300, true);
animator.start();
}
}
上記のプログラムをコンパイルして実行すると、次の出力が生成されます。目的のテクスチャが適用された3D立方体を見ることができます。
GPU −グラフィックプロセッシングユニット。画像のレンダリングを高速化する特殊な電子デバイスです。
JNI−Javaネイティブインターフェイス。これを使用して、Javaはネイティブメソッドにアクセスします。
Model −これらは、ポイント、ライン、ポリゴンなどの基本的なグラフィックプリミティブから構築されたオブジェクトです。
Pixel −画面に表示される表示の最小単位。
Projection −オブジェクトの座標を2次元平面にマッピングする方法は、投影と呼ばれます。
Projection matrix −これは、2Dサーフェス上のオブジェクトの線形変換です。
Rendering −コンピューターがモデルから画像を作成するプロセス。
Viewport −ビューポートは、コンピュータグラフィックスの画面上の表示領域です。