1# WebGL Overview 2 3Web Graphic Library (WebGL) is used for rendering interactive 2D and 3D graphics. WebGL used in OpenHarmony is based on OpenGL for Embedded Systems (OpenGL ES). It can be used in the **\<canvas>** object of HTML5 without using plug-ins and supports cross-platform. WebGL is programmed by JavaScript code. Its APIs can implement graphics rendering and acceleration by using GPU hardware provided by the user equipment. For more information, see [WebGL™](https://www.khronos.org/registry/webgl/specs/latest/1.0/). 4 5 6## Basic Concepts 7 8 9### Shader 10 11Shaders are instructions and data that run in a graphics card. In WebGL, shaders are written in the OpenGL Shading Language (GLSL). 12 13There are vertex shaders and fragment shaders. The interaction between vertex shaders and fragment shaders involves rasterization. 14 15- The vertex shader is mainly used to receive the coordinates of a point in a 3D space, process the coordinates into coordinates in a 2D space, and output the coordinates. 16 17- The fragment shader is mainly used to output a color value for each pixel being processed. 18 19- Rasterization is the process of converting the coordinates output by the vertex shader into pixels to be processed and passing the pixels to the fragment shader. 20 21 22### Buffer 23 24The buffer is a JavaScript object that resides in memory and stores the **attribute** object to be pushed to the shader. 25 26 27### WebGLProgram 28 29The WebGLProgram is a JavaScript object responsible for associating the shader with the buffer. A **WebGLProgram** object consists of two compiled WebGL shaders: a vertex shader and a fragment shader. 30 31 32## Working Principles 33 34**Figure 1** WebGL working principles 35 36![en-us_image_0000001238544451](figures/en-us_image_0000001238544451.png) 37 38 39- An application draws UI components using HTML5 at the foreground. 40 41- Native APIs complete the interaction between JavaScript and C++ code. 42 43- JavaScript engine is the graphics framework that provides the **Surface** object for the WebGL module. 44 45- The WebGL module exposes the GPU drawing APIs of OpenGL ES. 46 47- The Embedded Graphics Library (EGL) implements adaptation to different platforms. 48