Just to mention, the alternative for fast blurs using mips is a summed area table (SAT). I can explain with 1D example of 8 pixels. Say we have brightness value per pixel:
0,0,0,3,2,1,0,0
Next we do a prefix sum (adding the next value to the former sum):
0,0,0,3,5,6,6,6
Once we have this, we can look up an averaged range of any kernel size. Say we want the average from pixels 3 to 5, expecting an average of (0+3+2) / 3 pixels = 1.66:
0,0,[0,3,2],1,0,0
We can get this by looking up the start and end points of our range:
0,0,0,3,5,6,6,6
^ ^
range_size = 4-2 (looked up array indices)
range_sum = 5-0 (sums from the prefix sum array at those indices)
average = range_sum / range_size = 5 / 3 = 1.66
This also works with higher dimensions. The downside is it only supports rectangular kernels, and weighting isn't possible. Mips method is much more flexible and usually preferred. But good to know, especially because prefix sums can be calculated quickly with parallel algorithms (compute shaders).
taby said: I am trying this, but it refuses to accumulate:
Meaning, result is the same as with ignoring last_frame_glowmap_tex? If so, likely something is wrong on API side with managing the textures.
But anyway, instead of sampling both textures in inner loop, you should add the two textures together before that. Then you need to sample only one texture, and later you can extend such texture addition with making mips etc.
I guess you mean to do a temporal blur effect that smooths changes over time, so that lights leave trails in the image? Like this:
This can be implemented by having 2 “history” textures that are persistent across frames. You read from one, and write to the other, then switch on the next frame. On each frame, you want to do a linear combination mix() of the current history texture with the input image. The interpolation factor controls how fast or slow the response time is. This is also known as Exponential Smoothing.
OK, I have two history textures, but I'm not sure if I'm doing this right.
I generate the textures, which are global variables, so that they retain their data between frames: