WebGL-モデルの描画

バッファーをシェーダーに関連付けた後、最後のステップは必要なプリミティブを描画することです。WebGLには、次の2つのメソッドがあります。drawArrays() そして drawElements() モデルを描画します。

drawArrays()

drawArrays()は、頂点を使用してモデルを描画するために使用される方法です。これがその構文です-

void drawArrays(enum mode, int first, long count)

このメソッドは、次の3つのパラメーターを取ります-

  • mode− WebGLでは、モデルはプリミティブ型を使用して描画されます。モードを使用して、プログラマーはWebGLによって提供されるプリミティブ型の1つを選択する必要があります。このオプションに指定できる値は、-gl.POINTS、gl.LINE_STRIP、gl.LINE_LOOP、gl.LINES、gl.TRIANGLE_STRIP、gl.TRIANGLE_FAN、およびgl.TRIANGLESです。

  • first−このオプションは、有効な配列の開始要素を指定します。負の値にすることはできません。

  • count −このオプションは、レンダリングされる要素の数を指定します。

を使用してモデルを描画する場合 drawArrays() メソッド、次にWebGLは、形状をレンダリングするときに、頂点座標が定義されている順序でジオメトリを作成します。

を使用して単一の三角形を描画する場合 drawArray() メソッドの場合、3つの頂点を渡して、 drawArrays() 以下に示すように、メソッド。

var vertices = [-0.5,-0.5, -0.25,0.5, 0.0,-0.5,];
gl.drawArrays(gl.TRIANGLES, 0, 3);

以下に示すような三角形が生成されます。

連続する三角形を描画する場合、頂点バッファに次の3つの頂点を順番に渡し、レンダリングする要素の数を6として指定する必要があります。

var vertices = [-0.5,-0.5, -0.25,0.5, 0.0,-0.5, 0.0,-0.5, 0.25,0.5, 0.5,-0.5,];
gl.drawArrays(gl.TRIANGLES, 0, 6);

以下に示すように、連続した三角形が生成されます。

drawElements()

drawElements()は、頂点とインデックスを使用してモデルを描画するために使用される方法です。その構文は次のとおりです-

void drawElements(enum mode, long count, enum type, long offset)

このメソッドは、次の4つのパラメーターを取ります-

  • mode− WebGLモデルは、プリミティブ型を使用して描画されます。モードを使用して、プログラマーはWebGLによって提供されるプリミティブ型の1つを選択する必要があります。このオプションで可能な値のリストは、-gl.POINTS、gl.LINE_STRIP、gl.LINE_LOOP、gl.LINES、gl.TRIANGLE_STRIP、gl.TRIANGLE_FAN、およびgl.TRIANGLESです。

  • count −このオプションは、レンダリングされる要素の数を指定します。

  • type −このオプションは、UNSIGNED_BYTEまたはUNSIGNED_SHORTでなければならないインデックスのデータ型を指定します。

  • offset−このオプションは、レンダリングの開始点を指定します。通常、これは最初の要素(0)です。

を使用してモデルを描画する場合 drawElements()メソッドの場合、頂点バッファオブジェクトとともにインデックスバッファオブジェクトも作成する必要があります。この方法を使用すると、頂点データは1回処理され、インデックスに記載されている回数だけ使用されます。

インデックスを使用して単一の三角形を描画する場合は、頂点とともにインデックスを渡し、を呼び出す必要があります。 drawElements() 以下に示す方法。

var vertices = [ -0.5,-0.5,0.0, -0.25,0.5,0.0, 0.0,-0.5,0.0 ];
var indices = [0,1,2];

gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);

次の出力が生成されます-

を使用して伝染性の三角形を描きたい場合 drawElements() メソッドでは、他の頂点を追加し、残りの頂点のインデックスに言及するだけです。

var vertices = [
   -0.5,-0.5,0.0,
   -0.25,0.5,0.0,
   0.0,-0.5,0.0,
   0.25,0.5,0.0,
   0.5,-0.5,0.0 
];

var indices = [0,1,2,2,3,4];

gl.drawElements(gl.TRIANGLES, indices.length, gl.UNSIGNED_SHORT,0);

次の出力が生成されます-

必要な操作

プリミティブを描画する前に、以下で説明するいくつかの操作を実行する必要があります。

キャンバスをクリアする

まず、を使用してキャンバスをクリアする必要があります clearColor()方法。目的の色のRGBA値をパラメーターとしてこのメ​​ソッドに渡すことができます。次に、WebGLはキャンバスをクリアし、指定された色で塗りつぶします。したがって、この方法を使用して背景色を設定できます。

次の例を見てください。ここでは、灰色のRGBA値を渡します。

gl.clearColor(0.5, 0.5, .5, 1);

深度テストを有効にする

を使用して深度テストを有効にします enable() 以下に示すように、メソッド。

gl.enable(gl.DEPTH_TEST);

カラーバッファビットをクリアする

を使用して、色と深度バッファをクリアします。 clear() 以下に示すように、メソッド。

gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);

ビューポートを設定する

ビューポートは、描画バッファのレンダリング結果を含む長方形の表示可能領域を表します。ビューポートの寸法は、を使用して設定できます。viewport()方法。次のコードでは、ビューポートの寸法がキャンバスの寸法に設定されています。

gl.viewport(0,0,canvas.width,canvas.height);