- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在我的 Windows 应用程序中使用一些 OpenGL
要激活 gl 扩展功能,应照常执行以下步骤:
以这种方式得到所有需要的地址
PFNGLCOMPILESHADERPROC glCompileShader;glCompileShader=(PFNGLCOMPILESHADERPROC)wglGetProcAddress("glCompileShader");
对吧?
好的。首先,我的窗口中有一个简单的 openGL 功能,我刚刚制作了一个单独的窗口类所有的子类化都在那里完成,所有的函数都在那里进行 openGL 初始化和绘制。在同一个类中,我有一长串函数指针作为类数据成员,因此我可以在这个窗口类中使用它们。对于第 6 步,我创建了一个名为 load_glext_functions() 的单独函数
所以最后我的类看起来像这样(简化):
{民众: 笔刷 刷子背景; HWND hWnd; 高清数据中心 直流电, hDC_offscreen; HGLRC hGLRC; 矩形 客户区; 观点 点; float 网格颜色[3], point_color[3];
GLuint
program_id_default,
program_id_lights,
program_id_grid,
program_id_wireframe,
texture_id_fbo_color_ms,
texture_id_fbo_objectid_ms,
texture_id_fbo_objectid,
texture_id_fbo_depth_ms,
texture_id_fbo_depth,
texture_id_default_white;
bool
wireframe_mode,
alt_pressed;
//GLEXT_PROCEDURES
PFNGLCREATESHADERPROC glCreateShader;
PFNGLATTACHSHADERPROC glAttachShader;
PFNGLSHADERSOURCEPROC glShaderSource;
PFNGLCOMPILESHADERPROC glCompileShader;
PFNGLDELETESHADERPROC glDeleteShader;
PFNGLGETSHADERIVPROC glGetShaderiv;
PFNGLGETSHADERINFOLOGPROC glGetShaderInfoLog;
PFNGLCREATEPROGRAMPROC glCreateProgram;
PFNGLUSEPROGRAMPROC glUseProgram;
PFNGLGETPROGRAMIVPROC glGetProgramiv;
PFNGLGETPROGRAMINFOLOGPROC glGetProgramInfoLog;
//METHODS
Cnerv_window_gl();
~Cnerv_window_gl();
bool init(HINSTANCE hInstance,HWND hParent);
void load_glext_functions();
void draw_mesh(Snerv_viewport_object _display_object);
bool draw_scene();
void draw_viewport();
void create_texture(Cnerv_texture *_texture_handle);
void add_mesh_to_GPU(Cnerv_mesh *mesh_data);
void update_vbo(Cnerv_mesh *_mesh);
void update_texture(Cnerv_texture *_texture_handle);
void init_framebuffer();
void paint();
bool setPFD();
LRESULT CALLBACK wProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam);
static LRESULT CALLBACK wProc_init_gl(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam);
};
load_glext_function() 看起来像这样:
void Cnerv_window_gl::load_glext_functions()
{
glCompileShader=(PFNGLCOMPILESHADERPROC)wglGetProcAddress("glCompileShader");
glAttachShader=(PFNGLATTACHSHADERPROC)wglGetProcAddress("glAttachShader");
glCreateProgram=(PFNGLCREATEPROGRAMPROC)wglGetProcAddress("glCreateProgram");
glCreateShader=(PFNGLCREATESHADERPROC)wglGetProcAddress("glCreateShader");
glEnableVertexAttribArray=(PFNGLENABLEVERTEXATTRIBARRAYPROC)wglGetProcAddress("glEnableVertexAttribArray");
}
只是更长。
所以只要我在一个类中使用这些扩展函数,一切都很好。现在如果我想使用面向对象的风格,我需要为质地帧缓冲区网,等..
并说 Cframebuffer 类应该有它自己的初始化函数,我们应该有 glGenFramebuffers() 这是扩展,这个列表可以继续
class Cframebuffer
{
public:
GLuint fbo_id;
void init()
{
glGenFramebuffers(1,&fbo_id);
}
void delete()
{
glDeleteFramebuffers(fbo_id);
}
};
现在。我真的想把所有这些扩展放在一个单独的类中像这样
class Cgl_extentions
{
public:
static PFNGLCREATESHADERPROC glCreateShader;
static PFNGLATTACHSHADERPROC glAttachShader;
static PFNGLSHADERSOURCEPROC glShaderSource;
static PFNGLCOMPILESHADERPROC glCompileShader;
static init();
}
初始化看起来像这样
void Cgl_extentions::init()
{
glCompileShader=(PFNGLCOMPILESHADERPROC)wglGetProcAddress("glCompileShader");
glAttachShader=(PFNGLATTACHSHADERPROC)wglGetProcAddress("glAttachShader");
glCreateProgram=(PFNGLCREATEPROGRAMPROC)wglGetProcAddress("glCreateProgram");
glCreateShader=(PFNGLCREATESHADERPROC)wglGetProcAddress("glCreateShader");
glEnableVertexAttribArray=(PFNGLENABLEVERTEXATTRIBARRAYPROC)wglGetProcAddress("glEnableVertexAttribArray");
}
然后我只在任何我想使用它的地方包含带有扩展类的标题,并将这个函数作为一个类的静态函数来处理Cgl_extentions::glGenBuffers() ....等
现在我已经完全按照我所描述的去做了,但是我遇到了链接器错误。我试图在我的逻辑中找出一些错误。我做错了什么?
更新:有人建议我在 cpp 文件的开头 checkin 这些函数的符号。它有效。但是这个建议的作者未能解释这个解决方案背后发生的事情。事实上,即使是此类的普通数据成员也需要这种声明,否则它会在链接器中提示错误如果我执行这里注释的一些行是确切的错误字符串
1>Cnerv_GL.obj : error LNK2001: неразрешенный внешний символ ""public: static unsigned int (__cdecl* Cnerv_GL::glCreateShader)(unsigned int)" (?glCreateShader@Cnerv_GL@@2P6AII@ZEA)"
1>Cnerv_window_gl.obj : error LNK2019: ссылка на неразрешенный внешний символ "public: static unsigned int (__cdecl* Cnerv_GL::glCreateShader)(unsigned int)" (?glCreateShader@Cnerv_GL@@2P6AII@ZEA) в функции "public: bool __cdecl Cnerv_window_gl::init(struct HINSTANCE__ *,struct HWND__ *)" (?init@Cnerv_window_gl@@QEAA_NPEAUHINSTANCE__@@PEAUHWND__@@@Z)
1>Cnerv_GL.obj : error LNK2001: неразрешенный внешний символ ""public: static void (__cdecl* Cnerv_GL::glAttachShader)(unsigned int,unsigned int)" (?glAttachShader@Cnerv_GL@@2P6AXII@ZEA)"
1>Cnerv_window_gl.obj : error LNK2019: ссылка на неразрешенный внешний символ "public: static void (__cdecl* Cnerv_GL::glAttachShader)(unsigned int,unsigned int)" (?glAttachShader@Cnerv_GL@@2P6AXII@ZEA) в функции "public: static __int64 __cdecl Cnerv_window_gl::wProc_init_gl(struct HWND__ *,unsigned int,unsigned __int64,__int64)" (?wProc_init_gl@Cnerv_window_gl@@SA_JPEAUHWND__@@I_K_J@Z)
抱歉,它是俄语的,但我认为对于你们这些久经考验的代码老手来说,这不是问题。)
最佳答案
使 GL 函数成为全局函数,至少在您的渲染代码中,或者如果您想要 C++ 化所有内容,则可能将它们放在 GL namespace 中。例如GL::compileShader()
并在加载 GL 库后进行初始化。
将 GL 函数视为任何其他导入库,只是具有非标准导入机制。另请查看 GLEW ,它会让您免于担心此类事情,从而可以专注于您要解决的主要问题。
我认为,无论您的应用程序大小、复杂程度及其架构如何,GL 函数指针都需要在渲染后端具有一定的全局可见性,因为所有 GL 对象类型都使用某些 GL 函数。
如果您想继续自己的道路,您必须提供有关链接器错误的更多信息。
关于c++ - 单独类中的 opengl 扩展函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27635031/
在 OpenGL/ES 中,在实现渲染到纹理功能时,您必须小心,不要引起反馈循环(从正在写入的同一纹理中读取像素)。由于显而易见的原因,当您读取和写入纹理的相同像素时,行为是未定义的。但是,如果您正在
正如我们最终都知道的那样,规范是一回事,实现是另一回事。大多数错误是我们自己造成的,但有时情况并非如此。 我相信列出以下内容会很有用: GPU 驱动程序中当前已知的与最新版本的 OpenGL 和 GL
很难说出这里问的是什么。这个问题是模棱两可的、模糊的、不完整的、过于宽泛的或修辞的,无法以目前的形式得到合理的回答。为了帮助澄清这个问题以便可以重新打开它,visit the help center
我正在学习 OpenGL,非常想知道与显卡的交互如何。 我觉得了解它是如何在图形驱动程序中实现的,会让我了解 opengl 的完整内部结构(通过这个我可以知道哪些阶段/因素影响我对 opengl 性能
我正在尝试绘制到大于屏幕尺寸(即 320x480)的渲染缓冲区 (512x512)。 执行 glReadPixels 后,图像看起来是正确的,除非图像的尺寸超过屏幕尺寸——在本例中,超过 320 水平
我正在 Windows 中制作一个 3D 小行星游戏(使用 OpenGL 和 GLUT),您可以在其中穿过一堆障碍物在太空中移动并生存下来。我正在寻找一种方法来针对无聊的 bg 颜色选项设置图像背景。
如果我想要一个包含 100 个 10*10 像素 Sprite 的 Sprite 表,是否可以将它们全部排成一排来制作 1,000*10 像素纹理?还是 GPU 对不那么窄的纹理表现更好?这对性能有什
这个问题在这里已经有了答案: Rendering 2D sprites in a 3D world? (7 个答案) 关闭 6 年前。 我如何概念化让图像始终面对相机。我尝试将三角函数与 arcta
是否可以在 OpenGL 中增加缓冲区? 假设我想使用实例化渲染。每次在世界上生成一个新对象时,我都必须用实例化数据更新缓冲区。 在这种情况下,我有一个 3 个 float 的缓冲区 std::v
有人可以向我解释为什么下面的代码没有绘制任何东西,但如果我使用 GL_LINE_LOOP 它确实形成了一个闭环吗? glBegin(GL_POLYGON); for(int i = 0; i <= N
正如标题所说,OpenGL 中的渲染目标是什么?我对 OpenGL 很陌生,我看到的所有网站都让我很困惑。 它只是一个缓冲区,我在其中放置稍后将用于渲染的东西吗? 如果您能提供一个很好的引用来阅读它,
当使用 OpenGL 1.4 固定功能多纹理时,每个纹理阶段的输出在传递到下一个阶段之前是否都固定在 [0, 1]? spec说(第 153 页): If the value of TEXTURE_E
我比较了 2 个函数 openGL ES 和 openGL gvec4 texelFetchOffset(gsampler2DArray sampler, ivec3 P, int lod, ivec
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
那么当你调用opengl函数时,比如glDraw或者gLBufferData,是否会导致程序线程停止等待GL完成调用呢? 如果不是,那么 GL 如何处理调用像 glDraw 这样的重要函数,然后立即更
我正在尝试实现级联阴影贴图,当我想访问我的视锥体的每个分区的相应深度纹理时,我遇到了一个错误。 更具体地说,当我想选择正确的阴影纹理时会出现我的问题,如果我尝试下面的代码,我会得到一个像 this 中
我想为OpenGL ES和OpenGL(Windows)使用相同的着色器源。为此,我想定义自定义数据类型并仅使用OpenGL ES函数。 一种方法是定义: #define highp #define
我尝试用 6 个位图映射立方体以实现天空盒效果。我的问题是一个纹理映射到立方体的每个面。我已经检查了 gDEBugger,在立方体纹理内存中我只有一个 图像(因为我尝试加载六个图像)。 代码准备纹理:
在 OpenGL 中偏移深度的最佳方法是什么?我目前每个多边形都有索引顶点属性,我将其传递给 OpenGL 中的顶点着色器。我的目标是在深度上偏移多边形,其中最高索引始终位于较低索引的前面。我目前有这
我是一名优秀的程序员,十分优秀!