mirror of
https://github.com/glfw/glfw.git
synced 2024-11-14 14:33:52 +00:00
159 lines
4.8 KiB
C
159 lines
4.8 KiB
C
//========================================================================
|
|
// Gamma correction test program
|
|
// Copyright (c) Camilla Berglund <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
|
|
// both full screen and windowed mode windows
|
|
//
|
|
//========================================================================
|
|
|
|
#include <glad/glad.h>
|
|
#include <GLFW/glfw3.h>
|
|
|
|
#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
|
|
#include <nuklear.h>
|
|
|
|
#define NK_GLFW_GL2_IMPLEMENTATION
|
|
#include <nuklear_glfw_gl2.h>
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
|
|
static int windowed_xpos, windowed_ypos, windowed_width, windowed_height;
|
|
|
|
static void error_callback(int error, const char* description)
|
|
{
|
|
fprintf(stderr, "Error: %s\n", description);
|
|
}
|
|
|
|
static void key_callback(GLFWwindow* window, int key, int scancode, int action, int mods)
|
|
{
|
|
if (action == GLFW_PRESS && key == GLFW_KEY_ESCAPE)
|
|
glfwSetWindowShouldClose(window, GLFW_TRUE);
|
|
}
|
|
|
|
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))
|
|
{
|
|
int i;
|
|
for (i = 0; i < count; i++)
|
|
{
|
|
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);
|
|
}
|
|
}
|
|
|
|
nk_chart_end(nk);
|
|
}
|
|
}
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
GLFWmonitor* monitor = NULL;
|
|
GLFWwindow* window;
|
|
struct nk_context* nk;
|
|
struct nk_font_atlas* atlas;
|
|
float gamma_value = 1.f;
|
|
|
|
glfwSetErrorCallback(error_callback);
|
|
|
|
if (!glfwInit())
|
|
exit(EXIT_FAILURE);
|
|
|
|
monitor = glfwGetPrimaryMonitor();
|
|
|
|
window = glfwCreateWindow(800, 400, "Gamma Test", NULL, NULL);
|
|
if (!window)
|
|
{
|
|
glfwTerminate();
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
|
|
glfwMakeContextCurrent(window);
|
|
gladLoadGLLoader((GLADloadproc) glfwGetProcAddress);
|
|
glfwSwapInterval(1);
|
|
|
|
nk = nk_glfw3_init(window, NK_GLFW3_INSTALL_CALLBACKS);
|
|
nk_glfw3_font_stash_begin(&atlas);
|
|
nk_glfw3_font_stash_end();
|
|
|
|
glfwSetKeyCallback(window, key_callback);
|
|
|
|
while (!glfwWindowShouldClose(window))
|
|
{
|
|
int width, height;
|
|
struct nk_panel layout;
|
|
struct nk_rect area;
|
|
|
|
glfwGetWindowSize(window, &width, &height);
|
|
area = nk_rect(0.f, 0.f, (float) width, (float) height);
|
|
|
|
glClear(GL_COLOR_BUFFER_BIT);
|
|
nk_glfw3_new_frame();
|
|
if (nk_begin(nk, &layout, "", area, 0))
|
|
{
|
|
const GLFWgammaramp* ramp = glfwGetGammaRamp(monitor);
|
|
nk_window_set_bounds(nk, area);
|
|
|
|
nk_layout_row_dynamic(nk, 30, 2);
|
|
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);
|
|
nk_layout_row_end(nk);
|
|
|
|
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);
|
|
chart_ramp_array(nk, nk_rgb(0,0, 255), ramp->size, ramp->blue);
|
|
nk_layout_row_end(nk);
|
|
}
|
|
|
|
nk_end(nk);
|
|
nk_glfw3_render(NK_ANTI_ALIASING_ON, 10000, 1000);
|
|
|
|
glfwSwapBuffers(window);
|
|
glfwWaitEventsTimeout(1.0);
|
|
}
|
|
|
|
nk_glfw3_shutdown();
|
|
glfwTerminate();
|
|
exit(EXIT_SUCCESS);
|
|
}
|
|
|