glfw/tests/gamma.c

177 lines
5.4 KiB
C
Raw Permalink Normal View History

//========================================================================
// Gamma correction test program
2016-11-21 16:23:59 +01:00
// Copyright (c) Camilla Löwy <elmindreda@glfw.org>
//
// This software is provided 'as-is', without any express or implied
// warranty. In no event will the authors be held liable for any damages
// arising from the use of this software.
//
// Permission is granted to anyone to use this software for any purpose,
// including commercial applications, and to alter it and redistribute it
// freely, subject to the following restrictions:
//
// 1. The origin of this software must not be misrepresented; you must not
// claim that you wrote the original software. If you use this software
// in a product, an acknowledgment in the product documentation would
// be appreciated but is not required.
//
// 2. Altered source versions must be plainly marked as such, and must not
// be misrepresented as being the original software.
//
// 3. This notice may not be removed or altered from any source
// distribution.
//
//========================================================================
//
// This program is used to test the gamma correction functionality for
2015-01-05 21:55:15 +01:00
// both full screen and windowed mode windows
//
//========================================================================
2015-10-14 03:11:20 +02:00
#include <glad/glad.h>
#include <GLFW/glfw3.h>
2016-09-26 14:57:03 +02:00
#define NK_IMPLEMENTATION
#define NK_INCLUDE_FIXED_TYPES
#define NK_INCLUDE_FONT_BAKING
#define NK_INCLUDE_DEFAULT_FONT
#define NK_INCLUDE_DEFAULT_ALLOCATOR
#define NK_INCLUDE_VERTEX_BUFFER_OUTPUT
#define NK_INCLUDE_STANDARD_VARARGS
2017-11-26 22:12:41 +01:00
#define NK_BUTTON_TRIGGER_ON_RELEASE
2016-09-26 14:57:03 +02:00
#include <nuklear.h>
#define NK_GLFW_GL2_IMPLEMENTATION
#include <nuklear_glfw_gl2.h>
#include <stdio.h>
#include <stdlib.h>
2017-11-28 14:20:54 +01:00
#include <string.h>
static void error_callback(int error, const char* description)
{
fprintf(stderr, "Error: %s\n", description);
}
2013-05-30 17:19:12 +02:00
static void key_callback(GLFWwindow* window, int key, int scancode, int action, int mods)
{
2016-09-26 14:57:03 +02:00
if (action == GLFW_PRESS && key == GLFW_KEY_ESCAPE)
glfwSetWindowShouldClose(window, GLFW_TRUE);
}
2016-09-26 14:57:03 +02:00
static void chart_ramp_array(struct nk_context* nk,
struct nk_color color,
int count, unsigned short int* values)
{
if (nk_chart_begin_colored(nk, NK_CHART_LINES,
color, nk_rgb(255, 255, 255),
count, 0, 65535))
{
2016-09-26 14:57:03 +02:00
int i;
for (i = 0; i < count; i++)
2012-02-07 02:29:02 +01:00
{
2016-09-26 14:57:03 +02:00
char buffer[1024];
if (nk_chart_push(nk, values[i]))
{
snprintf(buffer, sizeof(buffer), "#%u: %u (%0.5f) ",
i, values[i], values[i] / 65535.f);
nk_tooltip(nk, buffer);
}
2012-02-07 02:29:02 +01:00
}
2016-09-26 14:57:03 +02:00
nk_chart_end(nk);
}
}
int main(int argc, char** argv)
{
GLFWmonitor* monitor = NULL;
GLFWwindow* window;
2017-11-26 22:12:41 +01:00
GLFWgammaramp orig_ramp;
2016-09-26 14:57:03 +02:00
struct nk_context* nk;
struct nk_font_atlas* atlas;
float gamma_value = 1.f;
glfwSetErrorCallback(error_callback);
if (!glfwInit())
exit(EXIT_FAILURE);
2016-09-26 14:57:03 +02:00
monitor = glfwGetPrimaryMonitor();
2016-09-26 14:57:03 +02:00
window = glfwCreateWindow(800, 400, "Gamma Test", NULL, NULL);
if (!window)
{
glfwTerminate();
exit(EXIT_FAILURE);
}
2017-11-26 22:12:41 +01:00
{
const GLFWgammaramp* ramp = glfwGetGammaRamp(monitor);
const size_t array_size = ramp->size * sizeof(short);
orig_ramp.size = ramp->size;
orig_ramp.red = malloc(array_size);
orig_ramp.green = malloc(array_size);
orig_ramp.blue = malloc(array_size);
memcpy(orig_ramp.red, ramp->red, array_size);
memcpy(orig_ramp.green, ramp->green, array_size);
memcpy(orig_ramp.blue, ramp->blue, array_size);
}
glfwMakeContextCurrent(window);
2015-10-14 03:11:20 +02:00
gladLoadGLLoader((GLADloadproc) glfwGetProcAddress);
glfwSwapInterval(1);
2016-09-26 14:57:03 +02:00
nk = nk_glfw3_init(window, NK_GLFW3_INSTALL_CALLBACKS);
nk_glfw3_font_stash_begin(&atlas);
nk_glfw3_font_stash_end();
2016-09-26 14:57:03 +02:00
glfwSetKeyCallback(window, key_callback);
while (!glfwWindowShouldClose(window))
{
2016-09-26 14:57:03 +02:00
int width, height;
struct nk_rect area;
glfwGetWindowSize(window, &width, &height);
2016-09-26 14:57:03 +02:00
area = nk_rect(0.f, 0.f, (float) width, (float) height);
2017-12-17 19:27:27 +01:00
nk_window_set_bounds(nk, "", area);
2016-09-26 14:57:03 +02:00
glClear(GL_COLOR_BUFFER_BIT);
2016-09-26 14:57:03 +02:00
nk_glfw3_new_frame();
2016-11-27 13:29:07 +01:00
if (nk_begin(nk, "", area, 0))
2016-09-26 14:57:03 +02:00
{
2017-11-26 22:12:41 +01:00
const GLFWgammaramp* ramp;
2016-09-26 14:57:03 +02:00
2017-11-26 22:12:41 +01:00
nk_layout_row_dynamic(nk, 30, 3);
2016-09-26 14:57:03 +02:00
if (nk_slider_float(nk, 0.1f, &gamma_value, 5.f, 0.1f))
glfwSetGamma(monitor, gamma_value);
nk_labelf(nk, NK_TEXT_LEFT, "%0.1f", gamma_value);
2017-11-26 22:12:41 +01:00
if (nk_button_label(nk, "Revert"))
glfwSetGammaRamp(monitor, &orig_ramp);
ramp = glfwGetGammaRamp(monitor);
2016-09-26 14:57:03 +02:00
nk_layout_row_dynamic(nk, height - 60.f, 3);
chart_ramp_array(nk, nk_rgb(255, 0, 0), ramp->size, ramp->red);
chart_ramp_array(nk, nk_rgb(0, 255, 0), ramp->size, ramp->green);
2017-12-18 15:47:49 +01:00
chart_ramp_array(nk, nk_rgb(0, 0, 255), ramp->size, ramp->blue);
2016-09-26 14:57:03 +02:00
}
nk_end(nk);
2017-07-30 14:52:26 +02:00
nk_glfw3_render(NK_ANTI_ALIASING_ON);
glfwSwapBuffers(window);
2016-09-26 14:57:03 +02:00
glfwWaitEventsTimeout(1.0);
}
2017-11-26 22:12:41 +01:00
free(orig_ramp.red);
free(orig_ramp.green);
free(orig_ramp.blue);
2016-09-26 14:57:03 +02:00
nk_glfw3_shutdown();
glfwTerminate();
exit(EXIT_SUCCESS);
}