diff options
author | Ronan Le Martret <ronan.lemartret@iot.bzh> | 2017-12-05 11:06:07 +0100 |
---|---|---|
committer | Scott Murray <scott.murray@konsulko.com> | 2017-12-20 19:24:21 -0500 |
commit | d03590991d2c7104e7cd4b2a18e710008b2759ab (patch) | |
tree | 93f69d19982cc4ea4a3b6a317558e0b399492447 /binding | |
parent | da737e24ee735b5dbcf773997ee1f42cd4cc9888 (diff) |
Add 4A supporteel_5.0.0eel_4.99.5eel/5.0.0eel/4.99.55.0.04.99.5
Add conditional compilation option to enable using the 4A high-level
API to request Multimedia role access.
Change-Id: I85c19e33a355f9133bdda837e9374776fc92efe9
Signed-off-by: Ronan Le Martret <ronan.lemartret@iot.bzh>
Signed-off-by: Scott Murray <scott.murray@konsulko.com>
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); |