Appsrc + decodebin + deinterleave + interleave HELP

classic Classic list List threaded Threaded
1 message Options
Reply | Threaded
Open this post in threaded view
|

Appsrc + decodebin + deinterleave + interleave HELP

diegoavila
Hey, I have a problem on my code, its almost done but i cant make that my
queue pads get linked to my sink if i link my sink pads it plays but im not
sure if its a multichannel pipeline because i tried to set volume 0 to each
channel and didtn work
This is my code :


#include <gst/gst.h>

#include <gst/app/gstappsrc.h>

#include <stdio.h>

#include <string.h>
#include <iostream>
#include <stdlib.h>

#include <gdk-pixbuf/gdk-pixbuf.h>

#define CHUNK_SIZE  4096

typedef struct {

    GstPipeline *pipeline;

    GstAppSrc *src;

    GstElement *sink;

    GstElement *decoder;

    GstElement *audioconvert;

    GstElement *audiosink;

    GstElement *audioresample;

    GstElement *deinterleave;

    GstElement *interleave;

    GMainLoop *loop;

    guint sourceid;

    GMappedFile *file;

    guint8 *data;

    gsize length;

    guint64 offset;
    GstCaps *caps;

}gst_app_t;

static gst_app_t gst_app;

#define BUFF_SIZE (1024)

static gboolean print_field (GQuark field, const GValue * value, gpointer
pfx) {

  gchar *str = gst_value_serialize (value);

  g_print ("%s  %15s: %s\n", (gchar *) pfx, g_quark_to_string (field), str);

  g_free (str);

  return TRUE;

}
static void print_caps (const GstCaps * caps, const gchar * pfx) {

  guint i;

  g_return_if_fail (caps != NULL);

  if (gst_caps_is_any (caps)) {

    g_print ("%sANY\n", pfx);

    return;

  }

  if (gst_caps_is_empty (caps)) {

    g_print ("%sEMPTY\n", pfx);

    return;

  }

  for (i = 0; i < gst_caps_get_size (caps); i++) {

    GstStructure *structure = gst_caps_get_structure (caps, i);

    g_print ("%s%s\n", pfx, gst_structure_get_name (structure));

    gst_structure_foreach (structure, print_field, (gpointer) pfx);

  }

}

static gboolean read_data(gst_app_t *app)

{

 GstBuffer *buffer;

    guint len;

    GstFlowReturn ret;

    if (app->offset >= app->length) {

        /* we are EOS, send end-of-stream and remove the source */

        g_signal_emit_by_name (app->src, "end-of-stream", &ret);

        return FALSE;

    }

    /* read the next chunk */

    buffer = gst_buffer_new ();

    len = CHUNK_SIZE;

    if (app->offset + len > app->length)

        len = app->length - app->offset;

    gst_buffer_append_memory (buffer,

                              gst_memory_new_wrapped
(GST_MEMORY_FLAG_READONLY,

                                                      app->data,
app->length, app->offset, len, NULL, NULL));

    g_print ("feed buffer %p, offset %" G_GUINT64_FORMAT "-%u \n", buffer,

             app->offset, len);

    g_signal_emit_by_name (app->src, "push-buffer", buffer, &ret);

    gst_buffer_unref (buffer);

    if (ret != GST_FLOW_OK) {

        /* some error, stop sending data */

        return FALSE;

    }

    app->offset += len;

    return TRUE;

}

static void start_feed (GstElement * playbin, guint size, gst_app_t * app)

{

    if (app->sourceid == 0) {

        g_print("Start feeding \n");

        app->sourceid = g_idle_add ((GSourceFunc) read_data, app);

    }

}

static void stop_feed (GstElement * playbin, gst_app_t * app)

{

    if (app->sourceid != 0) {

        g_print ("Stop feeding \n");

        g_source_remove (app->sourceid);

        app->sourceid = 0;

    }

}

static void cb_new_pad (GstElement *element, GstPad *pad, gpointer data)

{
  gchar *name;

  GstElement *other = data;

  name = gst_pad_get_name (pad);

  g_print ("A new pad %s was created for %s\n", name,
gst_element_get_name(element));

  g_free (name);

  g_print ("element %s will be linked to %s\n",

           gst_element_get_name(element),

           gst_element_get_name(other));

  gst_element_link(element, other);

}

static gboolean bus_callback(GstBus *bus, GstMessage *message, gpointer
*ptr)

{

    gst_app_t *app = (gst_app_t*)ptr;

    switch(GST_MESSAGE_TYPE(message)){

    case GST_MESSAGE_ERROR:{

        gchar *debug;

        GError *err;

        gst_message_parse_error(message, &err, &debug);

        g_print("Error %s\n", err->message);

        g_error_free(err);

        g_free(debug);

        g_main_loop_quit(app->loop);

    }

    break;

    case GST_MESSAGE_EOS:

        g_print("End of stream\n");

        g_main_loop_quit(app->loop);

        break;

    default:

        g_print("got message %s\n", \

            gst_message_type_get_name (GST_MESSAGE_TYPE (message)));

        break;

    }

    return TRUE;

}
int _channels=0;
void il_new_pad (GstElement *decodebin, GstPad *pad, gst_app_t * data)
{
    GstElement* element=0;  
    std::cout<<_channels;

        if (data->pipeline)
        {
            GstElement *queue, *audioconvert, *ares, *audiosink
,*interleave, *volume;

            queue = gst_element_factory_make("queue",  NULL);

            audiosink = gst_element_factory_make("alsasink", NULL);

            //interleave = gst_element_factory_make("interleave", NULL);

            volume = gst_element_factory_make("volume", NULL);

            gst_bin_add_many (GST_BIN (data->pipeline), queue, volume,NULL);

                if(!gst_element_link((GstElement*)queue, volume)){
                    g_warning("failed to link queue anbd volume");
                }
                if(!gst_element_link((GstElement*)volume,data->interleave)){
                    g_warning("failed to link volume anbd interleave");
                }

   /*            
if(!gst_element_link((GstElement*)data->interleave,data->audiosink)){
                    g_warning("failed to link volume anbd interleave");
                }

       
*/
            g_object_set(G_OBJECT (audiosink), "sync", true, NULL);
            //element=data->audiosink;
            element= queue;

            gst_element_sync_state_with_parent(element);

            ++_channels;
        }
        GstCaps *caps;
        GstStructure *str;
        GstPad *audiopad;

        /* only link once */
        audiopad = gst_element_get_static_pad (element, "sink");
        if (GST_PAD_IS_LINKED (audiopad))
        {
                g_object_unref (audiopad);
        }
        /* check media type */
        caps = gst_pad_query_caps (pad,NULL);
        print_caps(caps, "  ");
        str = gst_caps_get_structure (caps, 0);
        if (!g_strrstr (gst_structure_get_name (str), "audio"))
        {
                std::cerr<<"won't connect!"<<std::endl;
                gst_caps_unref (caps);
                gst_object_unref (audiopad);
        }
        gst_caps_unref (caps);
        /* link'n'play */
        gst_pad_link (pad, audiopad);
       


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

    gst_app_t *app = &amp;gst_app;

    GstBus *bus;

    GError *error = NULL;

    GstStateChangeReturn state_ret;


    app->file = g_mapped_file_new ("/home/arion/Downloads/test2.mp3", FALSE,
&error);

    if (error) {

        g_print ("failed to open file: %s \n", error->message);

        g_error_free (error);

    }

    app->length = g_mapped_file_get_length (app->file);

    app->data = (guint8 *) g_mapped_file_get_contents (app->file);

    app->offset = 0;

   

    gst_init(NULL, NULL);

    app->pipeline = (GstPipeline*)gst_pipeline_new("mypipeline");

    bus = gst_pipeline_get_bus(app->pipeline);

    gst_bus_add_watch(bus, (GstBusFunc)bus_callback, app);

    gst_object_unref(bus);

    app->src = (GstAppSrc*)gst_element_factory_make("appsrc", "mysrc");

    app->decoder = gst_element_factory_make("decodebin", "mydecoder");

    app->audioconvert = gst_element_factory_make("audioconvert",
"myaudioconvert");

    app->audiosink = gst_element_factory_make("alsasink", "myvsink");

    app->audioresample =
gst_element_factory_make("audioresample","audio-resample");

    app->deinterleave = gst_element_factory_make("deinterleave", "deint");

    app->interleave = gst_element_factory_make("interleave", "int");

    g_assert(app->src);

    g_assert(app->decoder);

    g_assert(app->audioconvert);

    g_assert(app->audiosink);

    g_assert(app->audioresample);

    g_assert(app->deinterleave);

    g_assert(app->interleave);

    g_object_set (app->interleave, "name", "i", NULL);

    g_object_set (app->src, "size", (gint64) app->length, NULL);

    g_signal_connect(app->src, "need-data", G_CALLBACK(start_feed), app);

    g_signal_connect(app->src, "enough-data", G_CALLBACK(stop_feed), app);

    g_signal_connect(app->decoder, "pad-added", G_CALLBACK(cb_new_pad),
app->audioresample);

    g_signal_connect(app->deinterleave, "pad-added",
G_CALLBACK(il_new_pad),app);

    app->caps = gst_caps_new_simple ("audio/x-raw", "format", G_TYPE_STRING,
"S16LE",  "layout",

    G_TYPE_STRING, "interleaved", "rate", G_TYPE_INT, (int)44100,
"channels", G_TYPE_INT, (int)6, NULL);
   

    gst_bin_add_many(GST_BIN(app->pipeline), (GstElement*)app->src,
app->decoder,
app->audioconvert,app->audioresample,app->deinterleave,app->interleave,
app->audiosink, NULL);

    gboolean link_ok = gst_element_link_filtered (app->audioconvert,
app->deinterleave, app->caps);
    gst_caps_unref (app->caps);
    if (!link_ok) {
        g_warning ("Failed to link element1 and element2!");
        }

    if(!gst_element_link((GstElement*)app->src, app->decoder)){

        g_warning("failed to link src anbd decoder");

    }

    if(!gst_element_link((GstElement*)app->audioresample,
app->audioconvert)){

        g_warning("failed to link audioresample anbd audioconvert");

    }

/*    if(!gst_element_link((GstElement*)app->deinterleave,
app->interleave)){

        g_warning("failed to link deinterleave anbd interleave");

    }
*/
 

    state_ret = gst_element_set_state((GstElement*)app->pipeline,
GST_STATE_PLAYING);

    g_warning("set state returned %d\n", state_ret);

    app->loop = g_main_loop_new(NULL, FALSE);

    printf("Running main loop\n");

    g_main_loop_run(app->loop);

    state_ret = gst_element_set_state((GstElement*)app->pipeline,
GST_STATE_NULL);

    g_warning("set state null returned %d\n", state_ret);

    return 0;

}

<http://gstreamer-devel.966125.n4.nabble.com/file/t378976/pipeline.png>



--
Sent from: http://gstreamer-devel.966125.n4.nabble.com/
_______________________________________________
gstreamer-devel mailing list
[hidden email]
https://lists.freedesktop.org/mailman/listinfo/gstreamer-devel