- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我不是在尝试流式传输或其他任何东西,我只是想通过将顶点和索引数据直接加载到 OpenGL 的缓冲区而不是必须先将其放入中间缓冲区来加快我的文件加载代码。这是获取指针的代码:
void* VertexArray::beginIndexLoad(GLenum indexFormat, unsigned int indexCount)
{
if (vao == 0)
return NULL;
bindArray();
glGenBuffers(1, &ibo);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, ibo);
glBufferData(GL_ELEMENT_ARRAY_BUFFER, indexSize(indexFormat) * indexCount, NULL, GL_STATIC_DRAW);
iformat = indexFormat;
icount = indexCount;
GLenum err = glGetError();
printf("%i\n", err);
void* ptr = glMapBuffer(GL_ELEMENT_ARRAY_BUFFER, GL_WRITE_ONLY);
err = glGetError();
printf("%i\n", err);
unbindArray();
return ptr;
}
问题是,这会返回 NULL。更糟糕的是,就在我对 GL_ARRAY_BUFFER
执行类似操作之前,我得到了一个完全有效的指针。为什么这个失败了,而另一个成功了?
第一个 glGetError
返回 1280 (GL_INVALID_ENUM
)。第二个 glGetError 返回 1285(GL_OUT_OF_MEMORY
)。我知道它实际上并没有内存不足,因为通常通过 glBufferData
上传完全相同的数据工作正常。
也许我只是错误地处理了顶点数组?
(ps。我在 gamedev stack exchange 上问过这个问题,但一无所获。在这里重新发布以尝试弄清楚)
最佳答案
首先,您的错误检查代码是错误的。您必须在循环中调用 glGetError
,直到它返回 GL_NO_ERROR
。
关于 GL_OUT_OF_MEMORY
错误代码:它也可能意味着地址空间不足,如果从操作系统请求大的连续虚拟地址空间区域,这很容易发生,但进程的地址空间非常零散,以至于没有可用的 block 大小(即使可用地址空间的总量就足够了)。
这已成为 32 位系统的祸根。一个简单的补救措施是使用 64 位系统。如果您坚持使用 32 位平台,则必须对您的地址空间进行碎片整理(这很重要)。
关于c++ - 为什么 glMapBuffer 返回 NULL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22156975/
我正在使用 OpenGL 进行一些 GPGPU 处理。所以我有不同的线程为 OpenGL 处理线程提供工作。 在每个“工作项”之后,我需要调用 glReadPixels 和 glMapBuffer 以
我已经初始化了glewInit()和任何其他openGL的东西。所有这些都是在我执行这些调用之前进行的。 glGenBuffers( 1, &m_uiVertBufferHandle ); g
假设我有一个缓冲区对象,其中包含一些数据。 我使用glMapBuffer与 GL_WRITE_ONLY并写入每隔一个字节(想想交错的顶点属性)。 然后我glUnmapBuffer缓冲区。 我没有写入的
我对缓冲区的概念感到困惑。我了解 glBufferData 和 glBufferSubData 的基础知识。在主循环中的渲染函数之前使用 glBufferSubData,您可以使用 offset 和
我遇到了一个奇怪的问题,我想更新包含大约五十万个元素(顶点)的数组缓冲区,因此我调用 glMapBuffer(...),对某些元素进行一些操作元素并调用 glUnmapBuffer(...),但从那时
我不是在尝试流式传输或其他任何东西,我只是想通过将顶点和索引数据直接加载到 OpenGL 的缓冲区而不是必须先将其放入中间缓冲区来加快我的文件加载代码。这是获取指针的代码: void* VertexA
我正在尝试将 glMapBuffer 与 QOpenGLWidget 一起使用,但我找不到它。这是我包含的文件: #include #include #include #include #in
是否有可能 glUnmapBuffer 一个 GL_STREAM_DRAW 像素缓冲区对象,并且仍然保留先前由 glMapBuffer 返回的指针指向的数据对使用 SSE 4.1 流加载的只读操作有效
为了更新我的统一缓冲区对象,我使用 glBufferSubData .使用速度更快吗glBufferSubData或 glMapBuffer与 glUnmapBuffer ? 最佳答案 关于glMap
我一直在用glBufferData ,对我来说,您必须指定使用提示(例如 GL_DYNAMIC_DRAW)是有意义的。 然而,最近是suggested to me on Stack Overflow我
阅读《 OpenGL编程指南》第8版。 这实际上是一个硬件问题,实际上... 我介绍了有关OpenGL缓冲区的部分,据我了解它们是在图形卡内存中分配的内存空间,这是否正确? 如果是这样,我们如何使用g
我突然想到用 std::vector 管理一系列映射内存(来自 glMapBuffer)是个好主意。 // map data to ptr T* dataPtr = (T*)glMapBuffer(t
我想在创建 VBO 后更新对象的顶点列表。我都看过 glBufferSubData和 glMapBuffer而且它们似乎都在做类似的事情,这意味着我现在不确定该使用哪一个。 我的伪工作流程是: Cre
我不得不粘贴的代码太多了。我已经按照教程进行操作,但是,当我尝试自己实现它们时,似乎没有任何效果。我将在下面粘贴 glMapBuffer 例程。请注意,vertex_type 和 render_tar
我正在尝试使用 glDrawRangeElements 从 VBO 和元素缓冲区对象渲染点。 VBO 和 EBO 是这样实例化的: glGenBuffers(1, &vertex_buffer
我需要在应用程序启动时为 PBO 分配一个相当大的缓冲区(1 GB),并且这样做: glBufferData(GL_PIXEL_UNPACK_BUFFER, new_size, 0, GL_STREA
我正在通过使用 kronos 和 pvrsdk 在 ununtu 10.10 中执行 Opengl-es 2.0。现在代码 #include #include ==========||||||||
我有大量数据要传输到缓冲区,例如 VBO 或 IndirectDrawBuffer,我使用 glMapBuffer 和 glBufferSubData 来执行此操作。我发现在渲染缓冲区时使用 glMa
我是一名优秀的程序员,十分优秀!