J'essaie d'effectuer un rendu OpenGL ES 2.0 sur un fichier image, indépendamment du fait que le rendu soit affiché à l'écran pour l'utilisateur. L'image vers laquelle j'effectue le rendu est d'une taille différente de celle de l'écran de l'utilisateur. J'ai juste besoin d'un tableau d'octets de données GL_RGB. Je connais bien glReadPixels, mais je ne pense pas qu'il puisse faire l'affaire dans ce cas puisque je n'utilise pas l'écran de l'utilisateur déjà rendu.
Pseudocode :
// Switch rendering to another buffer (framebuffer? renderbuffer?)
// Draw code here
// Save byte array of rendered data GL_RGB to file
// Switch rendering back to user's screen.
Comment puis-je faire cela sans interrompre l'affichage de l'utilisateur ? Je préférerais ne pas avoir à faire scintiller l'écran de l'utilisateur, en dessinant l'information désirée pour une seule image, en glReadPixel-ing et en la faisant disparaître ensuite.
Encore une fois, je ne veux pas qu'il montre quoi que ce soit à l'utilisateur. Voici mon code. Cela ne fonctionne pas est-ce que j'ai raté quelque chose ?
unsigned int canvasFrameBuffer;
bglGenFramebuffers(1, &canvasFrameBuffer);
bglBindFramebuffer(BGL_RENDERBUFFER, canvasFrameBuffer);
unsigned int canvasRenderBuffer;
bglGenRenderbuffers(1, &canvasRenderBuffer);
bglBindRenderbuffer(BGL_RENDERBUFFER, canvasRenderBuffer);
bglRenderbufferStorage(BGL_RENDERBUFFER, BGL_RGBA4, width, height);
bglFramebufferRenderbuffer(BGL_FRAMEBUFFER, BGL_COLOR_ATTACHMENT0, BGL_RENDERBUFFER, canvasRenderBuffer);
unsigned int canvasTexture;
bglGenTextures(1, &canvasTexture);
bglBindTexture(BGL_TEXTURE_2D, canvasTexture);
bglTexImage2D(BGL_TEXTURE_2D, 0, BGL_RGB, width, height, 0, BGL_RGB, BGL_UNSIGNED_BYTE, 0);
bglFramebufferTexture2D(BGL_FRAMEBUFFER, BGL_COLOR_ATTACHMENT0, BGL_TEXTURE_2D, canvasTexture, 0);
Matrix::matrix_t identity;
Matrix::LoadIdentity(&identity);
bglClearColor(1.0f, 1.0f, 1.0f, 1.0f);
bglClear(BGL_COLOR_BUFFER_BIT);
Draw(&identity, &identity, this);
bglFlush();
bglFinish();
byte *buffer = (byte*)Z_Malloc(width * height * 4, ZT_STATIC);
bglReadPixels(0, 0, width, height, BGL_RGB, BGL_UNSIGNED_BYTE, buffer);
SaveTGA("canvas.tga", buffer, width, height);
Z_Free(buffer);
// unbind frame buffer
bglBindRenderbuffer(BGL_RENDERBUFFER, 0);
bglBindFramebuffer(BGL_FRAMEBUFFER, 0);
bglDeleteTextures(1, &canvasTexture);
bglDeleteRenderbuffers(1, &canvasRenderBuffer);
bglDeleteFramebuffers(1, &canvasFrameBuffer);