WebGL-シェーダー

シェーダーは、GPUで実行されるプログラムです。シェーダーはOpenGLESシェーダー言語(ES SLとして知られています)で書かれています。ES SLには、独自の変数、データ型、修飾子、組み込みの入力および出力があります。

データ型

次の表に、OpenGL ESSLが提供する基本的なデータ型を示します。

シニア番号 タイプと説明
1

void

空の値を表します。

2

bool

trueまたはfalseを受け入れます。

3

int

これは符号付き整数データ型です。

4

float

これは浮動スカラーデータ型です。

5

vec2, vec3, vec4

n成分浮動小数点ベクトル

6

bvec2, bvec3, bvec4

ブールベクトル

7

ivec2, ivec3, ivec4

符号付き整数ベクトル

8

mat2, mat3, mat4

2x2、3x3、4x4フロートマトリックス

9

sampler2D

2Dテクスチャにアクセスする

10

samplerCube

キューブマップされたテクスチャにアクセスする

修飾子

OpenGL ESSLには3つの主要な修飾子があります-

シニア番号 修飾子と説明
1

attribute

この修飾子は、頂点シェーダーと頂点ごとのデータのOpenGLESの間のリンクとして機能します。この属性の値は、頂点シェーダーを実行するたびに変更されます。

2

uniform

この修飾子は、シェーダープログラムとWebGLアプリケーションをリンクします。属性修飾子とは異なり、ユニフォームの値は変更されません。ユニフォームは読み取り専用です。それらを任意の基本データ型で使用して、変数を宣言できます。

Example −均一 vec4 lightPosition;

3

varying

この修飾子は、補間されたデータの頂点シェーダーとフラグメントシェーダーの間のリンクを形成します。次のデータ型で使用できます-float、vec2、vec3、vec4、mat2、mat3、mat4、または配列。

Example −変化する vec3 正常;

頂点シェーダー

頂点シェーダーは、すべての頂点で呼び出されるプログラムコードです。ジオメトリ(例:三角形)をある場所から別の場所に変換(移動)します。頂点座標、法線、色、テクスチャ座標など、各頂点のデータ(頂点ごとのデータ)を処理します。

頂点シェーダーのESGLコードでは、プログラマーはデータを処理するための属性を定義する必要があります。これらの属性は、JavaScriptで記述された頂点バッファオブジェクトを指します。次のタスクは、頂点シェーダーと頂点変換を使用して実行できます。

  • 頂点変換
  • 通常の変換と正規化
  • テクスチャ座標の生成
  • テクスチャ座標変換
  • Lighting
  • カラー素材の用途

事前定義された変数

OpenGL ES SLは、頂点シェーダー用に次の定義済み変数を提供します-

シニア番号 変数と説明
1

highp vec4 gl_Position;

頂点の位置を保持します。

2

mediump float gl_PointSize;

変換されたポイントサイズを保持します。この変数の単位はピクセルです。

サンプルコード

頂点シェーダーの次のサンプルコードを見てください。三角形の頂点を処理します。

attribute vec2 coordinates;

void main(void) {
   gl_Position = vec4(coordinates, 0.0, 1.0);
};

上記のコードを注意深く観察すると、次の名前の属性変数が宣言されています。 coordinates。(この変数は、メソッドを使用して頂点バッファオブジェクトに関連付けられますgetAttribLocation()。属性coordinates シェーダープログラムオブジェクトとともに、このメソッドにパラメーターとして渡されます。)

指定された頂点シェーダープログラムの2番目のステップでは、 gl_position 変数が定義されています。

gl_Position

gl_Positionは、頂点シェーダープログラムでのみ使用できる事前定義された変数です。頂点の位置が含まれています。上記のコードでは、coordinates属性はベクトルの形式で渡されます。頂点シェーダーは頂点ごとの操作であるため、gl_position値は頂点ごとに計算されます。

その後、gl_position値は、プリミティブのアセンブリ、クリッピング、カリング、および頂点処理が終了した後にプリミティブを操作するその他の固定機能操作によって使用されます。

頂点シェーダーのすべての可能な操作のための頂点シェーダープログラムを作成できます。これについては、このチュートリアルで個別に説明します。

フラグメントシェーダー

A mesh は複数の三角形で形成され、各三角形の表面は fragment。フラグメントシェーダーは、各フラグメントのすべてのピクセルで実行されるコードです。これは、個々のピクセルの色を計算して塗りつぶすために作成されています。次のタスクは、フラグメントシェーダーを使用して実行できます-

  • 補間された値の操作
  • テクスチャへのアクセス
  • テクスチャアプリケーション
  • Fog
  • 色の合計

事前定義された変数

OpenGL ES SLは、フラグメントシェーダー用に次の定義済み変数を提供します-

シニア番号 変数と説明
1

中程度のvec4 gl_FragCoord;

フレームバッファ内のフラグメント位置を保持します。

2

bool gl_FrontFacing;

正面向きのプリミティブに属するフラグメントを保持します。

3

mediump vec2 gl_PointCoord;

ポイント内のフラグメント位置を保持します(ポイントラスタライズのみ)。

4

mediump vec4 gl_FragColor;

シェーダーの出力フラグメントカラー値を保持します

5

mediump vec4 gl_FragData[n]

カラーアタッチメントのフラグメントカラーを保持します n

サンプルコード

次のフラグメントシェーダーのサンプルコードは、三角形のすべてのピクセルに色を適用する方法を示しています。

void main(void) {
   gl_FragColor = vec4(0, 0.8, 0, 1);
}

上記のコードでは、 color値は変数に格納されますgl.FragColor。フラグメントシェーダープログラムは、固定関数変数を使用して出力をパイプラインに渡します。FragColorはその1つです。この変数は、モデルのピクセルのカラー値を保持します。

シェーダープログラムの保存とコンパイル

シェーダーは独立したプログラムであるため、別のスクリプトとして記述してアプリケーションで使用できます。または、直接保存することもできますstring 以下に示すフォーマット。

var vertCode =
   'attribute vec2 coordinates;' +
	
   'void main(void) {' +
      ' gl_Position = vec4(coordinates, 0.0, 1.0);' +
   '}';

シェーダーのコンパイル

コンパイルには次の3つのステップが含まれます-

  • シェーダーオブジェクトの作成
  • 作成したシェーダーオブジェクトにソースコードを添付する
  • プログラムのコンパイル

頂点シェーダーの作成

空のシェーダーを作成するために、WebGLはと呼ばれるメソッドを提供します createShader()。シェーダーオブジェクトを作成して返します。その構文は次のとおりです-

Object createShader (enum type)

構文に見られるように、このメソッドは事前定義された列挙値をパラメーターとして受け入れます。これには2つのオプションがあります-

  • gl.VERTEX_SHADER 頂点シェーダーを作成するため

  • gl.FRAGMENT_SHADER フラグメントシェーダーを作成するため。

ソースをシェーダーにアタッチする

メソッドを使用して、作成したシェーダーオブジェクトにソースコードを添付できます。 shaderSource()。その構文は次のとおりです-

void shaderSource(Object shader, string source)

このメソッドは2つのパラメーターを受け入れます-

  • shader −作成したシェーダーオブジェクトを1つのパラメーターとして渡す必要があります。

  • Source −シェーダープログラムコードを文字列形式で渡す必要があります。

プログラムのコンパイル

プログラムをコンパイルするには、メソッドを使用する必要があります compileShader()。その構文は次のとおりです-

compileShader(Object shader)

このメソッドは、シェーダープログラムオブジェクトをパラメーターとして受け入れます。シェーダープログラムオブジェクトを作成したら、それにソースコードを添付して、そのオブジェクトをこのメソッドに渡します。

次のコードスニペットは、頂点シェーダーとフラグメントシェーダーを作成およびコンパイルして三角形を作成する方法を示しています。

// Vertex Shader
var vertCode =
   'attribute vec3 coordinates;' +
	
   'void main(void) {' +
      ' gl_Position = vec4(coordinates, 1.0);' +
   '}';

var vertShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertShader, vertCode);
gl.compileShader(vertShader);
 
// Fragment Shader
var fragCode =
   'void main(void) {' +
      ' gl_FragColor = vec4(0, 0.8, 0, 1);' +
   '}';

var fragShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragShader, fragCode);
gl.compileShader(fragShader);

複合プログラム

両方のシェーダープログラムを作成してコンパイルした後、両方のシェーダー(頂点とフラグメント)を含む結合プログラムを作成する必要があります。次の手順に従う必要があります-

  • プログラムオブジェクトを作成する
  • 両方のシェーダーを取り付けます
  • 両方のシェーダーをリンクします
  • プログラムを使用する

プログラムオブジェクトを作成する

メソッドを使用してプログラムオブジェクトを作成します createProgram()。空のプログラムオブジェクトを返します。これがその構文です-

createProgram();

シェーダーを取り付ける

メソッドを使用して、作成したプログラムオブジェクトにシェーダーをアタッチします attachShader()。その構文は次のとおりです-

attachShader(Object program, Object shader);

このメソッドは2つのパラメーターを受け入れます-

  • Program −作成した空のプログラムオブジェクトを1つのパラメータとして渡します。

  • Shader −コンパイルされたシェーダープログラム(頂点シェーダー、フラグメントシェーダー)の1つを渡す

Note −この方法を使用して両方のシェーダーをアタッチする必要があります。

シェーダーをリンクする

メソッドを使用してシェーダーをリンクします linkProgram()、シェーダーをアタッチしたプログラムオブジェクトを渡すことによって。その構文は次のとおりです-

linkProgram(shaderProgram);

プログラムを使用する

WebGLはと呼ばれるメソッドを提供します useProgram()。リンクされたプログラムをそれに渡す必要があります。その構文は次のとおりです-

useProgram(shaderProgram);

次のコードスニペットは、結合されたシェーダープログラムを作成、リンク、および使用する方法を示しています。

var shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertShader);
gl.attachShader(shaderProgram, fragShader);
gl.linkProgram(shaderProgram);
gl.useProgram(shaderProgram);