gpu.1.py 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. """
  2. Geometry Batches
  3. ++++++++++++++++
  4. Geometry is drawn in batches.
  5. A batch contains the necessary data to perform the drawing.
  6. That includes an obligatory *Vertex Buffer* and an optional *Index Buffer*,
  7. each of which is described in more detail in the following sections.
  8. A batch also defines a draw type.
  9. Typical draw types are `POINTS`, `LINES` and `TRIS`.
  10. The draw type determines how the data will be interpreted and drawn.
  11. Vertex Buffers
  12. ++++++++++++++
  13. A *Vertex Buffer Object* (VBO) (:class:`gpu.types.GPUVertBuf`)
  14. is an array that contains the vertex attributes needed for drawing using a specific shader.
  15. Typical vertex attributes are *location*, *normal*, *color*, and *uv*.
  16. Every vertex buffer has a *Vertex Format* (:class:`gpu.types.GPUVertFormat`)
  17. and a length corresponding to the number of vertices in the buffer.
  18. A vertex format describes the attributes stored per vertex and their types.
  19. The following code demonstrates the creation of a vertex buffer that contains 6 vertices.
  20. For each vertex 2 attributes will be stored: The position and the normal.
  21. .. code-block:: python
  22. import gpu
  23. vertex_positions = [(0, 0, 0), ...]
  24. vertex_normals = [(0, 0, 1), ...]
  25. fmt = gpu.types.GPUVertFormat()
  26. fmt.attr_add(id="pos", comp_type='F32', len=3, fetch_mode='FLOAT')
  27. fmt.attr_add(id="normal", comp_type='F32', len=3, fetch_mode='FLOAT')
  28. vbo = gpu.types.GPUVertBuf(len=6, format=fmt)
  29. vbo.attr_fill(id="pos", data=vertex_positions)
  30. vbo.attr_fill(id="normal", data=vertex_normals)
  31. This vertex buffer could be used to draw 6 points, 3 separate lines, 5 consecutive lines, 2 separate triangles, ...
  32. E.g. in the case of lines, each two consecutive vertices define a line.
  33. The type that will actually be drawn is determined when the batch is created later.
  34. Index Buffers
  35. +++++++++++++
  36. Often triangles and lines share one or more vertices.
  37. With only a vertex buffer one would have to store all attributes for the these vertices multiple times.
  38. This is very inefficient because in a connected triangle mesh every vertex is used 6 times on average.
  39. A more efficient approach would be to use an *Index Buffer* (IBO) (:class:`gpu.types.GPUIndexBuf`),
  40. sometimes referred to as *Element Buffer*.
  41. An *Index Buffer* is an array that references vertices based on their index in the vertex buffer.
  42. For instance, to draw a rectangle composed of two triangles, one could use an index buffer.
  43. .. code-block:: python
  44. positions = (
  45. (-1, 1), (1, 1),
  46. (-1, -1), (1, -1))
  47. indices = ((0, 1, 2), (2, 1, 3))
  48. ibo = gpu.types.GPUIndexBuf(type='TRIS', seq=indices)
  49. Here the first tuple in `indices` describes which vertices should be used for the first triangle
  50. (same for the second tuple).
  51. Note how the diagonal vertices 1 and 2 are shared between both triangles.
  52. Shaders
  53. +++++++
  54. A shader is a program that runs on the GPU (written in GLSL in our case).
  55. There are multiple types of shaders.
  56. The most important ones are *Vertex Shaders* and *Fragment Shaders*.
  57. Typically multiple shaders are linked together into a *Program*.
  58. However, in the Blender Python API the term *Shader* refers to an OpenGL Program.
  59. Every :class:`gpu.types.GPUShader` consists of a vertex shader, a fragment shader and an optional geometry shader.
  60. For common drawing tasks there are some built-in shaders accessible from :class:`gpu.shader.from_builtin`
  61. with an identifier such as `2D_UNIFORM_COLOR` or `3D_FLAT_COLOR`.
  62. Every shader defines a set of attributes and uniforms that have to be set in order to use the shader.
  63. Attributes are properties that are set using a vertex buffer and can be different for individual vertices.
  64. Uniforms are properties that are constant per draw call.
  65. They can be set using the `shader.uniform_*` functions after the shader has been bound.
  66. Batch Creation
  67. ++++++++++++++
  68. Batches can be creates by first manually creating VBOs and IBOs.
  69. However, it is recommended to use the :class:`gpu_extras.batch.batch_for_shader` function.
  70. It makes sure that all the vertex attributes necessary for a specific shader are provided.
  71. Consequently, the shader has to be passed to the function as well.
  72. When using this function one rarely has to care about the vertex format, VBOs and IBOs created in the background.
  73. This is still something one should know when drawing stuff though.
  74. Since batches can be drawn multiple times, they should be cached and reused whenever possible.
  75. Offscreen Rendering
  76. +++++++++++++++++++
  77. What one can see on the screen after rendering is called the *Front Buffer*.
  78. When draw calls are issued, batches are drawn on a *Back Buffer* that will only be displayed
  79. when all drawing is done and the current back buffer will become the new front buffer.
  80. Sometimes, one might want to draw the batches into a distinct buffer that could be used as
  81. texture to display on another object or to be saved as image on disk.
  82. This is called Offscreen Rendering.
  83. In Blender Offscreen Rendering is done using the :class:`gpu.types.GPUOffScreen` type.
  84. .. warning::
  85. `GPUOffScreen` objects are bound to the OpenGL context they have been created in.
  86. This means that once Blender discards this context (i.e. the window is closed),
  87. the offscreen instance will be freed.
  88. Examples
  89. ++++++++
  90. To try these examples, just copy them into Blenders text editor and execute them.
  91. To keep the examples relatively small, they just register a draw function that can't easily be removed anymore.
  92. Blender has to be restarted in order to delete the draw handlers.
  93. """