После приостановки конвейера gstreamer и внесения изменений ничего не было применено, когда вы возвращаетесь в режим воспроизведения? - PullRequest
3 голосов
/ 22 сентября 2011

Приведенный ниже код предназначен для потоковой передачи видео mpeg4 (с использованием элемента v4l2src следующих возможностей: ширина = 640, высота = 480, частота кадров = 30/1) по сети с использованием элемента updsink, и значения возможностей должны измениться на (ширина = 352, высота = 288, частота кадров = 15/1) после нажатия «1» на клавиатуре.Я попытался сделать это, приостановив конвейер после нажатия «1», а затем заново установив caps на новые значения, а затем снова переведя конвейер в состояние воспроизведения, но это не сработало для меня.

Я получаю значения caps, напечатанные до приостановки конвейера и после внесенных изменений, и я вижу, что изменения в caps были сделаны, но не применены, когда конвейер снова приведен в состояние воспроизведения ()

, пожалуйста, помогите.......

вы можете воспроизвести этот поток, введя в новый терминал следующую команду непосредственно перед запуском приведенного ниже кода:

gst-launch udpsrc multicast-group = 127.0.0.1порт = 8999!mpeg4videoparse!ffdec_mpeg4!ffmpegcolorspace!autovideosink

=============================

    #include <gst/gst.h>

    #include <glib.h>

    #include <stdio.h>

    #include <glib-object.h>




    static gboolean bus_call (GstBus *bus, GstMessage *msg, gpointer data)

    {

       GMainLoop *loop = (GMainLoop *) data;

       switch (GST_MESSAGE_TYPE (msg)) {

         case GST_MESSAGE_EOS:

             g_print ("End of stream\n");

             g_main_loop_quit (loop);

             break;




         case GST_MESSAGE_ERROR: {

             gchar *debug;

             GError *error;

             gst_message_parse_error (msg, &error, &debug);

             g_free (debug);

             g_printerr ("Error: %s\n", error->message);

             g_error_free (error);

             g_main_loop_quit (loop);

             break;

             }




         default: break;

         }

    return TRUE;

   }




int main (int argc, char *argv[])

{

   GMainLoop *loop;

   GstElement *pipeline, *source, *filter, *vrate, *encoder, *conv, *sink;

   GstBus *bus;

   GstCaps *filtercaps; 

   gint width, height, num, denom;

   const GstStructure *str;




   /* Initialisation */

   gst_init (&argc, &argv);

   loop = g_main_loop_new (NULL, FALSE);




   /* Check input arguments */

   if (argc != 2) {

     g_printerr ("Usage: %s <Ogg/Vorbis filename>\n", argv[0]);

     return -1;

   }




   /* Create gstreamer elements */

   pipeline = gst_pipeline_new ("video-player");

   source = gst_element_factory_make ("v4l2src", "file-source");

   vrate = gst_element_factory_make ("videorate", "video-rate");

   filter = gst_element_factory_make ("capsfilter", "filter");

   conv = gst_element_factory_make ("ffmpegcolorspace","converter");

   encoder = gst_element_factory_make ("ffenc_mpeg4","mpeg-decoder");

   sink = gst_element_factory_make ("udpsink","audio-output");







   if (!pipeline || !source || !filter || !vrate || !conv || !encoder || !sink) {

     g_printerr ("One element could not be created. Exiting.\n");

     return -1;

   }




   /* Set up the pipeline */

   /* we set the input filename to the source element */

   filtercaps = gst_caps_new_simple ("video/x-raw-yuv",

         "width", G_TYPE_INT, 640,

         "height", G_TYPE_INT, 480,

         "framerate", GST_TYPE_FRACTION, 30, 1,

         NULL);




   g_object_set (G_OBJECT (filter), "caps", filtercaps, NULL);

   gst_caps_unref (filtercaps);

   g_object_set (G_OBJECT (encoder), "bitrate" , 384 ,  NULL);

   g_object_set (G_OBJECT (sink), "host" , argv[1] ,  NULL);

   g_object_set (G_OBJECT (sink), "port" , 8999 ,  NULL);

   g_object_set (G_OBJECT (sink), "async" , FALSE ,  NULL);






   /* we add a message handler */

   bus = gst_pipeline_get_bus (GST_PIPELINE (pipeline));

   gst_bus_add_watch (bus, bus_call, loop);

   gst_object_unref (bus);




   /* we add all elements into the pipeline */

   /* file-source | ogg-demuxer | vorbis-decoder | converter | alsa-output */

   gst_bin_add_many (GST_BIN (pipeline), source, vrate, filter, conv, encoder, sink, NULL);




   /* we link the elements together */

   /* file-source -> ogg-demuxer ~> vorbis-decoder -> converter -> alsa-output */

   gst_element_link_many (source, vrate, filter, conv, encoder,  sink, NULL);









   /* Set the pipeline to "playing" state*/

   g_print ("Now playing: \n");

   gst_element_set_state (pipeline, GST_STATE_PLAYING);





   /* Print out the frame size and rate */

   str = gst_caps_get_structure (filtercaps, 0);

   if (!gst_structure_get_int (str, "width", &width) || !gst_structure_get_int (str, "height", &height) || 

       !gst_structure_get_fraction (str, "framerate", &num, &denom)) 

         g_print ("No width/height available\n");

   g_print ("The video size of this set of capabilities is %dx%d and the frame rate is %d/%d\n", width, height, num, denom);









   /* Pausing the streame */ 

   int in;

   if (scanf ("%d", &in) == 1){

     g_print ("Now pausing: \n");

     gst_element_set_state (pipeline, GST_STATE_PAUSED );



     g_assert (GST_STATE (pipeline) == GST_STATE_PAUSED);

     g_assert (GST_STATE (source) == GST_STATE_PAUSED);

     g_assert (GST_STATE (filter) == GST_STATE_PAUSED);

     g_assert (GST_STATE (vrate) == GST_STATE_PAUSED);

     g_assert (GST_STATE (encoder) == GST_STATE_PAUSED);

     g_assert (GST_STATE (conv) == GST_STATE_PAUSED);

     g_assert (GST_STATE (sink) == GST_STATE_PAUSED);






     /* apply the alterations to the caps now */

     gst_caps_set_simple (filtercaps, "width", G_TYPE_INT, 352, "height", G_TYPE_INT, 288, "framerate", GST_TYPE_FRACTION, 15, 1, NULL);    





         /* Print out the frame size and rate after alteration*/

     str = gst_caps_get_structure (filtercaps, 0);

        if (!gst_structure_get_int (str, "width", &width) || !gst_structure_get_int (str, "height", &height) || 

        !gst_structure_get_fraction (str, "framerate", &num, &denom)) 

         g_print ("No width/height available\n");

     g_print ("The video size of this set of capabilities is %dx%d and the frame rate is %d/%d\n", width, height, num, denom);  



     /* set back to playing */

     gst_element_set_state (pipeline, GST_STATE_PLAYING);




     g_assert (GST_STATE (pipeline) == GST_STATE_PLAYING);

     g_assert (GST_STATE (source) == GST_STATE_PLAYING);

     g_assert (GST_STATE (filter) == GST_STATE_PLAYING);

     g_assert (GST_STATE (vrate) == GST_STATE_PLAYING);

     g_assert (GST_STATE (encoder) == GST_STATE_PLAYING);

     g_assert (GST_STATE (conv) == GST_STATE_PLAYING);

     g_assert (GST_STATE (sink) == GST_STATE_PLAYING);  



     }






   /* Iterate */

   g_print ("Running...\n");

   g_main_loop_run (loop);





   /* Out of the main loop, clean up nicely */

   g_print ("Returned, stopping playback\n");

   gst_element_set_state (pipeline, GST_STATE_NULL);

   g_print ("Deleting pipeline\n");

   gst_object_unref (GST_OBJECT (pipeline));




   return 0;

}

Приветствия.

Ибра

1 Ответ

3 голосов
/ 02 февраля 2012

вы пропустите функцию g_object_set(G_OBJECT(filter), "caps", filtercaps, NULL);

...