<div dir="ltr">I added a GstQueue (with default settings) and the video for scenario 2 has greatly improved, but 

<span style="font-size:small;text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">there is still a very fast black-screen between slides.  It does not happen for scenario 1, only scenario 2.</span><div><br></div><div>Here is the change I made:<div><br><blockquote style="margin:0 0 0 40px;border:none;padding:0px"><div><a href="https://github.com/adaviding/gstreamer-playground/commit/2b04911a839960691a09a4f9e0375afade1a605a">https://github.com/adaviding/gstreamer-playground/commit/2b04911a839960691a09a4f9e0375afade1a605a</a></div></blockquote><div><br></div><div>The log output for scenario #2 has not changed (as described earlier). <br></div></div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Aug 10, 2018 at 7:17 AM, David Ing <span dir="ltr"><<a href="mailto:ding@panopto.com" target="_blank">ding@panopto.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="auto">Yes it does.  I will try to add a queue after the timeline when I get to work ... You should hear back from me in a couple hours.</div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Aug 10, 2018 6:42 AM, "Thibault Saunier" <<a href="mailto:tsaunier@gnome.org" target="_blank">tsaunier@gnome.org</a>> wrote:<br type="attribution"><blockquote class="m_-8515980898191859934quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"> I just ran that on linux and I get no black frame, the foreground<br>
video stalls for a little while which I suspect is because you are<br>
missing some queuing after the composition. Also does that reproduce<br>
while rendering?<div class="m_-8515980898191859934signature-text"><br>
<br>
Thibault</div><div class="m_-8515980898191859934elided-text"><br>
<br>
On Fri, Aug 10, 2018 at 9:27 AM David Ing <<a href="mailto:ding@panopto.com" rel="noreferrer" target="_blank">ding@panopto.com</a>> wrote:<br>
><br>
> It's all in the master branch of my repo (currently 680b203603ffa35e27493e28fe1620<wbr>edacb8d655):  <a href="https://github.com/adaviding/gstreamer-playground" rel="noreferrer noreferrer" target="_blank">https://github.com/adaviding/<wbr>gstreamer-playground</a><br>
><br>
> It is a visual studio 2017 project, but I made sure to include<br>
><br>
> collateral --> a folder with all of the media files<br>
> Debug/x64 --> my build output<br>
><br>
> If you don't have visual studio, it should be easy enough to compile main.cpp in some other way.  The entire program is 1 source file:  main.cpp.<br>
><br>
> On Fri, Aug 10, 2018 at 5:37 AM, Thibault Saunier <<a href="mailto:saunierthibault@gmail.com" rel="noreferrer" target="_blank">saunierthibault@gmail.com</a>> wrote:<br>
>><br>
>> Hello, could you share you project with the assets?<br>
>><br>
>><br>
>> Regards<br>
>><br>
>> Thibault<br>
>><br>
>><br>
>><br>
>> On Fri, Aug 10, 2018, 01:01 David Ing <<a href="mailto:ding@panopto.com" rel="noreferrer" target="_blank">ding@panopto.com</a>> wrote:<br>
>>><br>
>>> I forgot to say that the log messages appear at the time of each slide transition.<br>
>>><br>
>>> On Thu, Aug 9, 2018 at 9:58 PM, David Ing <<a href="mailto:ding@panopto.com" rel="noreferrer" target="_blank">ding@panopto.com</a>> wrote:<br>
>>>><br>
>>>> I wrote a sample application to demonstrates a problem that I'm having with GES:<br>
>>>><br>
>>>> <a href="https://github.com/adaviding/gstreamer-playground/blob/680b203603ffa35e27493e28fe1620edacb8d655/ges-slide-composition/main.cpp" rel="noreferrer noreferrer" target="_blank">https://github.com/adaviding/<wbr>gstreamer-playground/blob/<wbr>680b203603ffa35e27493e28fe1620<wbr>edacb8d655/ges-slide-<wbr>composition/main.cpp</a><br>
>>>><br>
>>>> The problem is with scenario #2 only, and I observe the problem running on Windows 10 with GES 1.12.4 and 1.14.2.  I have only tried this on Windows.<br>
>>>><br>
>>>> Scenario 1 ( #define INCLUDE_FOREGROUND_VIDEO false )<br>
>>>><br>
>>>> The sample application builds a video consisting of 5 jpeg images (i.e. "slides").  Each slide is up for 2 seconds so the movie is 10 seconds long.  There is no audio in the sample application, and no audio track.<br>
>>>><br>
>>>> Scenario 2 ( #define INCLUDE_FOREGROUND_VIDEO true )<br>
>>>><br>
>>>> This is just like scenario 1, but there is also a picture-in-picture style video in the corner of the screen, in front of the slides.  I am using a video which has no audio track.<br>
>>>><br>
>>>> The problem is that in scenario #2, during the slide transition (which occurs every 2 seconds), the screen goes black for a fraction of a second.  Interestingly, the foreground video does not go black ... only the portion of the screen subtended by the slides does this (which is most of the screen).  And this happens for every slide transition.<br>
>>>><br>
>>>> Some other things to note about my application.<br>
>>>><br>
>>>> I am using a GESTimeline with a GstPipeline (not GESPipeline) because I need to encode the composition in many different ways.  Computational efficiency is of paramount importance, which means I only want to execute the pipeline once.  I cannot achieve this using a GESPipeline, so I need to use a GstPipeline<br>
>>>> I wired the NleComposition "query-position" signal so that it fetches the current position of the GstPipeline.<br>
>>>><br>
>>>> Running with --gst-debug=3, I observe the following logs under each scenario.<br>
>>>><br>
>>>> No highlights = the log appears in both scenarios.<br>
>>>> Yellow highlights = the log only appears in scenario #2.<br>
>>>> Pink highlights = the log appears in both scenarios, but is being repeated more often.<br>
>>>><br>
>>>><br>
>>>> Scenario 1:<br>
>>>><br>
>>>> 0:00:09.110542588 13280 0000016292B0B940 WARN              aggregator gstaggregator.c:1397:gst_<wbr>aggregator_query_latency_<wbr>unlocked:<gessmartmixer0-<wbr>compositor> Latency query failed<br>
>>>> 0:00:09.110791659 13280 0000016292B0BD00 WARN                 GST_URI gsturi.c:837:gst_file_utils_<wbr>canonicalise_path: FIXME: canonicalise win32 path<br>
>>>> 0:00:09.113365512 13280 0000016292B0BD00 WARN                 basesrc gstbasesrc.c:3480:gst_base_<wbr>src_start_complete:<source> pad not activated yet<br>
>>>> 0:00:09.115511241 13280 0000016292B0BD00 WARN                 basesrc gstbasesrc.c:3480:gst_base_<wbr>src_start_complete:<source> pad not activated yet<br>
>>>> 0:00:09.118815897 13280 0000016292D3CD00 FIXME           videodecoder gstvideodecoder.c:928:gst_<wbr>video_decoder_drain_out:<<wbr>jpegdec9> Sub-class should implement drain()<br>
>>>> 0:00:09.120799711 13280 0000016292D3CD00 FIXME           videodecoder gstvideodecoder.c:928:gst_<wbr>video_decoder_drain_out:<<wbr>jpegdec9> Sub-class should implement drain()<br>
>>>> 0:00:09.121881327 13280 0000016292D3CD00 WARN            videodecoder gstvideodecoder.c:2438:gst_<wbr>video_decoder_chain:<jpegdec9> Received buffer without a new-segment. Assuming timestamps start from 0.<br>
>>>><br>
>>>><br>
>>>> Scenario 2:<br>
>>>><br>
>>>> 0:00:09.250672090 16592 000001F366DE7200 WARN              aggregator gstaggregator.c:1397:gst_<wbr>aggregator_query_latency_<wbr>unlocked:<gessmartmixer0-<wbr>compositor> Latency query failed<br>
>>>> 0:00:09.250841298 16592 000001F366DECE40 WARN                 GST_URI gsturi.c:837:gst_file_utils_<wbr>canonicalise_path: FIXME: canonicalise win32 path<br>
>>>> 0:00:09.253852393 16592 000001F366DECE40 WARN                 basesrc gstbasesrc.c:3480:gst_base_<wbr>src_start_complete:<source> pad not activated yet<br>
>>>> 0:00:09.255128014 16592 000001F366DECE40 WARN                 basesrc gstbasesrc.c:3480:gst_base_<wbr>src_start_complete:<source> pad not activated yet<br>
>>>> 0:00:09.256701573 16592 000001F366DECE40 WARN                 GST_URI gsturi.c:837:gst_file_utils_<wbr>canonicalise_path: FIXME: canonicalise win32 path<br>
>>>> 0:00:09.257970631 16592 000001F366DECAC0 WARN                 qtdemux qtdemux_types.c:228:qtdemux_<wbr>type_get: unknown QuickTime node type uuid<br>
>>>> 0:00:09.262471410 16592 000001F366DECAC0 WARN                 qtdemux qtdemux_types.c:228:qtdemux_<wbr>type_get: unknown QuickTime node type pasp<br>
>>>> 0:00:09.258281331 16592 000001F366DECE40 WARN                 basesrc gstbasesrc.c:3480:gst_base_<wbr>src_start_complete:<source> pad not activated yet<br>
>>>> 0:00:09.263756148 16592 000001F366DECAC0 WARN                 qtdemux qtdemux.c:3017:qtdemux_parse_<wbr>trex:<qtdemux5> failed to find fragment defaults for stream 1<br>
>>>> 0:00:09.265397171 16592 000001F366DECE40 WARN                 basesrc gstbasesrc.c:3480:gst_base_<wbr>src_start_complete:<source> pad not activated yet<br>
>>>> 0:00:09.266319062 16592 000001F366DECAC0 WARN                 basesrc gstbasesrc.c:2389:gst_base_<wbr>src_update_length:<source> processing at or past EOS<br>
>>>> 0:00:09.268796277 16592 000001F366F6A500 FIXME           videodecoder gstvideodecoder.c:928:gst_<wbr>video_decoder_drain_out:<<wbr>jpegdec9> Sub-class should implement drain()<br>
>>>> 0:00:09.273111438 16592 000001F366F6A500 FIXME           videodecoder gstvideodecoder.c:928:gst_<wbr>video_decoder_drain_out:<<wbr>jpegdec9> Sub-class should implement drain()<br>
>>>> 0:00:09.274373567 16592 000001F366F6A500 WARN            videodecoder gstvideodecoder.c:2438:gst_<wbr>video_decoder_chain:<jpegdec9> Received buffer without a new-segment. Assuming timestamps start from 0.<br>
>>>> 0:00:09.313360990 16592 000001F366CFBD00 WARN                GST_PADS gstpad.c:4161:gst_pad_peer_<wbr>query:<queue11:src> could not send sticky events<br>
>>>> 0:00:09.315771835 16592 000001F366DE7D00 WARN              aggregator gstaggregator.c:1397:gst_<wbr>aggregator_query_latency_<wbr>unlocked:<gessmartmixer0-<wbr>compositor> Latency query failed<br>
>>>><br>
>>>><br>
>>>> Does anybody know how I might fix the problem with scenario #2?<br>
>>><br>
>>><br>
>>> ______________________________<wbr>_________________<br>
>>> gstreamer-devel mailing list<br>
>>> <a href="mailto:gstreamer-devel@lists.freedesktop.org" rel="noreferrer" target="_blank">gstreamer-devel@lists.<wbr>freedesktop.org</a><br>
>>> <a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/gstreamer-<wbr>devel</a><br>
>><br>
>><br>
>> ______________________________<wbr>_________________<br>
>> gstreamer-devel mailing list<br>
>> <a href="mailto:gstreamer-devel@lists.freedesktop.org" rel="noreferrer" target="_blank">gstreamer-devel@lists.<wbr>freedesktop.org</a><br>
>> <a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/gstreamer-<wbr>devel</a><br>
>><br>
><br>
> ______________________________<wbr>_________________<br>
> gstreamer-devel mailing list<br>
> <a href="mailto:gstreamer-devel@lists.freedesktop.org" rel="noreferrer" target="_blank">gstreamer-devel@lists.<wbr>freedesktop.org</a><br>
> <a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/gstreamer-<wbr>devel</a><br>
______________________________<wbr>_________________<br>
gstreamer-devel mailing list<br>
<a href="mailto:gstreamer-devel@lists.freedesktop.org" rel="noreferrer" target="_blank">gstreamer-devel@lists.<wbr>freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" rel="noreferrer noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/gstreamer-<wbr>devel</a><br>
</div></blockquote></div><br></div>
</div></div></blockquote></div><br></div>