Behavior of uniforms after glUseProgram() and spee

2020-08-26 03:27发布

问题:

How fast is glUseProgram()? Is there anything better (faster)?:

Here are my thoughts:

  1. Use 1 universal shader program, but with many input settings and attributes (settings for each graphics class)
  2. Use more than 1 shader for each graphics class

What state are uniforms in after changing the shader program? Do they save values (for example, values of matrices)?

Here are what I consider the benefits of #1 to be:

  • Doesn't use glUseProgram()

And the benefits of #2:

  • No matrix changes (for example, if class Menu and class Scene3D have different Projection matrices)

回答1:

What of the two options is better largely depends on what those shaders do, how different they are and how many attributes/uniforms you set and how often they are changed. There is no one right answer for all cases.

That said: Keep in mind, there is not only the cost for state changes, but also a shader runtime cost and it is payed per vertex and per fragment. So keeping the complexity of the shader low is always a good idea and a universal shader is more complex than specialised ones.

Minimize state change. If you have objects A, C, E using Program X and B, D, F using Program Y then, all else being equal, render in order ACEBDF, not ABCDEF.

Regarding the last question: Programs retain their state, and thus the values of uniforms, over their lifetime, unless you relink them. But uniforms are per program state, which means that if you have two uniforms with the same name and type in different programs, values won't carry over from one program to another.