2023-01-23 18:52:57 +01:00
|
|
|
/*
|
|
|
|
* Gem-graph OpenGL experiments
|
|
|
|
*
|
|
|
|
* Desc: OpenGL utils header
|
|
|
|
*
|
|
|
|
* Copyright (C) 2023 Arthur Menges <arthur.menges@a-lec.org>
|
|
|
|
* Copyright (C) 2023 Adrien Bourmault <neox@a-lec.org>
|
|
|
|
*
|
|
|
|
* This file is part of Gem-graph.
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#include <unistd.h>
|
2023-02-23 19:51:02 +01:00
|
|
|
#include <stdbool.h>
|
2023-01-23 18:52:57 +01:00
|
|
|
#include <GL/glu.h>
|
|
|
|
|
2023-02-23 19:51:02 +01:00
|
|
|
/*
|
|
|
|
* Structure describing a gl_area and its parameters, used to create a table
|
|
|
|
* of Gem-graph client current gl_areas
|
|
|
|
*/
|
|
|
|
struct gl_area_entry {
|
2023-02-26 14:57:50 +01:00
|
|
|
char name[16];
|
2023-02-23 19:51:02 +01:00
|
|
|
GLuint vao;
|
|
|
|
GLuint position_buffer;
|
|
|
|
GLuint color_buffer;
|
|
|
|
GLuint program;
|
|
|
|
GLuint m;
|
|
|
|
GLuint v;
|
|
|
|
GLuint p;
|
|
|
|
GLuint indices_nb;
|
|
|
|
};
|
2023-01-23 18:52:57 +01:00
|
|
|
|
2023-02-23 19:51:02 +01:00
|
|
|
/*
|
|
|
|
* Initializes a gl_area
|
|
|
|
*
|
|
|
|
* @param gl_area, ptr to the gl_area widget
|
|
|
|
*
|
|
|
|
* @return true if initialized
|
|
|
|
*/
|
2023-02-26 14:57:50 +01:00
|
|
|
bool graphics_init(const char *gl_area);
|
2023-01-23 18:52:57 +01:00
|
|
|
|
2023-02-23 19:51:02 +01:00
|
|
|
/*
|
|
|
|
* Draws the current buffer to a gl_area
|
|
|
|
*
|
|
|
|
* @param gl_area, ptr to the gl_area widget
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2023-02-26 14:57:50 +01:00
|
|
|
void graphics_draw(const void *gl_area);
|
2023-01-23 18:52:57 +01:00
|
|
|
|
2023-02-23 19:51:02 +01:00
|
|
|
/*
|
|
|
|
* Shutdowns a gl_area
|
|
|
|
*
|
|
|
|
* @param gl_area, ptr to the gl_area widget
|
|
|
|
*
|
|
|
|
* @return true if success
|
|
|
|
*/
|
2023-02-26 14:57:50 +01:00
|
|
|
bool graphics_shutdown(const void *gl_area);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Initializes the shaders of a gl_area and link them to a program
|
|
|
|
*
|
|
|
|
* @param gl_area, ptr to the gl_area widget
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @return true if initialized
|
|
|
|
*/
|
|
|
|
bool graphics_init_shaders(const void *gl_area);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Initializes the buffer of a gl_area
|
|
|
|
*
|
|
|
|
* @param gl_area, ptr to the gl_area widget
|
|
|
|
*
|
|
|
|
* Note : indices[] is defined in graphics_cube.h
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
void graphics_init_buffers(const void *gl_area);
|