Я использую Pixel Pixel Buffer Objects (PBO) с постоянными сопоставленными буферами для асинхронного обновления текстур в моем приложении QT. В моей петле рендеринга я делаю что -то вроде этого: < /p>
void GLWidget::updateTextures() {
for (int i = 0; i < workers.getVideoCount(); ++i) {
std::shared_ptr frame = workers.getNextFrame(i);
if (!frame) continue;
int nextIndex = (pboIndex[i] + 1) % MAX_PBO;
glBindBuffer(GL_PIXEL_UNPACK_BUFFER, pboIds[i][nextIndex]);
void* ptr = glMapBuffer(GL_PIXEL_UNPACK_BUFFER, GL_WRITE_ONLY);
if (ptr) {
memcpy(ptr, frame->bits(), frame->width() * frame->height() * 3); // This blocks and eats render time
glUnmapBuffer(GL_PIXEL_UNPACK_BUFFER);
}
glBindTexture(GL_TEXTURE_2D, textureId[i]);
glTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, frame->width(), frame->height(), GL_RGB, GL_UNSIGNED_BYTE, 0);
glBindBuffer(GL_PIXEL_UNPACK_BUFFER, 0);
glBindTexture(GL_TEXTURE_2D, 0);
pboIndex[i] = nextIndex;
}
}
Как я могу сделать загрузку данных текстуры (особенно в Memcpy в PBO) асинхронную или разгруженную в другой поток, не задерживая основной цикл рендеринга?
Я использую Pixel Pixel Buffer Objects (PBO) с постоянными сопоставленными буферами для асинхронного обновления текстур в моем приложении QT. В моей петле рендеринга я делаю что -то вроде этого: < /p> [code]void GLWidget::updateTextures() { for (int i = 0; i < workers.getVideoCount(); ++i) { std::shared_ptr frame = workers.getNextFrame(i); if (!frame) continue;
int nextIndex = (pboIndex[i] + 1) % MAX_PBO;
glBindBuffer(GL_PIXEL_UNPACK_BUFFER, pboIds[i][nextIndex]); void* ptr = glMapBuffer(GL_PIXEL_UNPACK_BUFFER, GL_WRITE_ONLY); if (ptr) { memcpy(ptr, frame->bits(), frame->width() * frame->height() * 3); // This blocks and eats render time glUnmapBuffer(GL_PIXEL_UNPACK_BUFFER); }
pboIndex[i] = nextIndex; } } [/code] Как я могу сделать загрузку данных текстуры (особенно в Memcpy в PBO) асинхронную или разгруженную в другой поток, не задерживая основной цикл рендеринга?