<div dir="ltr"><div>Could you expand on 1 and 2? <br></div><div>This rendering code works with my single threaded application.</div><div><br></div><div>Is the problem with 1 the fact that the vertices are allocated inside a function (ie on the stack)?</div><div>I have no idea what you mean by 2. Apologies for being a noob.</div><div>Re 3, does this mean gstreamer creates a separate OpenGL context? Is there a new context made for every element? Do some elements share contexts?</div><div><br></div><div>Thanks<br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Aug 2, 2021 at 3:40 AM Matthew Waters <<a href="mailto:ystreet00@gmail.com">ystreet00@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div>
Take a look at<br>
<br>
<a href="https://gitlab.freedesktop.org/gstreamer/gst-plugins-base/-/blob/master/gst-libs/gst/gl/gstglfilter.c#L1165" target="_blank">https://gitlab.freedesktop.org/gstreamer/gst-plugins-base/-/blob/master/gst-libs/gst/gl/gstglfilter.c#L1165</a>.<br>
<br>
I can notice a couple of things wrong:<br>
1. Vertex glBufferData call is taking the address of an array that
should not be taken.<br>
2. No retrieval of the vertex attribute locations (GPU driver
decides these)<br>
3. You may not be creating the VAO in the correct thread? VAO's are
not OpenGL shareable resource across OpenGL contexts.<br>
<br>
Cheers<br>
-Matt<br>
<br>
<div>On 2/8/21 5:47 am, Edward Anon via
gstreamer-devel wrote:<br>
</div>
<blockquote type="cite">
<div dir="ltr">
<div>My client takes a camera feed over RTP. I want to render an
overlay onto it using opengl. Hence, I want to use
GlImageSink in my application as it provides me with the next
frame already in a texture. I want to blit the already
rendered overlay onto the texture prior to rendering.<br>
<br>
</div>
<div>As a first step I am writing a simple draw callback which
should just render the texture to the screen. I am basing my
callback on the cube example in the gst-plugins-base source.</div>
<div><br>
</div>
<div>```</div>
<div>
<pre style="background-color:rgb(43,43,43);color:rgb(169,183,198);font-family:"JetBrains Mono",monospace;font-size:9.8pt"><span style="color:rgb(185,188,209)">gboolean </span><span style="color:rgb(255,198,109)">drawCallback </span>(<span style="color:rgb(185,188,209)">GstElement </span>* gl_sink<span style="color:rgb(204,120,50)">, </span><span style="color:rgb(185,188,209)">GstGLContext </span>*context<span style="color:rgb(204,120,50)">, </span><span style="color:rgb(185,188,209)">GstSample </span>* sample<span style="color:rgb(204,120,50)">, </span><span style="color:rgb(185,188,209)">gpointer </span>data) {
<span style="color:rgb(144,139,37)">assert</span>(gl_sink)<span style="color:rgb(204,120,50)">; </span><span style="color:rgb(144,139,37)">assert</span>(context)<span style="color:rgb(204,120,50)">; </span><span style="color:rgb(144,139,37)">assert</span>(sample)<span style="color:rgb(204,120,50)">; </span><span style="color:rgb(144,139,37)">assert</span>(<span style="color:rgb(204,120,50)">not </span>data)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(185,188,209)">GstVideoFrame </span>v_frame<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(185,188,209)">GstVideoInfo </span>v_info<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(185,188,209)">GstBuffer </span>*buf = gst_sample_get_buffer (sample)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(185,188,209)">GstCaps </span>*caps = gst_sample_get_caps (sample)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span>gst_video_info_from_caps (&v_info<span style="color:rgb(204,120,50)">, </span>caps)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> if </span>(!gst_video_frame_map (&v_frame<span style="color:rgb(204,120,50)">, </span>&v_info<span style="color:rgb(204,120,50)">, </span>buf<span style="color:rgb(204,120,50)">, </span>(<span style="color:rgb(185,188,209)">GstMapFlags</span>) (<span style="color:rgb(152,118,170);font-style:italic">GST_MAP_READ </span>| <span style="color:rgb(144,139,37)">GST_MAP_GL</span>))) {
<span style="color:rgb(144,139,37)">g_warning </span>(<span style="color:rgb(106,135,89)">"Failed to map the video buffer"</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> return </span><span style="color:rgb(144,139,37)">TRUE</span><span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span>}
<span style="color:rgb(185,188,209)">GLuint </span>texture_id = *(<span style="color:rgb(185,188,209)">guint </span>*) v_frame.<span style="color:rgb(147,115,165)">data</span>[<span style="color:rgb(104,151,187)">0</span>]<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(181,182,227)">Texture </span>t<span style="color:rgb(204,120,50)">; </span>t.from(texture_id<span style="color:rgb(204,120,50)">, </span><span style="color:rgb(181,182,227)">Texture</span>::<span style="color:rgb(181,182,227)">TextureType</span>::<span style="color:rgb(152,118,170);font-style:italic">COLOUR</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span>t.render()<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> return true;
</span>}</pre>
```<br>
<br>
</div>
<div>However, I get the following error: ```gldebug
gstgldebug.c:306:_gst_gl_debug_callback:<glcontextglx0>
high: GL error from API id:1, GL_INVALID_OPERATION in
glDrawArrays```.<br>
<br>
</div>
<div>The render code is as follows:<br>
```<br>
<pre style="background-color:rgb(43,43,43);color:rgb(169,183,198);font-family:"JetBrains Mono",monospace;font-size:9.8pt"><span style="color:rgb(204,120,50)">if </span>(texture_type != <span style="color:rgb(152,118,170);font-style:italic">UNINITIALISED</span>) {
<span style="color:rgb(204,120,50)">switch </span>(texture_type) {
<span style="color:rgb(204,120,50)">case </span><span style="color:rgb(152,118,170);font-style:italic">COLOUR</span>:
<span style="color:rgb(147,115,165)">colour_shader</span>.use()<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> break;
</span></pre>
<pre style="background-color:rgb(43,43,43);color:rgb(169,183,198);font-family:"JetBrains Mono",monospace;font-size:9.8pt"><span style="color:rgb(204,120,50)">// other texture type setup
</span></pre>
<pre style="background-color:rgb(43,43,43);color:rgb(169,183,198);font-family:"JetBrains Mono",monospace;font-size:9.8pt"><span style="color:rgb(204,120,50)"> default</span>:
<span style="color:rgb(204,120,50)">throw </span><span style="color:rgb(181,182,227)">std</span>::runtime_error(<span style="color:rgb(106,135,89)">"Unsupported texture type"</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span>}
<span style="color:rgb(144,139,37)">glBindVertexArray</span>(<span style="color:rgb(147,115,165)">quadVAO</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glDisable</span>(<span style="color:rgb(144,139,37)">GL_DEPTH_TEST</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBindTexture</span>(<span style="color:rgb(144,139,37)">GL_TEXTURE_2D</span><span style="color:rgb(204,120,50)">, </span>opengl_texture)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glDrawArrays</span>(<span style="color:rgb(144,139,37)">GL_TRIANGLES</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">6</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBindTexture</span>(<span style="color:rgb(144,139,37)">GL_TEXTURE_2D</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glEnable</span>(<span style="color:rgb(144,139,37)">GL_DEPTH_TEST</span>)<span style="color:rgb(204,120,50)">;
</span>}</pre>
```<br>
</div>
<div>Shaders, VAO and VBO set up as follows:<br>
```<br>
<pre style="background-color:rgb(43,43,43);color:rgb(169,183,198);font-family:"JetBrains Mono",monospace;font-size:9.8pt"> <span style="color:rgb(144,139,37)">glGenVertexArrays</span>(<span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span>&<span style="color:rgb(147,115,165)">quadVAO</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBindVertexArray</span>(<span style="color:rgb(147,115,165)">quadVAO</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glGenBuffers</span>(<span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span>&<span style="color:rgb(147,115,165)">quadVBO</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBindBuffer</span>(<span style="color:rgb(144,139,37)">GL_ARRAY_BUFFER</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(147,115,165)">quadVBO</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBindVertexArray</span>(<span style="color:rgb(147,115,165)">quadVAO</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBindBuffer</span>(<span style="color:rgb(144,139,37)">GL_ARRAY_BUFFER</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(147,115,165)">quadVBO</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glEnableVertexAttribArray</span>(<span style="color:rgb(104,151,187)">0</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glVertexAttribPointer</span>(<span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">2</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(144,139,37)">GL_FLOAT</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(144,139,37)">GL_FALSE</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">4 </span>* <span style="color:rgb(204,120,50)">sizeof</span>(<span style="color:rgb(204,120,50)">float</span>)<span style="color:rgb(204,120,50)">,
</span><span style="color:rgb(204,120,50)"> </span>(<span style="color:rgb(204,120,50)">void </span>*)<span style="color:rgb(204,120,50)">nullptr</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glEnableVertexAttribArray</span>(<span style="color:rgb(104,151,187)">1</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glVertexAttribPointer</span>(<span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">2</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(144,139,37)">GL_FLOAT</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(144,139,37)">GL_FALSE</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">4 </span>* <span style="color:rgb(204,120,50)">sizeof</span>(<span style="color:rgb(204,120,50)">float</span>)<span style="color:rgb(204,120,50)">,
</span><span style="color:rgb(204,120,50)"> </span>(<span style="color:rgb(204,120,50)">void </span>*)(<span style="color:rgb(104,151,187)">2 </span>* <span style="color:rgb(204,120,50)">sizeof</span>(<span style="color:rgb(204,120,50)">float</span>)))<span style="color:rgb(204,120,50)">;</span><span style="color:rgb(128,128,128)">
</span><span style="color:rgb(128,128,128)">
</span><span style="color:rgb(128,128,128)"> </span><span style="color:rgb(204,120,50)">constexpr float </span>quadVertices[] = {
<span style="color:rgb(128,128,128)">// positions // texCoords
</span><span style="color:rgb(128,128,128)"> </span><span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span>-<span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(128,128,128)">// top left
</span><span style="color:rgb(128,128,128)"> </span><span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(128,128,128)">// bottom left
</span><span style="color:rgb(128,128,128)"> </span>-<span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(128,128,128)">// bottom right
</span><span style="color:rgb(128,128,128)">
</span><span style="color:rgb(128,128,128)"> </span><span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span>-<span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(128,128,128)">// top left
</span><span style="color:rgb(128,128,128)"> </span>-<span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">0</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(128,128,128)">// bottom right
</span><span style="color:rgb(128,128,128)"> </span>-<span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span>-<span style="color:rgb(104,151,187)">1.0f</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1</span><span style="color:rgb(204,120,50)">, </span><span style="color:rgb(104,151,187)">1 </span><span style="color:rgb(128,128,128)">// top right
</span><span style="color:rgb(128,128,128)"> </span>}<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBufferData</span>(<span style="color:rgb(144,139,37)">GL_ARRAY_BUFFER</span><span style="color:rgb(204,120,50)">, sizeof</span>(quadVertices)<span style="color:rgb(204,120,50)">, </span>&quadVertices<span style="color:rgb(204,120,50)">,
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">GL_STATIC_DRAW</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(144,139,37)">glBindVertexArray</span>(<span style="color:rgb(104,151,187)">0</span>)<span style="color:rgb(204,120,50)">;
</span><span style="color:rgb(204,120,50)">
</span><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(147,115,165)">colour_shader </span>= Shader(shaderRoot <span style="color:rgb(95,140,138)">+ </span><span style="color:rgb(106,135,89)">"quadFromTexture.vs"</span><span style="color:rgb(204,120,50)">,
</span><span style="color:rgb(204,120,50)"> </span>shaderRoot <span style="color:rgb(95,140,138)">+ </span><span style="color:rgb(106,135,89)">"colourTexture.fs"</span>)<span style="color:rgb(204,120,50)">;
</span></pre>
<pre style="background-color:rgb(43,43,43);color:rgb(169,183,198);font-family:"JetBrains Mono",monospace;font-size:9.8pt"><span style="color:rgb(204,120,50)"> </span><span style="color:rgb(204,120,50)">// setup other shaders</span></pre>
```<br>
<br>
</div>
<div>What am I doing wrong?</div>
</div>
</blockquote>
<br>
</div>
</blockquote></div>