This case is mainly the use of common primitives connection, common basic primitives connection see this link
The final result is shown in the figure below:
As shown in the figure, the overall drawing process is as follows
- Main function: program entry
- ChangeSize function: mainly set the viewport and projection mode
- SetupRC function: graphic data configuration, mainly vertex data and pixel connection
- RenderScene function: The RenderScene function is used to draw graphics. It can be triggered either by the system or manually by the developer
- SpecialKeys function: callback processing for SpecialKeys
- KeyPressFunc: Callback handling for the space bar
- DrawWireFrameBatch: Used for filling and border drawing of stereo graphics
Three of these functions are mainly explained
ChangeSize function
In the previous demo, changeSize is mainly used to set the viewport size and call when the viewport changes. In this case, the projection matrix is used to draw the stereo graphics. Therefore, setting the projection matrix in this function mainly involves the following steps
- Set the image projection method: because it is stereoscopic graphics, so choose perspective projection
// Param 1: vertical field of view // Param 2: aspect ratio of viewport = W /h // Param 3: near clipping surface distance // Param 4: Vertical field of view // Param 2: aspect ratio of viewport = W /h // Param 3: near clipping surface distance // Param 4: Vertical field of view Cutting surface distance viewFrustum. SetPerspective (35.0 f, float (w)/float (h), 1.0 f, 500.0 f);Copy the code
- Obtain the projection matrix by the set projection mode and store it in the projection matrix
projectionMatrix.LoadMatrix(viewFrustum.GetProjectionMatrix());
Copy the code
- Initializes the model view matrix stack and pushes in a cell matrix
modelViewMatrix.LoadIdentity();
Copy the code
SetupRC function
As you can see from the flow chart, in addition to the basic background color Settings, storage shader initialization and vertex data creation and transfer, there are also some Settings for the matrix and observer
- Put the model view matrix and projection matrix into the transformation pipeline. The function of the transformation pipeline is to help quickly multiply the matrices. In the RenderScene function, the corresponding matrices can be obtained directly through the Get method of the transformation pipeline
transformPipeline.SetMatrixStacks(modelViewMatrix, projectionMatrix);
Copy the code
Among them, there are four matrices that can be obtained by transformation pipeline through GET
methods | instructions |
---|---|
GetProjectionMatrix() | Projection matrix |
GetNormalMatrix() | The normal matrix |
GetModelViewMatrix() | Model view matrix, mv for short |
GetModelViewProjectionMatrix() | Model view projection matrix, referred to as MVP |
- Set observer position
CameraFrame. MoveForward (15.0 f);Copy the code
There are three Settings for the observer position
methods | instructions |
---|---|
void MoveForward(float fDelta) | To move pixels outward, modify z |
void MoveUp(float fDelta) | Move the pixels up and change y |
void MoveRight(float fDelta) | Move the pixels to the right and modify x |
RenderScene function
The process is shown below, mainly the rendering process of three-dimensional graphics
As can be seen from the flow chart, this process is a process of converting object coordinates into clipping coordinates, and then converting them into NDC after OpenGL processing, and displaying them on the screen. The stack changes during this process as shown below
- The ChangeSize function initializes a cell matrix into the stack
- The RenderScene function pushes a cell matrix onto the stack again: this is mainly to restore the matrix after the graph is drawn, so there are two cell matrices on the stack
modelViewMatrix.PushMatrix();
Copy the code
- The cameraFrame is constructed as the observer matrix, the top element matrix is taken out and multiplied by the observer matrix to obtain a new observer matrix, and then pushed onto the stack
M3DMatrix44f mCamera;
cameraFrame.GetCameraMatrix(mCamera);
modelViewMatrix.MultMatrix(mCamera);
Copy the code
- Construct the objectFrame as the object matrix, take the observer matrix at the top of the stack, multiply it by the object matrix, get the model view matrix, and push it onto the stack
- Then the fixed pipeline is used to render the graph. After the image rendering is completed, pop the model view matrix in the stack to restore its initial state.
/ * * GetProjectionMatrix GetNormalMatrix normal matrix projection matrix GetModelViewMatrix GetModelViewProjectionMatrix model view matrix model view projection matrix * /Copy the code
See Github 04_OpenGL dots/lines for details…
Finally, a solution diagram of vertex coordinates (x, y) in a circle is attached
Supplement: graphic on the drawing of the border details see case 03 supplement: pyramid and other graphics such as the drawing of the border