KiCad PCB EDA Suite
opengl_gal.cpp File Reference
#include <gl_utils.h>
#include <gal/opengl/opengl_gal.h>
#include <gal/opengl/utils.h>
#include <gal/definitions.h>
#include <gl_context_mgr.h>
#include <geometry/shape_poly_set.h>
#include <bitmap_base.h>
#include <bezier_curves.h>
#include <math/util.h>
#include <macros.h>
#include <functional>
#include <limits>
#include <memory>
#include "gl_resources.h"
#include "gl_builtin_shaders.h"

Go to the source code of this file.

Classes

class  KIGFX::GL_BITMAP_CACHE
 
struct  KIGFX::GL_BITMAP_CACHE::CACHED_BITMAP
 

Namespaces

 KIGFX
 Class CAIRO_GAL is the cairo implementation of the graphics abstraction layer.
 

Macros

#define DISABLE_BITMAP_CACHE
 

Functions

static void InitTesselatorCallbacks (GLUtesselator *aTesselator)
 
void CALLBACK VertexCallback (GLvoid *aVertexPtr, void *aData)
 
void CALLBACK CombineCallback (GLdouble coords[3], GLdouble *vertex_data[4], GLfloat weight[4], GLdouble **dataOut, void *aData)
 
void CALLBACK EdgeCallback (GLboolean aEdgeFlag)
 
void CALLBACK ErrorCallback (GLenum aErrorCode)
 
static double roundr (double f, double r)
 

Variables

static const int glAttributes [] = { WX_GL_RGBA, WX_GL_DOUBLEBUFFER, WX_GL_DEPTH_SIZE, 8, 0 }
 

Macro Definition Documentation

◆ DISABLE_BITMAP_CACHE

#define DISABLE_BITMAP_CACHE

Definition at line 67 of file opengl_gal.cpp.

Function Documentation

◆ CombineCallback()

void CALLBACK CombineCallback ( GLdouble  coords[3],
GLdouble *  vertex_data[4],
GLfloat  weight[4],
GLdouble **  dataOut,
void *  aData 
)

Definition at line 2072 of file opengl_gal.cpp.

2075 {
2076  GLdouble* vertex = new GLdouble[3];
2077  OPENGL_GAL::TessParams* param = static_cast<OPENGL_GAL::TessParams*>( aData );
2078 
2079  // Save the pointer so we can delete it later
2080  param->intersectPoints.emplace_back( vertex );
2081 
2082  memcpy( vertex, coords, 3 * sizeof(GLdouble) );
2083 
2084  *dataOut = vertex;
2085 }
std::deque< boost::shared_array< GLdouble > > & intersectPoints
Intersect points, that have to be freed after tessellation.
Definition: opengl_gal.h:276

References KIGFX::OPENGL_GAL::TessParams::intersectPoints.

Referenced by InitTesselatorCallbacks().

◆ EdgeCallback()

void CALLBACK EdgeCallback ( GLboolean  aEdgeFlag)

Definition at line 2088 of file opengl_gal.cpp.

2089 {
2090  // This callback is needed to force GLU tesselator to use triangles only
2091 }

Referenced by InitTesselatorCallbacks().

◆ ErrorCallback()

void CALLBACK ErrorCallback ( GLenum  aErrorCode)

Definition at line 2094 of file opengl_gal.cpp.

2095 {
2096  //throw std::runtime_error( std::string( "Tessellation error: " ) +
2097  //std::string( (const char*) gluErrorString( aErrorCode ) );
2098 }

Referenced by InitTesselatorCallbacks().

◆ InitTesselatorCallbacks()

static void InitTesselatorCallbacks ( GLUtesselator *  aTesselator)
static

Definition at line 2101 of file opengl_gal.cpp.

2102 {
2103  gluTessCallback( aTesselator, GLU_TESS_VERTEX_DATA, ( void (CALLBACK*)() )VertexCallback );
2104  gluTessCallback( aTesselator, GLU_TESS_COMBINE_DATA, ( void (CALLBACK*)() )CombineCallback );
2105  gluTessCallback( aTesselator, GLU_TESS_EDGE_FLAG, ( void (CALLBACK*)() )EdgeCallback );
2106  gluTessCallback( aTesselator, GLU_TESS_ERROR, ( void (CALLBACK*)() )ErrorCallback );
2107 }
void CALLBACK EdgeCallback(GLboolean aEdgeFlag)
void CALLBACK VertexCallback(GLvoid *aVertexPtr, void *aData)
void CALLBACK ErrorCallback(GLenum aErrorCode)
void CALLBACK CombineCallback(GLdouble coords[3], GLdouble *vertex_data[4], GLfloat weight[4], GLdouble **dataOut, void *aData)
#define CALLBACK
Definition: opengl_gal.h:48

References CALLBACK, CombineCallback(), EdgeCallback(), ErrorCallback(), and VertexCallback().

Referenced by KIGFX::OPENGL_GAL::OPENGL_GAL().

◆ roundr()

static double roundr ( double  f,
double  r 
)
static

Definition at line 2117 of file opengl_gal.cpp.

2118 {
2119  return floor(f / r + 0.5) * r;
2120 }

Referenced by KIGFX::OPENGL_GAL::ComputeWorldScreenMatrix().

◆ VertexCallback()

void CALLBACK VertexCallback ( GLvoid *  aVertexPtr,
void *  aData 
)

Definition at line 2061 of file opengl_gal.cpp.

2062 {
2063  GLdouble* vertex = static_cast<GLdouble*>( aVertexPtr );
2064  OPENGL_GAL::TessParams* param = static_cast<OPENGL_GAL::TessParams*>( aData );
2065  VERTEX_MANAGER* vboManager = param->vboManager;
2066 
2067  assert( vboManager );
2068  vboManager->Vertex( vertex[0], vertex[1], vertex[2] );
2069 }
bool Vertex(const VERTEX &aVertex)
Function Vertex() adds a vertex with the given coordinates to the currently set item.
VERTEX_MANAGER * vboManager
Manager used for storing new vertices.
Definition: opengl_gal.h:273

References KIGFX::OPENGL_GAL::TessParams::vboManager, and KIGFX::VERTEX_MANAGER::Vertex().

Referenced by InitTesselatorCallbacks().

Variable Documentation

◆ glAttributes

const int glAttributes[] = { WX_GL_RGBA, WX_GL_DOUBLEBUFFER, WX_GL_DEPTH_SIZE, 8, 0 }
static

Definition at line 76 of file opengl_gal.cpp.