OpenGL ES

1.1 introduction

OpenGL is a set of versatile open standard libraries for processing visual 2D and 3D data. OpenGL can convert calling functions into graphics processing commands and send them to the underlying graphics hardware, so the drawing efficiency of OpenGL is very fast.

The Open Graphics Library (OpenGL) is used for visualizing 2D and 3D data. It is a multipurpose open-standard graphics library that supports applications for 2D and 3D digital content creation, mechanical and architectural design, virtual prototyping, flight simulation, video games, and more. You use OpenGL to configure a 3D graphics pipeline and submit data to it. Vertices are transformed and lit, assembled into primitives, and rasterized to create a 2D image. OpenGL is designed to translate function calls into graphics commands that can be sent to underlying graphics hardware. Because this underlying hardware is dedicated to processing graphics commands, OpenGL drawing is typically very fast.

OpenGL ES is a simplified version of OpenGL. It is an advanced 3D graphics and image API for handheld and mobile devices. It can directly operate GPU hardware. Its official Apple documentation describes it as follows:

OpenGL for Embedded Systems (OpenGL ES) is a simplified version of OpenGL that eliminates redundant functionality to provide a library that is both easier to learn and easier to implement in mobile graphics hardware.

OpenGL ES eliminates some redundant functions in OpenGL that are not available on mobile terminals. It is a mainstream graphical API for smart phones. Currently, OpenGL ES supports iOS, Android, BlackBerry, BADA, Linux, and Windows.

1.2 OpenGL/OpenGL ES rendering pipeline and process

1.2.1 Rendering architecture

  • Texture: Used to pass Texture data. You can pass Texture data to the fragment shader or to the vertex shader, but the vertex shader can’t handle textures, so it doesn’t make sense.
  • Uniform: Uniform data, batch pass, pass some unchanging data to shaders, either vertex shaders or chip shaders
  • Attribute: Parameter Attribute passing. Data can only be passed to the vertex shader and then indirectly to the chip shader through the vertex shader.

1.2.2 Shader business

Shaders are essentially a piece of program code. In OpenGL/OpenGL ES, developers can directly program only vertex shaders and slice shaders. Other shaders cannot be directly programmed by developers, so here only vertex shaders and slice shaders are introduced.

1. Vertex shader input data is the data of each vertex provided by the vertex array, mainly including the following services:

  • Matrix position transformations, such as rotation, translation, and scaling
  • Calculate the lighting formula to generate the vertex color, such as setting the point light or default light
  • Generate/transform texture coordinates

2. The input data of the pixel shader comes from the output of the rasterized vertex shader. It should be noted that the vertex shader is not the pixel shader after the vertex shader, but after the pixel assembly, rasterization, clipping and other processes. Chip shaders mainly include the following businesses:

  • Calculation of the color
  • Get texture value, texture coordinates and graphics coordinates for one – to – one correspondence
  • Fill the pixels with texture/color values

1.2.3 Rendering pipeline process

1. The vertex shader performs matrix transformation of rotation, translation and scaling, as well as lighting Settings, and then outputs data

2. After a series of operations such as pixel assembly, rasterization and clipping, the data is transferred to the pixel shader

  • Primitive assembly: determine what shape, point, line or triangle the graph displays
  • Rasterization: Convert primions to two-dimensional information because the screen is two-dimensional
  • Clipping: The part beyond the viewport is not displayed on the screen and must be clipped

3. After receiving the data, the chip shader calculates the color and acquires the texture, and fills the texture and color

4. Piece-by-fragment processing, which partly includes pixel attribution test, clipping test, depth test, mixing and other operations

  • Pixel ownership test: Determine whether the pixels in the frame buffer are owned by the OpenGL ES context; For example, if two views overlap in a single pixel, the pixels in the view below will be judged not to belong to the OpenGL ES Context and will be discarded.
  • Clipping test: Determines whether a pixel (x, y) is in the rectangular area. If not, it is discarded and not displayed
  • Depth testing: Compare depth values to determine the display level
  • Blend: Combine the newly generated fragment color with the color stored at the location of the frame buffer. For example, if two views overlap and the upper view has transparency, the blend will produce a new color value, since only one color can be displayed on a pixel

1.3 the EGL

The OpenGL ES API does not provide how to create a rendering context or how a context is linked to a native window. EGL is an interface between rendering apis and native windowning systems such as OpenGL ES and various platforms. IOS is the only platform that supports OpenGL ES but does not support EGL, because Apple provides its own EGL API implementation called EAGL. This is similar to the secondary packaging of third-party libraries in our daily development. OpenGL/OpenGL ES is their third-party library for Apple.

2. Introduction to GLKit

GLKit framework is designed to simplify application development based on OpenGL/OpenGL ES. Its appearance speeds up the development of OpenGL ES or OpenGL application programs. The render loop is implemented using math libraries, background texture loading, pre-created colored effects, and standard views and view controllers.

The GLKit framework provides functionality and classes that can reduce the amount of work required to create new pig-based applications or to support existing applications that rely on the fixed function vertex or fragment processing provided by earlier versions of OpenGL ES or OpenGL.

Features provided by GLKit:

  • Loading textures
  • Provides high performance mathematics
  • Provides common shaders
  • Provides views and view controllers, namely GLKView and GLKViewController

GLKit provides classes and interfaces

GLKView: The default implementation of a view that draws its content using OpenGL ES.

GLKViewController: The view controller that manages the OpenGL ES rendering loop.

GLKTextureLoader: utility class that simplifies loading OpenGL or OpenGL ES texture data from a variety of image file formats.

GLKTextureInfo: Information about OpenGL textures created by the GLKTextureInfo class.

GLKBaseEffect: A simple lighting and shading system for shade-based OpenGL rendering. Equivalent to a fixed pipeline shader

Third, summary

What is OpenGL ES?

OpenGL ES is a subset of OpenGL and provides a graphics processing API targeted at mobile and embedded devices.

2. What is EGL?

An interface between OpenGL and native Windows, iOS system does not support EGL, but has its own implementation, called EAGL.

3. What is GLKit?

Apple’s object-oriented encapsulation of OpenGL ES greatly simplifies the development of OpenGL/OpenGL ES.