diff options
Diffstat (limited to 'binding')
-rw-r--r-- | binding/CMakeLists.txt | 3 | ||||
-rw-r--r-- | binding/afm-mediaplayer-binding.c | 29 |
2 files changed, 32 insertions, 0 deletions
diff --git a/binding/CMakeLists.txt b/binding/CMakeLists.txt index 02f2aa9..2df218b 100644 --- a/binding/CMakeLists.txt +++ b/binding/CMakeLists.txt @@ -39,3 +39,6 @@ PROJECT_TARGET_ADD(afm-mediaplayer-binding) INSTALL(TARGETS ${TARGET_NAME} LIBRARY DESTINATION ${BINDINGS_INSTALL_DIR}) + if(HAVE_4A_FRAMEWORK) + add_definitions(-DHAVE_4A_FRAMEWORK) + endif() diff --git a/binding/afm-mediaplayer-binding.c b/binding/afm-mediaplayer-binding.c index 2e3bef2..478ba0e 100644 --- a/binding/afm-mediaplayer-binding.c +++ b/binding/afm-mediaplayer-binding.c @@ -660,6 +660,35 @@ static void *gstreamer_loop_thread(void *ptr) data.fake_sink = gst_element_factory_make("fakesink", NULL); data.alsa_sink = gst_element_factory_make("alsasink", NULL); +#ifdef HAVE_4A_FRAMEWORK + json_object *jsonData = json_object_new_object(); + json_object_object_add(jsonData, "audio_role", json_object_new_string("Multimedia")); + json_object_object_add(jsonData, "endpoint_type", json_object_new_string("sink")); + ret = afb_service_call_sync("ahl-4a", "stream_open", jsonData, &response); + + if (!ret) { + json_object *valJson = NULL; + json_object *val = NULL; + gboolean ret; + ret = json_object_object_get_ex(response, "response", &valJson); + if (ret) { + ret = json_object_object_get_ex(valJson, "device_uri", &val); + if (ret) { + char* jres_pcm = json_object_get_string(val); + gchar ** res_pcm= g_strsplit (jres_pcm,":",-1); + if (res_pcm) { + g_object_set(data.alsa_sink, "device", res_pcm[1], NULL); + g_free(res_pcm); + } + } + ret = json_object_object_get_ex(valJson, "stream_id", &val); + if (ret) { + int stream_id = json_object_get_int(val); + } + } + } +#endif + g_object_set(data.playbin, "audio-sink", data.fake_sink, NULL); gst_element_set_state(data.playbin, GST_STATE_PAUSED); |