Thanks Stefan, as I understand, now I have to control the &quot;position&quot; property.<br><br>I run an the following example, where I control the &quot;alpha&quot; property, and it works fine. I don&#39;t know if it&#39;s due a different pipeline, but it doesn&#39;t concern about &quot;alpha&quot; property.<br>
Here&#39;s the code which runs (without sound): <br><br><br>#include &lt;gst.h&gt;<br>#include &lt;controller/gstcontroller.h&gt;<br><br>#include &lt;iostream&gt;<br><br>using namespace std;<br><br><br>// Manejador de errores<br>
static gboolean bus_call (GstBus *bus, GstMessage *msg, gpointer data)<br>{<br>:::::::::::::::<br>}<br><br>static void on_pad_added (GstElement *element, GstPad *pad, gpointer  data)<br>{<br>  GstPad *sinkpad = NULL;<br>  GstElement * queue = (GstElement *) data;<br>
<br>  /* Ahora linkeo el pad de comp con sink pad */<br>  g_print (&quot;Dynamic pad created, linking queue\n&quot;);<br>  sinkpad = gst_element_get_static_pad (queue, &quot;sink&quot;);<br><br>  gst_pad_link (pad, sinkpad);<br>
<br>  gst_object_unref (sinkpad);<br><br>}<br><br>GstElement * getBin(const gchar * nomBin, GstElement * &amp;alfa1, GstElement *&amp;smpte, GstElement * &amp;color, gint transicion = 1)<br>{<br><br>  GstElement * bin = gst_bin_new(nomBin);<br>
<br>  if (!bin)<br>  {<br>      g_printerr (&quot;No se pudo crear el bin. Saliendo\n&quot;);<br>     return NULL;<br>  }<br><br>  alfa1   = gst_element_factory_make (&quot;alpha&quot;,&quot;alfa1&quot;);<br>  smpte  = gst_element_factory_make (&quot;smptealpha&quot;,&quot;smpte&quot;);<br>
  color  = gst_element_factory_make (&quot;ffmpegcolorspace&quot;, &quot;color&quot;);<br>  GstElement * mixer  = gst_element_factory_make(&quot;videomixer&quot;, &quot;mixer&quot;);<br><br><br>  if ((!alfa1) || (!smpte) || (!color) || (!mixer))<br>
  {<br>      g_printerr (&quot;Alguno de los elementos del Bin no pudo ser creado. Saliendo\n&quot;);<br>     return NULL;<br>  }<br><br>  // Anexamos al bin<br>  gst_bin_add_many(GST_BIN (bin),alfa1,smpte,mixer,color,NULL);<br>
<br>  // Enlazamos elementos<br>  gst_element_link (alfa1, mixer);<br>  gst_element_link (smpte, mixer);<br>  gst_element_link (mixer,color);<br><br>  g_object_set(smpte,&quot;type&quot;, transicion, NULL);<br><br>  return bin;<br>
}<br><br>void getAndSetController(GstElement * smpte, gdouble duracion)<br>{<br>    GstController * ctrl = NULL;<br>    if (!(ctrl = gst_controller_new (G_OBJECT (smpte), &quot;alpha&quot;,NULL))) {  // Here it works fine<br>
        GST_WARNING (&quot;No puede controlar el elemento fuente\n&quot;);<br>        return;<br>   }<br><br>  // Todo valor GValue debe inicializarse en 0<br>  GValue val_double = { 0, };<br>  g_value_init (&amp;val_double, G_TYPE_DOUBLE);<br>
<br><br>  // Creo la fuente al controlador y la asocio al controlador<br>  // Seteo modo de interpolacion<br><br>  GstInterpolationControlSource * csource = gst_interpolation_control_source_new();<br>  gst_controller_set_control_source (ctrl, &quot;alpha&quot;, GST_CONTROL_SOURCE (csource));<br>
<br>  gst_interpolation_control_source_set_interpolation_mode(csource,GST_INTERPOLATE_LINEAR);<br><br>  // Seteo primer valor<br>  g_value_set_double(&amp;val_double, 0.0);<br>  gst_interpolation_control_source_set(csource,(0 * GST_MSECOND),&amp;val_double);<br>
<br>  // Seteo segundo valor<br>  g_value_set_double (&amp;val_double, duracion);<br>  gst_interpolation_control_source_set(csource,(1 * GST_MSECOND),&amp;val_double);<br><br><br>  g_object_unref (csource);<br><br>}<br><br>
void addGhostPadsToBin(GstElement *alfa1, GstElement * smpte, GstElement * color, GstElement* bin)<br>{<br>    /* add ghostpad */<br>  GstPad * pad1 = gst_element_get_static_pad (alfa1, &quot;sink&quot;);<br>  gst_element_add_pad(bin, gst_ghost_pad_new(&quot;alfasink1&quot;, pad1));<br>
  gst_object_unref (GST_OBJECT (pad1));<br><br>  GstPad * pad2 = gst_element_get_static_pad (smpte, &quot;sink&quot;);<br>  gst_element_add_pad(bin, gst_ghost_pad_new(&quot;alfasink2&quot;, pad2));<br>  gst_object_unref(GST_OBJECT(pad2));<br>
<br>  GstPad * pad3 = gst_element_get_static_pad (color, &quot;src&quot;);<br>  gst_element_add_pad(bin, gst_ghost_pad_new(&quot;colorsrc&quot;, pad3));<br>  gst_object_unref(GST_OBJECT(pad3));<br><br>}<br><br>void crossTransicion(gdouble duracion, GstElement * &amp; bin,gint transicion = 1)<br>
{<br>    // devuelve el bin<br>    GstElement * alfa1, *smpte, *color;<br>    alfa1 = 0;<br>    smpte = 0;<br>    color = 0;<br><br>    bin = getBin(&quot;bin&quot;,alfa1, smpte,color,transicion);  // Crea el bin y los elementos<br>
<br>    getAndSetController(smpte,duracion);<br><br>    addGhostPadsToBin(alfa1, smpte, color, bin);<br><br>}<br><br>GstElement * getSetPipeline(gchar *argv[])<br>{<br>    gint dur1 = 9000; // duration (in ms) to play of first clip<br>
    gint dur2 = 8000; // duration (in ms) to play of second clip<br>    gint dur_crossfade = 500; //number of milliseconds to crossfade for<br>    GstElement *comp = 0;<br>    GstElement *pipeline, *video1, *video2, *op, *bin, *queue, *sink;<br>
<br>    // ejecuta 2 clips serialmente con un crosdfade entre ellos usando el elemento (GnlOlin) gnlcomposition<br>    if ((comp = gst_element_factory_make(&quot;gnlcomposition&quot;, &quot;micomposicion&quot;)) == NULL)<br>
    {<br>      printf (&quot;\n Fallo al crear gnlcomposition \n&quot;);<br>      return NULL;<br>    }<br><br>    op = gst_element_factory_make(&quot;gnloperation&quot;, &quot;op&quot;);<br><br>    crossTransicion(dur_crossfade, bin,1);<br>
<br>    if (gst_bin_add (GST_BIN (op), bin) == FALSE)<br>    {<br>      printf (&quot;\n No pudo agregar el bin a la gnloperacion op \n&quot;);<br>      return NULL;<br>    }<br><br>    g_object_set (op,&quot;start&quot;, (dur1-dur_crossfade) * GST_MSECOND,NULL);<br>
    g_object_set (op,&quot;duration&quot;, dur_crossfade *  GST_MSECOND,NULL);<br>    g_object_set (op,&quot;media-start&quot;, 0 *  GST_MSECOND,NULL);<br>    g_object_set(op,&quot;media-duration&quot;, dur_crossfade * GST_MSECOND,NULL);<br>
    g_object_set(op,&quot;priority&quot;,0,NULL);<br><br>    if (gst_bin_add (GST_BIN (comp), op) == FALSE)<br>    {<br>      printf (&quot;\n No pudo agregar la gnloperacion a la gnlcomposition \n&quot;);<br>      return NULL;<br>
    }<br><br><br>    // configura primer clip<br><br>    if ((video1 = gst_element_factory_make(&quot;gnlfilesource&quot;, &quot;video1&quot;)) == NULL)<br>    {<br>      printf (&quot;\n Falló la creacion del gnlfilesource \n&quot;);<br>
      return NULL;<br>    }<br>    if (gst_bin_add (GST_BIN (comp), video1) == FALSE)<br>    {<br>      printf (&quot;\n No pudo agregar video1 a comp \n&quot;);<br>      return NULL;<br>    }<br><br>    g_object_set (video1, &quot;location&quot;, argv[1], NULL);<br>
    g_object_set(video1, &quot;uri&quot;, argv[1],NULL);<br>    g_object_set (video1, &quot;start&quot;, 0 * GST_MSECOND, NULL);<br>    g_object_set (video1, &quot;duration&quot;, dur1 * GST_MSECOND, NULL);<br>    g_object_set (video1, &quot;media-start&quot;, 0* GST_MSECOND, NULL);<br>
    g_object_set (video1, &quot;media-duration&quot;, dur1 * GST_MSECOND, NULL);<br>    g_object_set (video1, &quot;priority&quot;, 1,NULL);<br><br>    // crea 2º clip<br>    if ((video2 = gst_element_factory_make(&quot;gnlfilesource&quot;, &quot;video2&quot;)) == NULL)<br>
    {<br>      printf (&quot;\n Falló la creacion del gnlfilesource \n&quot;);<br>      return NULL;<br>    }<br><br><br>    if (gst_bin_add (GST_BIN (comp), video2) == FALSE)<br>    {<br>      printf (&quot;\n No pudo agregar video2 a comp \n&quot;);<br>
      return NULL;<br>    }<br><br>    g_object_set (video2, &quot;location&quot;, argv[2], NULL);<br>    g_object_set (video2,&quot;uri&quot;,argv[2],NULL);<br>    g_object_set (video2, &quot;start&quot;, (dur1-dur_crossfade) * GST_MSECOND, NULL);<br>
    g_object_set (video2, &quot;duration&quot;, dur2 * GST_MSECOND, NULL);<br>    g_object_set (video2, &quot;media-start&quot;, 0 * GST_MSECOND, NULL);<br>    g_object_set (video2, &quot;media-duration&quot;, dur2 * GST_MSECOND, NULL);<br>
    g_object_set (video2, &quot;priority&quot;, 2,NULL);<br><br>    // setup the backend viewer<br>    queue = gst_element_factory_make(&quot;queue&quot;, &quot;queue&quot;);<br>    sink  = gst_element_factory_make(&quot;autovideosink&quot;, &quot;sink&quot;);<br>
<br>    pipeline = gst_pipeline_new (&quot;video-player&quot;);<br><br>    /* Agrego elementos al pipeline */<br><br>    gst_bin_add_many (GST_BIN (pipeline),comp, queue, sink, NULL);<br><br>    g_signal_connect (comp, &quot;pad-added&quot;, G_CALLBACK (on_pad_added),queue);<br>
<br>    gst_element_link (queue, sink);<br><br>    return pipeline;<br><br>}<br><br>void startPlay(GstElement * pip)<br>{<br>    /* Set the pipeline to &quot;playing&quot; state*/<br>  gst_element_set_state (pip, GST_STATE_PLAYING);<br>
<br>}<br><br><br>int main(gint argc, gchar *argv[])<br>{<br>    GMainLoop *loop = NULL;<br><br>    /* init GStreamer */<br>    gst_init (&amp;argc, &amp;argv);<br>    gst_controller_init (&amp;argc, &amp;argv);<br><br>    loop = g_main_loop_new (NULL, FALSE);<br>
<br>    /* chequeamos sintaxis */<br>    if (argc != 3)<br>    {<br>        g_print (&quot;Uso: %s &lt;URI1&gt;  &lt;URI2&gt;\n&quot;, argv[0]);<br>        return -1;<br>    }<br><br>    GstElement * play = getSetPipeline(argv);<br>
<br><br>    GstBus *bus2 = gst_pipeline_get_bus (GST_PIPELINE (play));<br>    gst_bus_add_watch (bus2, bus_call, loop);<br>    gst_object_unref (bus2);<br><br>    cout &lt;&lt; &quot;...PLAY&quot; &lt;&lt; endl;<br><br>    startPlay(play);<br>
<br>    /* now run */<br>    g_main_loop_run (loop);<br><br>    /* also clean up */<br>    gst_element_set_state (play, GST_STATE_NULL);<br>    gst_object_unref (GST_OBJECT (play));<br>    return 0;<br>}<br><br><br><br><br>
<br><div class="gmail_quote">2011/10/25 Stefan Sauer <span dir="ltr">&lt;<a href="mailto:ensonic@hora-obscura.de">ensonic@hora-obscura.de</a>&gt;</span><br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<u></u>

  
    
    
  
  <div bgcolor="#ffffff" text="#000000"><div class="im">
    On 10/25/2011 08:06 AM, Rossana Guerra wrote:
    <blockquote type="cite">Hello everyone, I am translating the following code to
      C/C++: <a href="http://notes.brooks.nu/2011/01/python-gstreamer-controller/" target="_blank">http://notes.brooks.nu/2011/01/python-gstreamer-controller/</a><br>
      It&#39;s a controller for controlling the alpha channel during
      crossfade, I adapted it for transitions, using, smpte instead.<br>
    </blockquote>
    <br></div>
    smptealpha does not have a property called &quot;alpha&quot;. Only &quot;border&quot;
    and &quot;invert&quot; are controllable right now.<br>
    <br>
    Stefan<div><div></div><div class="h5"><br>
    <blockquote type="cite">
      <br>
      The fact is it returns NULL and the programs stop running. The
      code is below, I appreciate any suggestion.<br>
      I am a bit clueless is an adaptation of a code I did before and it
      works.<br>
      <br>
      Thanks and regards.<br>
      <br>
      Rossana<br>
      <br>
      //// the code<br>
      <br>
      #include &lt;gst.h&gt;<br>
      #include &lt;controller/gstcontroller.h&gt;<br>
      <br>
      #include &lt;iostream&gt;<br>
      <br>
      <br>
      using namespace std;<br>
      <br>
      // Manejador de errores<br>
      static gboolean bus_call (GstBus *bus, GstMessage *msg, gpointer
      data)<br>
      {<br>
      ::::::::::::::::::::::::................<br>
      }<br>
      <br>
      static void on_pad_added (GstElement *element, GstPad *pad,
      gpointer  data)<br>
      {<br>
        GstPad *sinkpad = NULL;<br>
        GstElement * elemento = (GstElement *) data;<br>
      <br>
      <br>
        /* Ahora linkeo el pad de comp con sink pad */<br>
        g_print (&quot;Dynamic pad created, linking queue\n&quot;);<br>
        sinkpad = gst_element_get_static_pad (elemento, &quot;sink&quot;);<br>
      <br>
      <br>
        gst_pad_link (pad, sinkpad);<br>
        gst_object_unref(sinkpad);<br>
      <br>
      }<br>
      <br>
      <br>
      int main(int argc, char *argv[])<br>
      {<br>
      <br>
        GMainLoop *loop = NULL;<br>
      <br>
        GstElement *src1,
      *src2,*dec1,*dec2,*alfa1,*color,*smpte,*queue,*sink;<br>
        GstBus *bus;<br>
      <br>
        gdouble duracion = 500;<br>
        gint transicion = 1;<br>
      <br>
        cout &lt;&lt; &quot;Inicio...&quot; &lt;&lt; endl;<br>
      <br>
          /* init GStreamer */<br>
        gst_init (&amp;argc, &amp;argv);<br>
        gst_controller_init (&amp;argc, &amp;argv);<br>
      <br>
        loop = g_main_loop_new (NULL, FALSE);  <br>
      <br>
        /* make sure we have input */<br>
        if (argc != 3) {<br>
          g_print (&quot;Usage: %s &lt;filename1&gt; &lt;filename2&gt;\n&quot;,
      argv[0]);<br>
          return -1;<br>
        }<br>
        <br>
        src1 = gst_element_factory_make(&quot;filesrc&quot;, &quot;src1&quot;);<br>
        g_object_set(G_OBJECT(src1),&quot;location&quot;,argv[1], NULL);<br>
      <br>
        src2 = gst_element_factory_make(&quot;filesrc&quot;, &quot;src2&quot;);<br>
        g_object_set(G_OBJECT(src1),&quot;location&quot;,argv[2], NULL);<br>
      <br>
        GstElement *pipeline = gst_pipeline_new (&quot;video-player&quot;);<br>
      <br>
        dec1 = gst_element_factory_make(&quot;decodebin2&quot;,&quot;dec1&quot;);<br>
      <br>
        dec2 = gst_element_factory_make(&quot;decodebin2&quot;,&quot;dec2&quot;);<br>
      <br>
        bus = gst_pipeline_get_bus (GST_PIPELINE (pipeline));<br>
        gst_bus_add_watch (bus, bus_call, loop);<br>
        gst_object_unref (bus);<br>
      <br>
        alfa1   = gst_element_factory_make (&quot;alpha&quot;,&quot;alfa1&quot;);<br>
        smpte  = gst_element_factory_make (&quot;smptealpha&quot;,&quot;smpte&quot;);<br>
        color  = gst_element_factory_make (&quot;ffmpegcolorspace&quot;, &quot;color&quot;);<br>
        GstElement * mixer  = gst_element_factory_make(&quot;videomixer&quot;,
      &quot;mixer&quot;);<br>
      <br>
        if ((!alfa1) || (!smpte) || (!color) || (!mixer))<br>
        {<br>
            g_printerr (&quot;Alguno de los elementos del Bin no pudo ser
      creado. Saliendo\n&quot;);<br>
           return 0;<br>
        }<br>
      <br>
        queue = gst_element_factory_make(&quot;queue&quot;, &quot;queue&quot;);<br>
        sink  = gst_element_factory_make(&quot;autovideosink&quot;, &quot;sink&quot;);<br>
      <br>
        cout &lt;&lt; &quot;Creando 1...&quot; &lt;&lt; endl;<br>
      <br>
        // Agrego Controlador<br>
      <br>
        GstController * ctrl = NULL;<br>
        if (!(ctrl = gst_controller_new (G_OBJECT(smpte),
      &quot;alpha&quot;,NULL)))  /// Here&#39;s the error, always return NULL<br>
        {<br>
              cout &lt;&lt; &quot;ctrl value...&quot; &lt;&lt; ctrl &lt;&lt;
      endl;         <br>
              GST_WARNING (&quot;No puede controlar el elemento fuente\n&quot;);<br>
              return 1;<br>
        }<br>
    </blockquote>
    <br>
    <br>
    <br>
    </div></div><blockquote type="cite"><div><div></div><div class="h5"><br>
        // Todo valor GValue debe inicializarse en 0<br>
        GValue val_double = { 0, };<br>
        g_value_init (&amp;val_double, G_TYPE_DOUBLE);<br>
      <br>
      <br>
        // Creo la fuente al controlador y la asocio al controlador<br>
        // Seteo modo de interpolacion<br>
      <br>
        GstInterpolationControlSource * csource =
      gst_interpolation_control_source_new();<br>
        gst_controller_set_control_source (ctrl, &quot;alpha&quot;,
      GST_CONTROL_SOURCE (csource));<br>
      <br>
       
gst_interpolation_control_source_set_interpolation_mode(csource,GST_INTERPOLATE_LINEAR);<br>
      <br>
        // Seteo primer valor<br>
        g_value_set_double(&amp;val_double, 0.0);<br>
        gst_interpolation_control_source_set(csource,(0 *
      GST_MSECOND),&amp;val_double);<br>
      <br>
        // Seteo segundo valor<br>
        g_value_set_double (&amp;val_double, duracion);<br>
        gst_interpolation_control_source_set(csource,(1 *
      GST_MSECOND),&amp;val_double);<br>
      <br>
        g_object_unref (csource);<br>
      <br>
        gst_bin_add_many (GST_BIN (pipeline),src1, src2, dec1, dec2,
      alfa1, smpte, mixer, queue, color, sink, NULL);<br>
        g_signal_connect (G_OBJECT (dec1), &quot;pad-added&quot;, G_CALLBACK
      (on_pad_added),alfa1);<br>
        g_signal_connect (G_OBJECT (dec2), &quot;pad-added&quot;, G_CALLBACK
      (on_pad_added),smpte);<br>
      <br>
        gst_element_link (src1,dec1);<br>
        gst_element_link (src2,dec2);<br>
        gst_element_link (alfa1,mixer);<br>
        gst_element_link (smpte,mixer);<br>
        gst_element_link (mixer,queue);<br>
        gst_element_link (queue,sink);<br>
        g_object_set(smpte,&quot;type&quot;, transicion, NULL);<br>
      <br>
        /* now run */<br>
        gst_element_set_state (pipeline, GST_STATE_PLAYING);<br>
        cout &lt;&lt; &quot;Playing...&quot; &lt;&lt; endl;<br>
        g_main_loop_run (loop);<br>
      <br>
          /* also clean up */<br>
        gst_element_set_state (pipeline, GST_STATE_NULL);<br>
        gst_object_unref (GST_OBJECT (pipeline));<br>
      <br>
        return 0;<br>
      }<br>
      <br>
      <br>
      <br>
      </div></div><pre><fieldset></fieldset>
_______________________________________________
gstreamer-devel mailing list
<a href="mailto:gstreamer-devel@lists.freedesktop.org" target="_blank">gstreamer-devel@lists.freedesktop.org</a>
<a href="http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a>
</pre>
    </blockquote>
    <br>
  </div>

<br>_______________________________________________<br>
gstreamer-devel mailing list<br>
<a href="mailto:gstreamer-devel@lists.freedesktop.org">gstreamer-devel@lists.freedesktop.org</a><br>
<a href="http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel" target="_blank">http://lists.freedesktop.org/mailman/listinfo/gstreamer-devel</a><br>
<br></blockquote></div><br>