CG_Labs 2021.2
Loading...
Searching...
No Matches
Classes | Namespaces | Typedefs | Enumerations | Functions
helpers.hpp File Reference
#include <glad/glad.h>
#include <GLFW/glfw3.h>
#include <glm/glm.hpp>
#include "core/FPSCamera.h"
#include <functional>
#include <string>
#include <vector>
#include <unordered_map>

Go to the source code of this file.

Classes

struct  bonobo::material_data
 
struct  bonobo::mesh_data
 Contains the data for a mesh in OpenGL. More...
 

Namespaces

namespace  bonobo
 Namespace containing a few helpers for the LUGG computer graphics labs.
 

Typedefs

using bonobo::texture_bindings = std::unordered_map< std::string, GLuint >
 Association of a sampler name used in GLSL to a corresponding texture ID.
 

Enumerations

enum class  bonobo::shader_bindings : unsigned int {
  bonobo::vertices = 0u , bonobo::normals , bonobo::texcoords , bonobo::tangents ,
  bonobo::binormals
}
 Formalise mapping between an OpenGL VAO attribute binding, and the meaning of that attribute. More...
 
enum class  bonobo::cull_mode_t : unsigned int { bonobo::disabled = 0u , bonobo::back_faces , bonobo::front_faces }
 
enum class  bonobo::polygon_mode_t : unsigned int { bonobo::fill = 0u , bonobo::line , bonobo::point }
 

Functions

void bonobo::init ()
 Allocate some objects needed by some helper functions.
 
void bonobo::deinit ()
 Deallocate objects allocated by the init() function.
 
std::vector< mesh_databonobo::loadObjects (std::string const &filename)
 Load objects found in an object/scene file, using assimp.
 
GLuint bonobo::createTexture (uint32_t width, uint32_t height, GLenum target=GL_TEXTURE_2D, GLint internal_format=GL_RGBA, GLenum format=GL_RGBA, GLenum type=GL_UNSIGNED_BYTE, GLvoid const *data=nullptr)
 Creates an OpenGL texture without any content nor parameters.
 
GLuint bonobo::loadTexture2D (std::string const &filename, bool generate_mipmap=true)
 Load an image into an OpenGL 2D-texture.
 
GLuint bonobo::loadTextureCubeMap (std::string const &posx, std::string const &negx, std::string const &posy, std::string const &negy, std::string const &posz, std::string const &negz, bool generate_mipmap=true)
 Load six images into an OpenGL cubemap-texture.
 
GLuint bonobo::createProgram (std::string const &vert_shader_source_path, std::string const &frag_shader_source_path)
 Create an OpenGL program consisting of a vertex and a fragment shader.
 
void bonobo::displayTexture (glm::vec2 const &lower_left, glm::vec2 const &upper_right, GLuint texture, GLuint sampler, glm::ivec4 const &swizzle, glm::ivec2 const &window_size, bool linearise=false, float nearPlane=0.0f, float farPlane=0.0f)
 Display the current texture in the specified rectangle.
 
GLuint bonobo::createFBO (std::vector< GLuint > const &color_attachments, GLuint depth_attachment=0u)
 Create an OpenGL FrameBuffer Object using the specified attachments.
 
GLuint bonobo::createSampler (std::function< void(GLuint)> const &setup)
 Create an OpenGL sampler and set it up.
 
void bonobo::drawFullscreen ()
 Draw full screen.
 
GLuint bonobo::getDebugTextureID ()
 Retrieve the ID of a small placeholder texture.
 
void bonobo::renderBasis (float thickness_scale, float length_scale, glm::mat4 const &view_projection, glm::mat4 const &world=glm::mat4(1.0f))
 Render a right-hand orthonormal basis.
 
bool bonobo::uiSelectCullMode (std::string const &label, enum cull_mode_t &cull_mode) noexcept
 Add a combo box to the current ImGUI window, to choose a cull mode.
 
void bonobo::changeCullMode (enum cull_mode_t const cull_mode) noexcept
 Enable or disable culling, and call glCullFace with the specified cull mode.
 
bool bonobo::uiSelectPolygonMode (std::string const &label, enum polygon_mode_t &polygon_mode) noexcept
 Add a combo box to the current ImGUI window, to choose a polygon mode.
 
void bonobo::changePolygonMode (enum polygon_mode_t const polygon_mode) noexcept
 Call glPolygonMode for both front and back faces, with the specified polygon mode.