gamma.frag 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. ** Copyright (c) 2012, Romain Dura romain@shazbits.com
  3. **
  4. ** Permission to use, copy, modify, and/or distribute this software for any
  5. ** purpose with or without fee is hereby granted, provided that the above
  6. ** copyright notice and this permission notice appear in all copies.
  7. **
  8. ** THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. ** WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. ** MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
  11. ** SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. ** WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. ** ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
  14. ** IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. /*
  17. ** Gamma correction
  18. ** Details: http://blog.mouaif.org/2009/01/22/photoshop-gamma-correction-shader/
  19. */
  20. /*
  21. ** 2013 adapted for Extended View Toolkit by Marian Weger
  22. */
  23. #extension GL_ARB_texture_rectangle : enable
  24. uniform sampler2DRect tex0;
  25. uniform float gamma;
  26. void main(void)
  27. {
  28. vec2 pos = (gl_TextureMatrix[0] * gl_TexCoord[0]).st;
  29. vec4 color_old = texture2DRect(tex0, vec2(pos.x, pos.y));
  30. vec4 color_new = vec4(pow(color_old.r, 1.0 / gamma), pow(color_old.g, 1.0 / gamma), pow(color_old.b, 1.0 / gamma), color_old.a);
  31. gl_FragColor = color_new;
  32. }