KiCad PCB EDA Suite
opengl_gal.cpp File Reference
#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 <text_utils.h>
#include <bitmap_base.h>
#include <macros.h>
#include <limits>
#include <functional>
#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)
 

Variables

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

Macro Definition Documentation

#define DISABLE_BITMAP_CACHE

Definition at line 57 of file opengl_gal.cpp.

Function Documentation

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

Definition at line 2081 of file opengl_gal.cpp.

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

Referenced by InitTesselatorCallbacks().

2084 {
2085  GLdouble* vertex = new GLdouble[3];
2086  OPENGL_GAL::TessParams* param = static_cast<OPENGL_GAL::TessParams*>( aData );
2087 
2088  // Save the pointer so we can delete it later
2089  param->intersectPoints.push_back( boost::shared_array<GLdouble>( vertex ) );
2090 
2091  memcpy( vertex, coords, 3 * sizeof(GLdouble) );
2092 
2093  *dataOut = vertex;
2094 }
std::deque< boost::shared_array< GLdouble > > & intersectPoints
Intersect points, that have to be freed after tessellation.
Definition: opengl_gal.h:279
void CALLBACK EdgeCallback ( GLboolean  aEdgeFlag)

Definition at line 2097 of file opengl_gal.cpp.

Referenced by InitTesselatorCallbacks().

2098 {
2099  // This callback is needed to force GLU tesselator to use triangles only
2100 }
void CALLBACK ErrorCallback ( GLenum  aErrorCode)

Definition at line 2103 of file opengl_gal.cpp.

Referenced by InitTesselatorCallbacks().

2104 {
2105  //throw std::runtime_error( std::string( "Tessellation error: " ) +
2106  //std::string( (const char*) gluErrorString( aErrorCode ) );
2107 }
static void InitTesselatorCallbacks ( GLUtesselator *  aTesselator)
static

Definition at line 2110 of file opengl_gal.cpp.

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

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

2111 {
2112  gluTessCallback( aTesselator, GLU_TESS_VERTEX_DATA, ( void (CALLBACK*)() )VertexCallback );
2113  gluTessCallback( aTesselator, GLU_TESS_COMBINE_DATA, ( void (CALLBACK*)() )CombineCallback );
2114  gluTessCallback( aTesselator, GLU_TESS_EDGE_FLAG, ( void (CALLBACK*)() )EdgeCallback );
2115  gluTessCallback( aTesselator, GLU_TESS_ERROR, ( void (CALLBACK*)() )ErrorCallback );
2116 }
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
void CALLBACK VertexCallback ( GLvoid *  aVertexPtr,
void *  aData 
)

Definition at line 2070 of file opengl_gal.cpp.

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

Referenced by InitTesselatorCallbacks().

2071 {
2072  GLdouble* vertex = static_cast<GLdouble*>( aVertexPtr );
2073  OPENGL_GAL::TessParams* param = static_cast<OPENGL_GAL::TessParams*>( aData );
2074  VERTEX_MANAGER* vboManager = param->vboManager;
2075 
2076  assert( vboManager );
2077  vboManager->Vertex( vertex[0], vertex[1], vertex[2] );
2078 }
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:276

Variable Documentation

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

Definition at line 66 of file opengl_gal.cpp.