gamma.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. //========================================================================
  2. // Gamma correction test program
  3. // Copyright (c) Camilla Löwy <elmindreda@glfw.org>
  4. //
  5. // This software is provided 'as-is', without any express or implied
  6. // warranty. In no event will the authors be held liable for any damages
  7. // arising from the use of this software.
  8. //
  9. // Permission is granted to anyone to use this software for any purpose,
  10. // including commercial applications, and to alter it and redistribute it
  11. // freely, subject to the following restrictions:
  12. //
  13. // 1. The origin of this software must not be misrepresented; you must not
  14. // claim that you wrote the original software. If you use this software
  15. // in a product, an acknowledgment in the product documentation would
  16. // be appreciated but is not required.
  17. //
  18. // 2. Altered source versions must be plainly marked as such, and must not
  19. // be misrepresented as being the original software.
  20. //
  21. // 3. This notice may not be removed or altered from any source
  22. // distribution.
  23. //
  24. //========================================================================
  25. //
  26. // This program is used to test the gamma correction functionality for
  27. // both full screen and windowed mode windows
  28. //
  29. //========================================================================
  30. #include <glad/gl.h>
  31. #define GLFW_INCLUDE_NONE
  32. #include <GLFW/glfw3.h>
  33. #define NK_IMPLEMENTATION
  34. #define NK_INCLUDE_FIXED_TYPES
  35. #define NK_INCLUDE_FONT_BAKING
  36. #define NK_INCLUDE_DEFAULT_FONT
  37. #define NK_INCLUDE_DEFAULT_ALLOCATOR
  38. #define NK_INCLUDE_VERTEX_BUFFER_OUTPUT
  39. #define NK_INCLUDE_STANDARD_VARARGS
  40. #define NK_BUTTON_TRIGGER_ON_RELEASE
  41. #include <nuklear.h>
  42. #define NK_GLFW_GL2_IMPLEMENTATION
  43. #include <nuklear_glfw_gl2.h>
  44. #include <stdio.h>
  45. #include <stdlib.h>
  46. #include <string.h>
  47. static void error_callback(int error, const char* description)
  48. {
  49. fprintf(stderr, "Error: %s\n", description);
  50. }
  51. static void key_callback(GLFWwindow* window, int key, int scancode, int action, int mods)
  52. {
  53. if (action == GLFW_PRESS && key == GLFW_KEY_ESCAPE)
  54. glfwSetWindowShouldClose(window, GLFW_TRUE);
  55. }
  56. static void chart_ramp_array(struct nk_context* nk,
  57. struct nk_color color,
  58. int count, unsigned short int* values)
  59. {
  60. if (nk_chart_begin_colored(nk, NK_CHART_LINES,
  61. color, nk_rgb(255, 255, 255),
  62. count, 0, 65535))
  63. {
  64. int i;
  65. for (i = 0; i < count; i++)
  66. {
  67. char buffer[1024];
  68. if (nk_chart_push(nk, values[i]))
  69. {
  70. snprintf(buffer, sizeof(buffer), "#%u: %u (%0.5f) ",
  71. i, values[i], values[i] / 65535.f);
  72. nk_tooltip(nk, buffer);
  73. }
  74. }
  75. nk_chart_end(nk);
  76. }
  77. }
  78. int main(int argc, char** argv)
  79. {
  80. GLFWmonitor* monitor = NULL;
  81. GLFWwindow* window;
  82. GLFWgammaramp orig_ramp;
  83. struct nk_context* nk;
  84. struct nk_font_atlas* atlas;
  85. float gamma_value = 1.f;
  86. glfwSetErrorCallback(error_callback);
  87. if (!glfwInit())
  88. exit(EXIT_FAILURE);
  89. monitor = glfwGetPrimaryMonitor();
  90. glfwWindowHint(GLFW_SCALE_TO_MONITOR, GLFW_TRUE);
  91. window = glfwCreateWindow(800, 400, "Gamma Test", NULL, NULL);
  92. if (!window)
  93. {
  94. glfwTerminate();
  95. exit(EXIT_FAILURE);
  96. }
  97. {
  98. const GLFWgammaramp* ramp = glfwGetGammaRamp(monitor);
  99. const size_t array_size = ramp->size * sizeof(short);
  100. orig_ramp.size = ramp->size;
  101. orig_ramp.red = malloc(array_size);
  102. orig_ramp.green = malloc(array_size);
  103. orig_ramp.blue = malloc(array_size);
  104. memcpy(orig_ramp.red, ramp->red, array_size);
  105. memcpy(orig_ramp.green, ramp->green, array_size);
  106. memcpy(orig_ramp.blue, ramp->blue, array_size);
  107. }
  108. glfwMakeContextCurrent(window);
  109. gladLoadGL(glfwGetProcAddress);
  110. glfwSwapInterval(1);
  111. nk = nk_glfw3_init(window, NK_GLFW3_INSTALL_CALLBACKS);
  112. nk_glfw3_font_stash_begin(&atlas);
  113. nk_glfw3_font_stash_end();
  114. glfwSetKeyCallback(window, key_callback);
  115. while (!glfwWindowShouldClose(window))
  116. {
  117. int width, height;
  118. struct nk_rect area;
  119. glfwGetWindowSize(window, &width, &height);
  120. area = nk_rect(0.f, 0.f, (float) width, (float) height);
  121. nk_window_set_bounds(nk, "", area);
  122. glClear(GL_COLOR_BUFFER_BIT);
  123. nk_glfw3_new_frame();
  124. if (nk_begin(nk, "", area, 0))
  125. {
  126. const GLFWgammaramp* ramp;
  127. nk_layout_row_dynamic(nk, 30, 3);
  128. if (nk_slider_float(nk, 0.1f, &gamma_value, 5.f, 0.1f))
  129. glfwSetGamma(monitor, gamma_value);
  130. nk_labelf(nk, NK_TEXT_LEFT, "%0.1f", gamma_value);
  131. if (nk_button_label(nk, "Revert"))
  132. glfwSetGammaRamp(monitor, &orig_ramp);
  133. ramp = glfwGetGammaRamp(monitor);
  134. nk_layout_row_dynamic(nk, height - 60.f, 3);
  135. chart_ramp_array(nk, nk_rgb(255, 0, 0), ramp->size, ramp->red);
  136. chart_ramp_array(nk, nk_rgb(0, 255, 0), ramp->size, ramp->green);
  137. chart_ramp_array(nk, nk_rgb(0, 0, 255), ramp->size, ramp->blue);
  138. }
  139. nk_end(nk);
  140. nk_glfw3_render(NK_ANTI_ALIASING_ON);
  141. glfwSwapBuffers(window);
  142. glfwWaitEventsTimeout(1.0);
  143. }
  144. free(orig_ramp.red);
  145. free(orig_ramp.green);
  146. free(orig_ramp.blue);
  147. nk_glfw3_shutdown();
  148. glfwTerminate();
  149. exit(EXIT_SUCCESS);
  150. }