WebGL - Pipeline Grafik

Untuk membuat grafik 3D, kita harus mengikuti serangkaian langkah. Langkah-langkah ini dikenal sebagaigraphics pipeline atau rendering pipeline. Diagram berikut menggambarkan pipeline grafis WebGL.

Pada bagian berikut, kita akan membahas satu per satu peran dari setiap langkah dalam pipeline.

JavaScript

Saat mengembangkan aplikasi WebGL, kami menulis kode bahasa Shader untuk berkomunikasi dengan GPU. JavaScript digunakan untuk menulis kode kontrol program, yang mencakup tindakan berikut -

  • Initialize WebGL - JavaScript digunakan untuk menginisialisasi konteks WebGL.

  • Create arrays - Kami membuat array JavaScript untuk menyimpan data geometri.

  • Buffer objects - Kami membuat objek penyangga (simpul dan indeks) dengan melewatkan array sebagai parameter.

  • Shaders - Kami membuat, mengompilasi, dan menautkan shader menggunakan JavaScript.

  • Attributes - Kita dapat membuat atribut, mengaktifkannya, dan mengaitkannya dengan objek buffer menggunakan JavaScript.

  • Uniforms - Kami juga dapat mengasosiasikan seragam menggunakan JavaScript.

  • Transformation matrix - Menggunakan JavaScript, kita dapat membuat matriks transformasi.

Awalnya kami membuat data untuk geometri yang diperlukan dan meneruskannya ke shader dalam bentuk buffer. Variabel atribut dari bahasa shader menunjuk ke objek buffer, yang diteruskan sebagai input ke vertex shader.

Vertex Shader

Saat kita memulai proses rendering dengan menjalankan metode drawElements() dan drawArray(), vertex shader dijalankan untuk setiap vertex yang disediakan di objek buffer vertex. Ini menghitung posisi setiap simpul dari poligon primitif dan menyimpannya dalam variasigl_position. Itu juga menghitung atribut lain seperticolor, texture coordinates, dan vertices yang biasanya diasosiasikan dengan sebuah simpul.

Majelis Primitif

Setelah menghitung posisi dan detail lain dari setiap simpul, tahap selanjutnya adalah primitive assembly stage. Di sini segitiga dirakit dan diteruskan ke rasterizer.

Rasterisasi

Pada langkah rasterisasi, piksel pada gambar akhir dari primitif ditentukan. Ini memiliki dua langkah -

  • Culling- Awalnya orientasi poligon (menghadap ke depan atau belakang?) Ditentukan. Semua segitiga dengan orientasi yang tidak tepat yang tidak terlihat di area tampilan akan dibuang. Proses ini disebut pemusnahan.

  • Clipping- Jika segitiga sebagian berada di luar area tampilan, maka bagian di luar area tampilan dihilangkan. Proses ini dikenal sebagai clipping.

Fragmen Shader

Fragmen shader mendapat

  • data dari vertex shader dalam berbagai variabel,
  • primitif dari tahap rasterisasi, dan kemudian
  • menghitung nilai warna untuk setiap piksel antara simpul.

Shader fragmen menyimpan nilai warna setiap piksel di setiap fragmen. Nilai warna ini dapat diakses selama operasi fragmen, yang akan kita bahas selanjutnya.

Operasi Fragmen

Operasi fragmen dilakukan setelah menentukan warna setiap piksel pada primitif. Operasi fragmen ini mungkin termasuk yang berikut -

  • Depth
  • Campuran penyangga warna
  • Dithering

Setelah semua fragmen diproses, gambar 2D terbentuk dan ditampilkan di layar. Ituframe buffer adalah tujuan akhir dari pipeline rendering.

Penyangga Bingkai

Buffer bingkai adalah bagian dari memori grafis yang menyimpan data adegan. Buffer ini berisi detail seperti lebar dan tinggi permukaan (dalam piksel), warna setiap piksel, serta buffer kedalaman dan stensil.