2 * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 #include <player_internal.h>
18 #include <sound_manager.h>
22 #include <appcore-efl.h>
23 #include <Elementary.h>
25 #include <Ecore_Wayland.h>
33 #define PACKAGE "player_test"
38 #define LOG_TAG "PLAYER_TEST"
40 #define MAX_STRING_LEN 2048
41 #define PLAYER_TEST_DUMP_PATH_PREFIX "/home/owner/dump_pcm_"
42 #define DEFAULT_HTTP_TIMEOUT -1
44 #include <system_info.h>
47 TIZEN_PROFILE_UNKNOWN = 0,
48 TIZEN_PROFILE_MOBILE = 0x1,
49 TIZEN_PROFILE_WEARABLE = 0x2,
50 TIZEN_PROFILE_TV = 0x4,
51 TIZEN_PROFILE_IVI = 0x8,
52 TIZEN_PROFILE_COMMON = 0x10,
54 static tizen_profile_t _get_tizen_profile()
57 static tizen_profile_t profile = TIZEN_PROFILE_UNKNOWN;
59 if (__builtin_expect(profile != TIZEN_PROFILE_UNKNOWN, 1))
62 system_info_get_platform_string("http://tizen.org/feature/profile", &profileName);
63 switch (*profileName) {
66 profile = TIZEN_PROFILE_MOBILE;
70 profile = TIZEN_PROFILE_WEARABLE;
74 profile = TIZEN_PROFILE_TV;
78 profile = TIZEN_PROFILE_IVI;
80 default: // common or unknown ==> ALL ARE COMMON.
81 profile = TIZEN_PROFILE_COMMON;
87 #define TIZEN_TV ((_get_tizen_profile()) == TIZEN_PROFILE_TV)
89 static gboolean g_memory_playback = FALSE;
90 static char g_uri[MAX_STRING_LEN];
91 static char g_subtitle_uri[MAX_STRING_LEN];
92 static FILE *g_pcm_fd;
94 static gboolean is_es_push_mode = FALSE;
95 static pthread_t g_feed_video_thread_id = 0;
96 static bool g_thread_end = FALSE;
97 static media_packet_h g_audio_pkt = NULL;
98 static media_format_h g_audio_fmt = NULL;
100 static media_packet_h g_video_pkt = NULL;
101 static media_format_h g_video_fmt = NULL;
103 static int _save(unsigned char *src, int length);
105 #define DUMP_OUTBUF 1
107 FILE *fp_out1 = NULL;
108 FILE *fp_out2 = NULL;
112 CURRENT_STATUS_MAINMENU,
113 CURRENT_STATUS_HANDLE_NUM,
114 CURRENT_STATUS_FILENAME,
115 CURRENT_STATUS_VOLUME,
116 CURRENT_STATUS_SOUND_TYPE,
117 CURRENT_STATUS_SOUND_STREAM_INFO,
119 CURRENT_STATUS_POSITION_TIME,
120 CURRENT_STATUS_LOOPING,
121 CURRENT_STATUS_DISPLAY_SURFACE_CHANGE,
122 CURRENT_STATUS_DISPLAY_MODE,
123 CURRENT_STATUS_DISPLAY_DST_ROI,
124 CURRENT_STATUS_DISPLAY_ROTATION,
125 CURRENT_STATUS_DISPLAY_VISIBLE,
126 CURRENT_STATUS_SUBTITLE_FILENAME,
127 CURRENT_STATUS_AUDIO_EQUALIZER,
128 CURRENT_STATUS_PLAYBACK_RATE,
129 CURRENT_STATUS_STREAMING_PLAYBACK_RATE,
130 CURRENT_STATUS_SWITCH_SUBTITLE,
131 CURRENT_STATUS_NEXT_URI,
132 CURRENT_STATUS_GAPLESS,
133 CURRENT_STATUS_GET_TRACK_INFO,
136 #define MAX_HANDLE 20
138 /* for video display */
139 static Evas_Object *g_win_id;
140 #ifdef _ACTIVATE_EOM_
141 static Evas_Object *g_external_win_id;
143 static Evas_Object *selected_win_id;
144 static Evas_Object *g_eo[MAX_HANDLE] = { 0, };
146 static int g_current_surface_type = -1;
150 Evas_Object *layout_main; /* layout widget based on EDJ */
151 /* add more variables here */
152 #ifdef _ACTIVATE_EOM_
158 static player_h g_player[MAX_HANDLE] = { 0, };
160 int g_handle_num = 1;
161 int g_menu_state = CURRENT_STATUS_MAINMENU;
162 gboolean quit_pushing;
163 sound_stream_info_h g_stream_info_h = NULL;
165 static void win_del(void *data, Evas_Object * obj, void *event)
170 static Evas_Object *create_win(const char *name)
172 Evas_Object *eo = NULL;
176 g_print("[%s][%d] name=%s\n", __func__, __LINE__, name);
178 eo = elm_win_add(NULL, name, ELM_WIN_BASIC);
180 elm_win_title_set(eo, name);
181 elm_win_borderless_set(eo, EINA_TRUE);
182 evas_object_smart_callback_add(eo, "delete,request", win_del, NULL);
183 elm_win_screen_size_get(eo, NULL, NULL, &w, &h);
184 g_print("window size :%d,%d", w, h);
185 evas_object_resize(eo, w, h);
186 elm_win_autodel_set(eo, EINA_TRUE);
187 elm_win_alpha_set(eo, EINA_TRUE);
192 static Evas_Object *create_image_object(Evas_Object * eo_parent)
197 Evas *evas = evas_object_evas_get(eo_parent);
198 Evas_Object *eo = NULL;
200 eo = evas_object_image_add(evas);
205 void create_render_rect_and_bg(Evas_Object * win)
211 Evas_Object *bg, *rect;
213 bg = elm_bg_add(win);
214 elm_win_resize_object_add(win, bg);
215 evas_object_size_hint_weight_set(bg, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
216 evas_object_show(bg);
218 rect = evas_object_rectangle_add(evas_object_evas_get(win));
223 evas_object_color_set(rect, 0, 0, 0, 0);
224 evas_object_render_op_set(rect, EVAS_RENDER_COPY);
226 elm_win_resize_object_add(win, rect);
227 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
228 evas_object_show(rect);
229 evas_object_show(win);
232 #ifdef _ACTIVATE_EOM_
233 int eom_get_output_id(const char *output_name)
235 eom_output_id *output_ids = NULL;
236 eom_output_id output_id = 0;
237 eom_output_type_e output_type = EOM_OUTPUT_TYPE_UNKNOWN;
242 output_ids = eom_get_eom_output_ids(&id_cnt);
244 g_print("[eom] no external outuputs supported\n");
248 /* find output ids interested */
249 for (i = 0; i < id_cnt; i++) {
250 eom_get_output_type(output_ids[i], &output_type);
251 if (!strncmp(output_name, "HDMI", 4)) {
252 if (output_type == EOM_OUTPUT_TYPE_HDMIA || output_type == EOM_OUTPUT_TYPE_HDMIB) {
253 output_id = output_ids[i];
256 } else if (!strncmp(output_name, "Virtual", 4)) {
257 if (output_type == EOM_OUTPUT_TYPE_VIRTUAL) {
258 output_id = output_ids[i];
270 static void eom_notify_cb_output_add(eom_output_id output_id, void *user_data)
272 appdata *info = (appdata *) user_data;
274 if (info->hdmi_output_id != output_id) {
275 g_print("[eom] OUTPUT ADDED. SKIP. my output ID is %d\n", info->hdmi_output_id);
278 g_print("[eom] output(%d) connected\n", output_id);
279 /* it is for external window */
280 if (!g_external_win_id) {
281 g_external_win_id = elm_win_add(NULL, "External", ELM_WIN_BASIC);
282 if (eom_set_output_window(info->hdmi_output_id, g_external_win_id) == EOM_ERROR_NONE) {
283 create_render_rect_and_bg(g_external_win_id);
284 g_print("[eom] create external window\n");
286 evas_object_del(g_external_win_id);
287 g_external_win_id = NULL;
288 g_print("[eom] create external window fail\n");
293 static void eom_notify_cb_output_remove(eom_output_id output_id, void *user_data)
295 appdata *info = (appdata *) user_data;
296 player_state_e state;
298 if (info->hdmi_output_id != output_id) {
299 g_print("[eom] OUTPUT REMOVED. SKIP. my output ID is %d\n", info->hdmi_output_id);
302 g_print("[eom] output(%d) disconnected\n", output_id);
304 if (selected_win_id == g_external_win_id && g_player[0]) {
305 player_get_state(g_player[0], &state);
306 if (state >= PLAYER_STATE_READY) {
308 g_win_id = create_win(PACKAGE);
309 if (g_win_id == NULL)
311 g_print("create win_id %p\n", g_win_id);
312 create_render_rect_and_bg(g_win_id);
313 elm_win_activate(g_win_id);
314 evas_object_show(g_win_id);
316 player_set_display(g_player[0], PLAYER_DISPLAY_TYPE_OVERLAY, GET_DISPLAY(g_win_id));
320 /* it is for external window */
321 if (g_external_win_id) {
322 evas_object_del(g_external_win_id);
323 g_external_win_id = NULL;
325 selected_win_id = g_win_id;
328 static void eom_notify_cb_mode_changed(eom_output_id output_id, void *user_data)
330 appdata *info = (appdata *) user_data;
331 eom_output_mode_e mode = EOM_OUTPUT_MODE_NONE;
333 if (info->hdmi_output_id != output_id) {
334 g_print("[eom] MODE CHANGED. SKIP. my output ID is %d\n", info->hdmi_output_id);
338 eom_get_output_mode(output_id, &mode);
339 g_print("[eom] output(%d) mode changed(%d)\n", output_id, mode);
342 static void eom_notify_cb_attribute_changed(eom_output_id output_id, void *user_data)
344 appdata *info = (appdata *) user_data;
346 eom_output_attribute_e attribute = EOM_OUTPUT_ATTRIBUTE_NONE;
347 eom_output_attribute_state_e state = EOM_OUTPUT_ATTRIBUTE_STATE_NONE;
349 if (info->hdmi_output_id != output_id) {
350 g_print("[eom] ATTR CHANGED. SKIP. my output ID is %d\n", info->hdmi_output_id);
354 eom_get_output_attribute(output_id, &attribute);
355 eom_get_output_attribute_state(output_id, &state);
357 g_print("[eom] output(%d) attribute changed(%d, %d)\n", output_id, attribute, state);
358 if (state == EOM_OUTPUT_ATTRIBUTE_STATE_ACTIVE) {
359 g_print("[eom] active\n");
360 if (!g_external_win_id) {
361 g_external_win_id = elm_win_add(NULL, "External", ELM_WIN_BASIC);
362 if (eom_set_output_window(info->hdmi_output_id, g_external_win_id) == EOM_ERROR_NONE) {
363 create_render_rect_and_bg(g_external_win_id);
364 g_print("[eom] create external window\n");
366 evas_object_del(g_external_win_id);
367 g_external_win_id = NULL;
368 g_print("[eom] create external window fail\n");
371 selected_win_id = g_external_win_id;
372 /* play video on external window */
374 player_set_display(g_player[0], PLAYER_DISPLAY_TYPE_OVERLAY, GET_DISPLAY(selected_win_id));
375 } else if (state == EOM_OUTPUT_ATTRIBUTE_STATE_INACTIVE) {
376 g_print("[eom] inactive\n");
378 g_win_id = create_win(PACKAGE);
379 if (g_win_id == NULL)
381 g_print("create win_id %p\n", g_win_id);
382 create_render_rect_and_bg(g_win_id);
383 elm_win_activate(g_win_id);
384 evas_object_show(g_win_id);
386 selected_win_id = g_win_id;
388 player_set_display(g_player[0], PLAYER_DISPLAY_TYPE_OVERLAY, GET_DISPLAY(selected_win_id));
390 if (g_external_win_id) {
391 evas_object_del(g_external_win_id);
392 g_external_win_id = NULL;
394 } else if (state == EOM_OUTPUT_ATTRIBUTE_STATE_LOST) {
395 g_print("[eom] lost\n");
397 g_win_id = create_win(PACKAGE);
398 if (g_win_id == NULL)
400 g_print("create win_id %p\n", g_win_id);
401 create_render_rect_and_bg(g_win_id);
402 elm_win_activate(g_win_id);
403 evas_object_show(g_win_id);
405 selected_win_id = g_win_id;
408 player_set_display(g_player[0], PLAYER_DISPLAY_TYPE_OVERLAY, GET_DISPLAY(selected_win_id));
410 if (g_external_win_id) {
411 evas_object_del(g_external_win_id);
412 g_external_win_id = NULL;
415 eom_unset_output_added_cb(eom_notify_cb_output_add);
416 eom_unset_output_removed_cb(eom_notify_cb_output_remove);
417 eom_unset_mode_changed_cb(eom_notify_cb_mode_changed);
418 eom_unset_attribute_changed_cb(eom_notify_cb_attribute_changed);
424 static int app_create(void *data)
427 Evas_Object *win = NULL;
428 #ifdef _ACTIVATE_EOM_
429 eom_output_mode_e output_mode = EOM_OUTPUT_MODE_NONE;
432 elm_config_accel_preference_set("opengl");
435 win = create_win(PACKAGE);
440 selected_win_id = g_win_id;
441 create_render_rect_and_bg(ad->win);
442 /* Create evas image object for EVAS surface */
443 g_eo[0] = create_image_object(ad->win);
444 evas_object_image_size_set(g_eo[0], 500, 500);
445 evas_object_image_fill_set(g_eo[0], 0, 0, 500, 500);
446 evas_object_resize(g_eo[0], 500, 500);
448 elm_win_activate(win);
449 evas_object_show(win);
450 #ifdef _ACTIVATE_EOM_
451 /* check external device */
453 ad->hdmi_output_id = eom_get_output_id("HDMI");
454 if (ad->hdmi_output_id == 0) {
455 g_print("[eom] error : HDMI output id is NULL.\n");
459 g_print("eom_set_output_attribute EOM_OUTPUT_ATTRIBUTE_NORMAL(id:%d)\n", ad->hdmi_output_id);
460 if (eom_set_output_attribute(ad->hdmi_output_id, EOM_OUTPUT_ATTRIBUTE_NORMAL) != EOM_ERROR_NONE) {
461 g_print("attribute set fail. cannot use external output\n");
465 eom_get_output_mode(ad->hdmi_output_id, &output_mode);
466 if (output_mode != EOM_OUTPUT_MODE_NONE) {
467 g_external_win_id = elm_win_add(NULL, "External", ELM_WIN_BASIC);
468 if (eom_set_output_window(ad->hdmi_output_id, g_external_win_id) == EOM_ERROR_NONE) {
469 create_render_rect_and_bg(g_external_win_id);
470 g_print("[eom] create external window\n");
472 evas_object_del(g_external_win_id);
473 g_external_win_id = NULL;
474 g_print("[eom] create external window fail\n");
476 selected_win_id = g_external_win_id;
479 /* set callback for detecting external device */
480 eom_set_output_added_cb(eom_notify_cb_output_add, ad);
481 eom_set_output_removed_cb(eom_notify_cb_output_remove, ad);
482 eom_set_mode_changed_cb(eom_notify_cb_mode_changed, ad);
483 eom_set_attribute_changed_cb(eom_notify_cb_attribute_changed, ad);
488 static int app_terminate(void *data)
493 for (i = 0; i < MAX_HANDLE; i++) {
495 evas_object_del(g_eo[i]);
500 evas_object_del(g_win_id);
503 #ifdef _ACTIVATE_EOM_
504 if (g_external_win_id) {
505 evas_object_del(g_external_win_id);
506 g_external_win_id = NULL;
510 selected_win_id = NULL;
511 #ifdef _ACTIVATE_EOM_
512 eom_unset_output_added_cb(eom_notify_cb_output_add);
513 eom_unset_output_removed_cb(eom_notify_cb_output_remove);
514 eom_unset_mode_changed_cb(eom_notify_cb_mode_changed);
515 eom_unset_attribute_changed_cb(eom_notify_cb_attribute_changed);
522 struct appcore_ops ops = {
523 .create = app_create,
524 .terminate = app_terminate,
527 static void prepared_cb(void *user_data)
529 g_print("[Player_Test] prepared_cb!!!!\n");
532 static void _audio_frame_decoded_cb_ex(player_audio_raw_data_s * audio_raw_frame, void *user_data)
534 player_audio_raw_data_s *audio_raw = audio_raw_frame;
539 g_print("[Player_Test] decoded_cb_ex! channel: %d channel_mask: %llu\n", audio_raw->channel, audio_raw->channel_mask);
542 if (audio_raw->channel_mask == 1 && fp_out1)
543 fwrite((guint8 *) audio_raw->data, 1, audio_raw->size, fp_out1);
544 else if (audio_raw->channel_mask == 2 && fp_out2)
545 fwrite((guint8 *) audio_raw->data, 1, audio_raw->size, fp_out2);
549 static void progress_down_cb(player_pd_message_type_e type, void *user_data)
551 g_print("[Player_Test] progress_down_cb!!!! type : %d\n", type);
554 static void buffering_cb(int percent, void *user_data)
556 g_print("[Player_Test] buffering_cb!!!! percent : %d\n", percent);
559 static void seek_completed_cb(void *user_data)
561 g_print("[Player_Test] seek_completed_cb!!! \n");
564 static void completed_cb(void *user_data)
566 g_print("[Player_Test] completed_cb!!!!\n");
569 static void error_cb(int code, void *user_data)
571 g_print("[Player_Test] error_cb!!!! code : %d\n", code);
574 static void interrupted_cb(player_interrupted_code_e code, void *user_data)
576 g_print("[Player_Test] interrupted_cb!!!! code : %d\n", code);
579 static void video_changed_cb(int width, int height, int fps, int bit_rate, void *user_data)
581 g_print("[Player_Test] video_changed_cb!!!! %d x %d, %d, %d \n", width, height, fps, bit_rate);
585 static void audio_frame_decoded_cb(unsigned char *data, unsigned int size, void *user_data)
589 if (data && g_pcm_fd)
590 fwrite(data, 1, size, g_pcm_fd);
591 player_get_play_position(g_player[0], &pos);
592 g_print("[Player_Test] audio_frame_decoded_cb [size: %d] --- current pos : %d!!!!\n", size, pos);
596 static void subtitle_updated_cb(unsigned long duration, char *text, void *user_data)
598 g_print("[Player_Test] subtitle_updated_cb!!!! [%ld] %s\n", duration, text);
601 static void video_captured_cb(unsigned char *data, int width, int height, unsigned int size, void *user_data)
603 g_print("[Player_Test] video_captured_cb!!!! width: %d, height : %d, size : %d \n", width, height, size);
607 static int _save(unsigned char *src, int length)
609 /* unlink(CAPTUERD_IMAGE_SAVE_PATH); */
611 char filename[256] = { 0, };
612 static int WRITE_COUNT = 0;
613 /* gchar *filename = CAPTUERD_IMAGE_SAVE_PATH; */
614 snprintf(filename, 256, "/tmp/IMAGE_client%d", WRITE_COUNT);
616 fp = fopen(filename, "w+");
618 g_print("file open error!!\n");
621 g_print("open success\n");
622 if (fwrite(src, 1, length, fp) < 1) {
623 g_print("file write error!!\n");
627 g_print("write success(%s)\n", filename);
634 static void reset_display()
638 /* delete evas window, if it is */
639 for (i = 0; i < MAX_HANDLE; i++) {
641 evas_object_del(g_eo[i]);
647 static void input_filename(char *filename)
649 int len = strlen(filename);
652 if (len < 0 || len > MAX_STRING_LEN - 1)
655 for (i = 0; i < g_handle_num; i++) {
656 if (g_player[i] != NULL) {
657 player_unprepare(g_player[i]);
658 player_destroy(g_player[i]);
662 if (player_create(&g_player[i]) != PLAYER_ERROR_NONE)
663 g_print("player create is failed\n");
666 strncpy(g_uri, filename, len);
670 /* ned(APPSRC_TEST) */
675 GError *error = NULL;
676 guint8 *g_media_mem = NULL;
680 file = g_mapped_file_new(ext, FALSE, &error);
681 file_size = g_mapped_file_get_length(file);
682 g_media_mem = (guint8 *) g_mapped_file_get_contents(file);
684 g_sprintf(uri, "mem://ext=%s,size=%d", ext ? ext : "", file_size);
685 g_print("[uri] = %s\n", uri);
687 mm_player_set_attribute(g_player[0], &g_err_name, "profile_uri", uri, strlen(uri), "profile_user_param", g_media_mem, file_size NULL);
689 /* player_set_uri(g_player[0], filename); */
694 player_state_e state;
695 for (i = 0; i < g_handle_num; i++) {
696 ret = player_get_state(g_player[i], &state);
697 g_print("player_get_state returned [%d]\n", ret);
698 g_print("1. After player_create() - Current State : %d \n", state);
702 /* use this API instead of player_set_uri */
703 static void player_set_memory_buffer_test()
707 guint8 *g_media_mem = NULL;
709 file = g_mapped_file_new(g_uri, FALSE, NULL);
710 file_size = g_mapped_file_get_length(file);
711 g_media_mem = (guint8 *) g_mapped_file_get_contents(file);
713 int ret = player_set_memory_buffer(g_player[0], (void *)g_media_mem, file_size);
714 g_print("player_set_memory_buffer ret : %d\n", ret);
717 int video_packet_count = 0;
719 static void buffer_need_video_data_cb(unsigned int size, void *user_data)
721 int real_read_len = 0;
724 static guint64 pts = 0L;
727 guint8 *buff_ptr = NULL;
730 memset(fname, 0, 128);
731 memset(fptsname, 0, 128);
733 video_packet_count++;
735 if (video_packet_count > 1000) {
738 /* player_submit_packet(g_player[0], NULL, 0, 0, 1); */
739 player_push_media_stream(g_player[0], NULL);
743 /* snprintf(fname, 128, "/opt/storage/usb/test/packet/packet_%d.dat", video_packet_count); */
744 /* snprintf(fptsname, 128, "/opt/storage/usb/test/packet/gstpts_%d.dat", video_packet_count); */
745 snprintf(fname, 128, "/home/developer/test/packet/packet_%d.dat", video_packet_count);
746 snprintf(fptsname, 128, "/home/developer/test/packet/gstpts_%d.dat", video_packet_count);
748 fp = fopen(fptsname, "rb");
751 pts_len = fread(&pts, 1, sizeof(guint64), fp);
752 if (pts_len != sizeof(guint64))
753 g_print("Warning, pts value can be wrong.\n");
758 fp = fopen(fname, "rb");
760 buff_ptr = (guint8 *) g_malloc0(1048576);
762 g_print("no free space\n");
767 real_read_len = fread(buff_ptr, 1, size, fp);
771 g_print("video need data - data size : %d, pts : %" G_GUINT64_FORMAT "\n", real_read_len, pts);
773 player_submit_packet(g_player[0], buff_ptr, real_read_len, (pts / 1000000), 1);
775 /* create media packet */
777 media_packet_destroy(g_video_pkt);
781 media_packet_create_alloc(g_video_fmt, NULL, NULL, &g_video_pkt);
783 g_print("packet = %p, src = %p\n", g_video_pkt, src);
785 if (media_packet_get_buffer_data_ptr(g_video_pkt, &src) != MEDIA_PACKET_ERROR_NONE)
788 if (media_packet_set_pts(g_video_pkt, (uint64_t) pts) != MEDIA_PACKET_ERROR_NONE)
791 if (media_packet_set_buffer_size(g_video_pkt, (uint64_t) real_read_len) != MEDIA_PACKET_ERROR_NONE)
794 memcpy(src, buff_ptr, real_read_len);
797 player_push_media_stream(g_player[0], g_video_pkt);
807 int audio_packet_count = 0;
808 static void buffer_need_audio_data_cb(unsigned int size, void *user_data)
810 int real_read_len = 0;
813 guint8 *buff_ptr = NULL;
816 memset(fname, 0, 128);
817 audio_packet_count++;
819 if (audio_packet_count > 1000) {
821 /* player_submit_packet(g_player[0], NULL, 0, 0, 0); */
822 player_push_media_stream(g_player[0], NULL);
826 /* snprintf(fname, 128, "/opt/storage/usb/test/audio_packet/packet_%d.dat", audio_packet_count); */
827 snprintf(fname, 128, "/home/developer/test/audio_packet/packet_%d.dat", audio_packet_count);
829 static guint64 audio_pts = 0;
830 guint64 audio_dur = 21333333;
832 fp = fopen(fname, "rb");
834 buff_ptr = (guint8 *) g_malloc0(1048576);
836 g_print("no free space\n");
841 real_read_len = fread(buff_ptr, 1, size, fp);
845 g_print("\t audio need data - data size : %d, pts : %" G_GUINT64_FORMAT "\n", real_read_len, audio_pts);
848 player_submit_packet(g_player[0], buff_ptr, real_read_len, (audio_pts / 1000000), 0);
850 /* create media packet */
852 media_packet_destroy(g_audio_pkt);
855 media_packet_create_alloc(g_audio_fmt, NULL, NULL, &g_audio_pkt);
857 g_print("packet = %p, src = %p\n", g_audio_pkt, src);
859 if (media_packet_get_buffer_data_ptr(g_audio_pkt, &src) != MEDIA_PACKET_ERROR_NONE)
862 if (media_packet_set_pts(g_audio_pkt, (uint64_t) audio_pts) != MEDIA_PACKET_ERROR_NONE)
865 if (media_packet_set_buffer_size(g_audio_pkt, (uint64_t) real_read_len) != MEDIA_PACKET_ERROR_NONE)
868 memcpy(src, buff_ptr, real_read_len);
871 player_push_media_stream(g_player[0], g_audio_pkt);
874 audio_pts += audio_dur;
882 static void set_content_info(bool is_push_mode)
884 /* testcode for es buff src case, please input url as es_buff://123 or es_buff://push_mode */
885 /* unsigned char codec_data[45] = {0x0,0x0,0x1,0xb0,0x1,0x0,0x0,0x1,0xb5,0x89,0x13,0x0,0x0,0x1,0x0,0x0,0x0,0x1,0x20,0x0,0xc4,0x8d,0x88,0x5d,0xad,0x14,0x4,0x22,0x14,0x43,0x0,0x0,0x1,0xb2,0x4c,0x61,0x76,0x63,0x35,0x31,0x2e,0x34,0x30,0x2e,0x34}; */
887 /* create media format */
888 media_format_create(&g_audio_fmt);
889 media_format_create(&g_video_fmt);
892 /* configure media format for video and set to player */
893 media_format_set_video_mime(g_video_fmt, MEDIA_FORMAT_MPEG4_SP);
894 media_format_set_video_width(g_video_fmt, 640);
895 media_format_set_video_height(g_video_fmt, 272);
896 /* player_set_media_stream_info(g_player[0], PLAYER_STREAM_TYPE_VIDEO, g_video_fmt); */
898 /* Audio--aac--StarWars.mp4 */
899 media_format_set_audio_mime(g_audio_fmt, MEDIA_FORMAT_AAC);
900 media_format_set_audio_channel(g_audio_fmt, 2);
901 media_format_set_audio_samplerate(g_audio_fmt, 48000);
902 /* player_set_media_stream_info(g_player[0], PLAYER_STREAM_TYPE_AUDIO, g_audio_fmt); */
904 /* video_info->mime = g_strdup("video/mpeg"); *//* CODEC_ID_MPEG4VIDEO */
905 video_info->width = 640;
906 video_info->height = 272;
907 video_info->version = 4;
908 video_info->framerate_den = 100;
909 video_info->framerate_num = 2997;
911 video_info->extradata_size = 45;
912 video_info->codec_extradata = codec_data;
913 player_set_video_stream_info(g_player[0], video_info);
915 /* audio--aac--StarWars.mp4 */
916 /* audio_info->mime = g_strdup("audio/mpeg"); */
917 /* audio_info->version = 2; */
918 /* audio_info->user_info = 0; *//* raw */
923 player_set_buffer_need_video_data_cb(g_player[0], buffer_need_video_data_cb, (void *)g_player[0]);
924 player_set_buffer_need_audio_data_cb(g_player[0], buffer_need_audio_data_cb, (void *)g_player[0]);
929 static void feed_video_data_thread_func(void *data)
931 while (!g_thread_end) {
932 buffer_need_video_data_cb(1048576, NULL);
933 buffer_need_audio_data_cb(1048576, NULL);
937 static void _player_prepare(bool async)
940 int slen = strlen(g_subtitle_uri);
942 if (slen > 0 && slen < MAX_STRING_LEN) {
943 g_print("0. set subtile path() (size : %d) - %s \n", slen, g_subtitle_uri);
944 player_set_subtitle_path(g_player[0], g_subtitle_uri);
945 player_set_subtitle_updated_cb(g_player[0], subtitle_updated_cb, (void *)g_player[0]);
947 if (g_current_surface_type == -1) {
948 g_print("You must set display surface type before setting prepare.\n");
952 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
953 player_set_buffering_cb(g_player[0], buffering_cb, (void *)g_player[0]);
954 player_set_completed_cb(g_player[0], completed_cb, (void *)g_player[0]);
955 player_set_interrupted_cb(g_player[0], interrupted_cb, (void *)g_player[0]);
956 player_set_error_cb(g_player[0], error_cb, (void *)g_player[0]);
957 player_set_video_stream_changed_cb(g_player[0], video_changed_cb, (void *)g_player[0]);
958 if (g_memory_playback)
959 player_set_memory_buffer_test();
961 player_set_uri(g_player[0], g_uri);
964 for (i = 0; i < g_handle_num; i++) {
965 player_set_buffering_cb(g_player[i], buffering_cb, (void *)g_player[i]);
966 player_set_completed_cb(g_player[i], completed_cb, (void *)g_player[i]);
967 player_set_interrupted_cb(g_player[i], interrupted_cb, (void *)g_player[i]);
968 player_set_error_cb(g_player[i], error_cb, (void *)g_player[i]);
969 player_set_video_stream_changed_cb(g_player[0], video_changed_cb, (void *)g_player[0]);
970 if (g_memory_playback)
971 player_set_memory_buffer_test();
973 player_set_uri(g_player[i], g_uri);
977 if (strstr(g_uri, "es_buff://")) {
978 is_es_push_mode = FALSE;
979 video_packet_count = 0;
980 audio_packet_count = 0;
982 if (strstr(g_uri, "es_buff://push_mode")) {
983 set_content_info(TRUE);
985 is_es_push_mode = TRUE;
988 set_content_info(FALSE);
993 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
995 ret = player_prepare_async(g_player[0], prepared_cb, (void *)g_player[0]);
997 ret = player_prepare(g_player[0]);
1000 for (i = 0; i < g_handle_num; i++) {
1002 ret = player_prepare_async(g_player[i], prepared_cb, (void *)g_player[i]);
1004 ret = player_prepare(g_player[i]);
1008 if (ret != PLAYER_ERROR_NONE)
1009 g_print("prepare is failed (errno = %d) \n", ret);
1011 player_state_e state;
1012 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1013 ret = player_get_state(g_player[0], &state);
1014 g_print("After player_prepare() - Current State : %d \n", state);
1017 for (i = 0; i < g_handle_num; i++) {
1018 ret = player_get_state(g_player[i], &state);
1019 g_print("After player_prepare() - Current State : %d \n", state);
1023 if (is_es_push_mode)
1024 pthread_create(&g_feed_video_thread_id, NULL, (void *)feed_video_data_thread_func, NULL);
1028 static void _player_unprepare()
1032 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1033 ret = player_unprepare(g_player[0]);
1034 if (ret != PLAYER_ERROR_NONE)
1035 g_print("unprepare is failed (errno = %d) \n", ret);
1037 ret = player_unset_subtitle_updated_cb(g_player[0]);
1038 g_print("player_unset_subtitle_updated_cb ret %d\n", ret);
1040 ret = player_unset_buffering_cb(g_player[0]);
1041 g_print("player_unset_buffering_cb ret %d\n", ret);
1043 ret = player_unset_completed_cb(g_player[0]);
1044 g_print("player_unset_completed_cb ret %d\n", ret);
1046 ret = player_unset_interrupted_cb(g_player[0]);
1047 g_print("player_unset_interrupted_cb ret %d\n", ret);
1049 ret = player_unset_error_cb(g_player[0]);
1050 g_print("player_unset_error_cb ret %d\n", ret);
1052 for (i = 0; i < g_handle_num; i++) {
1053 if (g_player[i] != NULL) {
1054 ret = player_unprepare(g_player[i]);
1055 if (ret != PLAYER_ERROR_NONE)
1056 g_print("unprepare is failed (errno = %d) \n", ret);
1058 ret = player_unset_subtitle_updated_cb(g_player[i]);
1059 g_print("player_unset_subtitle_updated_cb [%d] ret %d\n", i, ret);
1061 ret = player_unset_buffering_cb(g_player[i]);
1062 g_print("player_unset_buffering_cb [%d] ret %d\n", i, ret);
1064 ret = player_unset_completed_cb(g_player[i]);
1065 g_print("player_unset_completed_cb [%d] ret %d\n", i, ret);
1067 ret = player_unset_interrupted_cb(g_player[i]);
1068 g_print("player_unset_interrupted_cb [%d] ret %d\n", i, ret);
1070 ret = player_unset_error_cb(g_player[i]);
1071 g_print("player_unset_error_cb [%d] ret %d\n", i, ret);
1076 memset(g_subtitle_uri, 0, sizeof(g_subtitle_uri));
1077 player_state_e state;
1078 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1079 ret = player_get_state(g_player[0], &state);
1080 g_print(" After player_unprepare() - Current State : %d \n", state);
1082 for (i = 0; i < g_handle_num; i++) {
1083 ret = player_get_state(g_player[i], &state);
1084 g_print(" After player_unprepare() - Current State : %d \n", state);
1089 static void _player_destroy()
1093 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1094 player_destroy(g_player[0]);
1097 for (i = 0; i < g_handle_num; i++) {
1098 if (g_player[i] != NULL) {
1099 player_unprepare(g_player[i]);
1100 player_destroy(g_player[i]);
1106 if (g_stream_info_h) {
1107 sound_manager_destroy_stream_information(g_stream_info_h);
1108 g_stream_info_h = NULL;
1112 media_packet_destroy(g_video_pkt);
1115 media_packet_destroy(g_audio_pkt);
1126 static void _player_play()
1130 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1131 #ifdef _ACTIVATE_EOM_
1132 /* for checking external display.... */
1133 player_set_display(g_player[0], g_current_surface_type, GET_DISPLAY(selected_win_id));
1135 bRet = player_start(g_player[0]);
1136 g_print("player_start returned [%d]", bRet);
1138 for (i = 0; i < g_handle_num; i++) {
1139 bRet = player_start(g_player[i]);
1140 g_print("player_start returned [%d]", bRet);
1145 static void _player_stop()
1149 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1150 bRet = player_stop(g_player[0]);
1151 g_print("player_stop returned [%d]", bRet);
1153 for (i = 0; i < g_handle_num; i++) {
1154 bRet = player_stop(g_player[i]);
1155 g_print("player_stop returned [%d]", bRet);
1159 g_thread_end = TRUE;
1160 if (g_feed_video_thread_id) {
1161 pthread_join(g_feed_video_thread_id, NULL);
1162 g_feed_video_thread_id = 0;
1167 static void _player_resume()
1171 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1172 #ifdef _ACTIVATE_EOM_
1173 /* for checking external display.... */
1174 player_set_display(g_player[0], PLAYER_DISPLAY_TYPE_OVERLAY, GET_DISPLAY(selected_win_id));
1176 bRet = player_start(g_player[0]);
1177 g_print("player_start returned [%d]", bRet);
1179 for (i = 0; i < g_handle_num; i++) {
1180 bRet = player_start(g_player[i]);
1181 g_print("player_start returned [%d]", bRet);
1186 static void _player_pause()
1190 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1191 bRet = player_pause(g_player[0]);
1192 g_print("player_pause returned [%d]", bRet);
1194 for (i = 0; i < g_handle_num; i++) {
1195 bRet = player_pause(g_player[i]);
1196 g_print("player_pause returned [%d]", bRet);
1201 static void _player_state()
1203 player_state_e state;
1204 player_get_state(g_player[0], &state);
1205 g_print(" ==> [Player_Test] Current Player State : %d\n", state);
1208 static void _player_set_progressive_download()
1210 player_set_progressive_download_path(g_player[0], "/home/owner/test.pd");
1211 player_set_progressive_download_message_cb(g_player[0], progress_down_cb, (void *)g_player[0]);
1214 static void _player_get_progressive_download_status()
1217 unsigned long curr = 0, total = 0;
1218 bRet = player_get_progressive_download_status(g_player[0], &curr, &total);
1219 g_print("player_get_progressive_download_status return[%d] ==> [Player_Test] progressive download status : %lu/%lu\n", bRet, curr, total);
1222 static void _player_enable_tsurf_pool(void)
1224 bool enabled = FALSE;
1227 g_print("not support at TV profile");
1231 player_is_enabled_tsurf_pool(g_player[0], &enabled);
1233 g_print("tbm surface pool will be %s", (enabled) ? "disabled" : "enabled");
1234 player_enable_tsurf_pool(g_player[0], !enabled);
1237 static void set_next_uri(char * uri)
1240 g_print("not support at TV profile");
1244 if (player_set_next_uri(g_player[0], uri) != PLAYER_ERROR_NONE)
1245 g_print("fail to set next uri");
1248 static void get_next_uri()
1253 g_print("not support at TV profile");
1257 if (player_get_next_uri(g_player[0], &uri) != PLAYER_ERROR_NONE) {
1258 g_print("fail to get next uri");
1263 g_print("next_uri = %s", uri);
1268 static void set_volume(float volume)
1270 if (player_set_volume(g_player[0], volume, volume) != PLAYER_ERROR_NONE)
1271 g_print("failed to set volume\n");
1274 static void get_volume(float *left, float *right)
1276 player_get_volume(g_player[0], left, right);
1277 g_print(" ==> [Player_Test] volume - left : %f, right : %f\n", *left, *right);
1280 static void set_mute(bool mute)
1282 if (player_set_mute(g_player[0], mute) != PLAYER_ERROR_NONE)
1283 g_print("failed to set_mute\n");
1286 static void get_mute(bool * mute)
1288 player_is_muted(g_player[0], mute);
1289 g_print(" ==> [Player_Test] mute = %d\n", *mute);
1292 static void set_sound_type(sound_type_e type)
1294 if (player_set_sound_type(g_player[0], type) != PLAYER_ERROR_NONE)
1295 g_print("failed to set sound type(%d)\n", type);
1297 g_print("set sound type(%d) success", type);
1300 void focus_callback(sound_stream_info_h stream_info,
1301 sound_stream_focus_mask_e focus_mask,
1302 sound_stream_focus_state_e focus_state,
1303 sound_stream_focus_change_reason_e reason,
1305 const char *extra_info,
1308 g_print("FOCUS callback is called, reason(%d), extra_info(%s), userdata(%p)", reason, extra_info, user_data);
1312 static void set_sound_stream_info(int type)
1314 sound_device_list_h device_list = NULL;
1315 int ret = SOUND_MANAGER_ERROR_NONE;
1317 if (g_stream_info_h) {
1318 g_print("stream information is already set, please destory handle and try again\n");
1321 if (sound_manager_create_stream_information(type, focus_callback, g_player[0], &g_stream_info_h)) {
1322 g_print("failed to create stream_information()\n");
1325 /* In case of MEDIA_EXTERNAL_ONLY, we need to set external device manually */
1326 if (type == (int)SOUND_STREAM_TYPE_MEDIA_EXTERNAL_ONLY) {
1327 sound_device_h device = NULL;
1328 sound_device_type_e device_type;
1330 if ((ret = sound_manager_get_device_list(SOUND_DEVICE_ALL_MASK, &device_list))) {
1331 g_print("failed to sound_manager_get_device_list(), ret(0x%x)\n", ret);
1334 while (!(ret = sound_manager_get_next_device(device_list, &device))) {
1335 if ((ret = sound_manager_get_device_type(device, &device_type))) {
1336 g_print("failed to sound_manager_get_device_type(), ret(0x%x)\n", ret);
1339 if (device_type == SOUND_DEVICE_BLUETOOTH || device_type == SOUND_DEVICE_USB_AUDIO) {
1340 if ((ret = sound_manager_add_device_for_stream_routing(g_stream_info_h, device))) {
1341 g_print("failed to sound_manager_add_device_for_stream_routing(), ret(0x%x)\n", ret);
1344 if ((ret = sound_manager_apply_stream_routing(g_stream_info_h))) {
1345 g_print("failed to sound_manager_apply_stream_routing(), ret(0x%x)\n", ret);
1351 if (ret != SOUND_MANAGER_ERROR_NONE) {
1352 g_print("failed to sound_manager_get_next_device(), ret(0x%x)\n", ret);
1357 if (player_set_sound_stream_info(g_player[0], g_stream_info_h) != PLAYER_ERROR_NONE)
1358 g_print("failed to set sound stream information(%p)\n", g_stream_info_h);
1360 g_print("set stream information(%p) success", g_stream_info_h);
1364 sound_manager_free_device_list(device_list);
1368 static void get_position()
1372 ret = player_get_play_position(g_player[0], &position);
1373 g_print(" ==> [Player_Test] player_get_play_position()%d return : %d\n", ret, position);
1376 static void set_position(int position)
1378 if (player_set_play_position(g_player[0], position, TRUE, seek_completed_cb, g_player[0]) != PLAYER_ERROR_NONE)
1379 g_print("failed to set position\n");
1382 static void set_playback_rate(float rate, bool streaming)
1385 if (player_set_streaming_playback_rate(g_player[0], rate) != PLAYER_ERROR_NONE)
1386 g_print("failed to set streaming playback rate\n");
1388 if (player_set_playback_rate(g_player[0], rate) != PLAYER_ERROR_NONE)
1389 g_print("failed to set playback rate\n");
1393 static void get_duration()
1397 ret = player_get_duration(g_player[0], &duration);
1398 g_print(" ==> [Player_Test] player_get_duration() return : %d\n", ret);
1399 g_print(" ==> [Player_Test] Duration: [%d ] msec\n", duration);
1402 static void audio_frame_decoded_cb_ex(bool sync)
1406 fp_out1 = fopen("/tmp/out1.pcm", "wb");
1407 fp_out2 = fopen("/tmp/out2.pcm", "wb");
1408 if (!fp_out1 || !fp_out2) {
1409 g_print("File open error\n");
1414 ret = player_set_pcm_extraction_mode(g_player[0], sync, _audio_frame_decoded_cb_ex, &ret);
1415 g_print(" ==> [Player_Test] player_set_audio_frame_decoded_cb_ex(sync:%d) ret:%d\n", sync, ret);
1417 ret = player_set_pcm_spec(g_player[0], "F32LE", 44100, 2);
1418 g_print("[Player_Test] set_pcm_spec return: %d\n", ret);
1421 static void get_stream_info()
1427 player_get_content_info(g_player[0], PLAYER_CONTENT_INFO_ALBUM, &value);
1428 g_print(" ==> [Player_Test] PLAYER_CONTENT_INFO_ALBUM: [%s ] \n", value);
1429 player_get_content_info(g_player[0], PLAYER_CONTENT_INFO_ARTIST, &value);
1430 g_print(" ==> [Player_Test] PLAYER_CONTENT_INFO_ARTIST: [%s ] \n", value);
1431 player_get_content_info(g_player[0], PLAYER_CONTENT_INFO_AUTHOR, &value);
1432 g_print(" ==> [Player_Test] PLAYER_CONTENT_INFO_AUTHOR: [%s ] \n", value);
1433 player_get_content_info(g_player[0], PLAYER_CONTENT_INFO_GENRE, &value);
1434 g_print(" ==> [Player_Test] PLAYER_CONTENT_INFO_GENRE: [%s ] \n", value);
1435 player_get_content_info(g_player[0], PLAYER_CONTENT_INFO_TITLE, &value);
1436 g_print(" ==> [Player_Test] PLAYER_CONTENT_INFO_TITLE: [%s ] \n", value);
1439 player_get_album_art(g_player[0], &album, &size);
1440 g_print(" ==> [Player_Test] Album art : [ data : %p, size : %d ]\n", (unsigned int *)album, size);
1442 if (value != NULL) {
1450 int fps, v_bit_rate;
1451 player_get_audio_stream_info(g_player[0], &sample_rate, &channel, &bit_rate);
1452 g_print(" ==> [Player_Test] Sample Rate: [%d ] , Channel: [%d ] , Bit Rate: [%d ] \n", sample_rate, channel, bit_rate);
1454 player_get_video_stream_info(g_player[0], &fps, &v_bit_rate);
1455 g_print(" ==> [Player_Test] fps: [%d ] , Bit Rate: [%d ] \n", fps, v_bit_rate);
1457 char *audio_codec = NULL;
1458 char *video_codec = NULL;
1459 player_get_codec_info(g_player[0], &audio_codec, &video_codec);
1460 if (audio_codec != NULL) {
1461 g_print(" ==> [Player_Test] Audio Codec: [%s ] \n", audio_codec);
1465 if (video_codec != NULL) {
1466 g_print(" ==> [Player_Test] Video Codec: [%s ] \n", video_codec);
1470 player_get_video_size(g_player[0], &w, &h);
1471 g_print(" ==> [Player_Test] Width: [%d ] , Height: [%d ] \n", w, h);
1474 static void set_gapless(bool gapless)
1477 g_print("not support at TV profile");
1481 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1482 if (player_set_gapless(g_player[0], gapless) != PLAYER_ERROR_NONE)
1483 g_print("failed set_gapless\n");
1486 for (i = 0; i < g_handle_num; i++) {
1487 if (player_set_gapless(g_player[i], gapless) != PLAYER_ERROR_NONE)
1488 g_print("failed to set_gapless\n");
1493 static void set_looping(bool looping)
1495 if (g_current_surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1496 if (player_set_looping(g_player[0], looping) != PLAYER_ERROR_NONE)
1497 g_print("failed to set_looping\n");
1500 for (i = 0; i < g_handle_num; i++) {
1501 if (player_set_looping(g_player[i], looping) != PLAYER_ERROR_NONE)
1502 g_print("failed to set_looping\n");
1507 static void get_looping(bool * looping)
1509 player_is_looping(g_player[0], looping);
1510 g_print(" ==> [Player_Test] looping = %d\n", *looping);
1513 static void change_surface(int option)
1515 player_display_type_e surface_type = 0;
1516 int ret = PLAYER_ERROR_NONE;
1517 #ifdef _ACTIVATE_EOM_
1519 eom_output_mode_e output_mode;
1524 surface_type = PLAYER_DISPLAY_TYPE_OVERLAY;
1525 g_print("change surface type to X\n");
1527 #ifdef TIZEN_FEATURE_EVAS_RENDERER
1530 surface_type = PLAYER_DISPLAY_TYPE_EVAS;
1531 g_print("change surface type to EVAS\n");
1535 g_print("change surface type to NONE\n");
1536 surface_type = g_current_surface_type = PLAYER_DISPLAY_TYPE_NONE;
1537 player_set_display(g_player[0], PLAYER_DISPLAY_TYPE_NONE, NULL);
1540 g_print("invalid surface type\n");
1544 if (surface_type == g_current_surface_type) {
1545 g_print("same with the previous surface type(%d)\n", g_current_surface_type);
1548 player_state_e player_state = PLAYER_STATE_NONE;
1549 ret = player_get_state(g_player[0], &player_state);
1551 g_print("failed to player_get_state(), ret(0x%x)\n", ret);
1555 if (surface_type == PLAYER_DISPLAY_TYPE_OVERLAY) {
1556 #ifdef _ACTIVATE_EOM_
1557 hdmi_output_id = eom_get_output_id("HDMI");
1558 if (hdmi_output_id == 0)
1559 g_print("[eom] error : HDMI output id is NULL.\n");
1561 eom_get_output_mode(hdmi_output_id, &output_mode);
1562 if (output_mode == EOM_OUTPUT_MODE_NONE) {
1565 g_win_id = create_win(PACKAGE);
1566 if (g_win_id == NULL)
1568 g_print("create win_id %p\n", g_win_id);
1569 create_render_rect_and_bg(g_win_id);
1570 elm_win_activate(g_win_id);
1571 evas_object_show(g_win_id);
1572 g_win_id = selected_win_id;
1574 #ifdef _ACTIVATE_EOM_
1579 ret = player_set_display(g_player[0], surface_type, GET_DISPLAY(selected_win_id));
1582 g_win_id = create_win(PACKAGE);
1583 if (g_win_id == NULL)
1585 g_print("create win_id %p\n", g_win_id);
1586 create_render_rect_and_bg(g_win_id);
1587 elm_win_activate(g_win_id);
1588 evas_object_show(g_win_id);
1591 for (i = 0; i < g_handle_num; i++) {
1592 /* Create evas image object for EVAS surface */
1594 g_eo[i] = create_image_object(g_win_id);
1595 g_print("create eo[%d] %p\n", i, g_eo[i]);
1596 evas_object_image_size_set(g_eo[i], 500, 500);
1597 evas_object_image_fill_set(g_eo[i], 0, 0, 500, 500);
1598 evas_object_resize(g_eo[i], 500, 500);
1599 evas_object_move(g_eo[i], i * 20, i * 20);
1601 ret = player_set_display(g_player[i], surface_type, g_eo[i]);
1606 g_print("failed to set display, surface_type(%d)\n", surface_type);
1609 g_current_surface_type = surface_type;
1614 static void set_display_mode(int mode)
1616 if (player_set_display_mode(g_player[0], mode) != PLAYER_ERROR_NONE)
1617 g_print("failed to player_set_display_mode\n");
1620 static void get_display_mode()
1622 player_display_mode_e mode;
1623 player_get_display_mode(g_player[0], &mode);
1624 g_print(" ==> [Player_Test] Display mode: [%d ] \n", mode);
1627 static void set_display_roi_area(int x, int y, int width, int height)
1629 player_set_display_roi_area(g_player[0], x, y, width, height);
1630 g_print(" ==> [Player_Test] Display roi area: [x(%d) y(%d) width(%d) height(%d)] \n", x, y, width, height);
1633 static void set_display_rotation(int rotation)
1635 if (player_set_display_rotation(g_player[0], rotation) != PLAYER_ERROR_NONE)
1636 g_print("failed to set_display_rotation\n");
1639 static void get_display_rotation()
1641 player_display_rotation_e rotation = 0;
1642 player_get_display_rotation(g_player[0], &rotation);
1643 g_print(" ==> [Player_Test] Video Overlay Display rotation: [%d ] \n", rotation);
1646 static void set_display_visible(bool visible)
1648 if (player_set_display_visible(g_player[0], visible) != PLAYER_ERROR_NONE)
1649 g_print("failed to player_set_x11_display_visible\n");
1652 static void get_display_visible(bool * visible)
1654 player_is_display_visible(g_player[0], visible);
1655 g_print(" ==> [Player_Test] Video Overlay Display Visible = %d\n", *visible);
1658 static void input_subtitle_filename(char *subtitle_filename)
1660 int len = strlen(subtitle_filename);
1662 if (len < 1 || len > MAX_STRING_LEN)
1665 strncpy(g_subtitle_uri, subtitle_filename, len);
1666 g_print("subtitle uri is set to %s\n", g_subtitle_uri);
1667 player_set_subtitle_path(g_player[0], g_subtitle_uri);
1670 static void switch_subtitle(int index)
1672 char *lang_code = NULL;
1673 if (player_select_track(g_player[0], PLAYER_STREAM_TYPE_TEXT, index) != PLAYER_ERROR_NONE)
1674 g_print("player_select_track failed\n");
1676 if (player_get_track_language_code(g_player[0], PLAYER_STREAM_TYPE_TEXT, index, &lang_code) == PLAYER_ERROR_NONE) {
1677 g_print("selected track code %s\n", lang_code);
1682 static void get_track_info(int index)
1684 int count = 0, cur_index = 0;
1686 char *lang_code = NULL;
1688 if (index != PLAYER_STREAM_TYPE_AUDIO &&
1689 index != PLAYER_STREAM_TYPE_TEXT) {
1690 g_print("invalid stream type %d", index);
1694 ret = player_get_track_count(g_player[0], index, &count);
1695 if (ret != PLAYER_ERROR_NONE)
1696 g_print("player_get_track_count fail!!!!\n");
1699 player_get_current_track(g_player[0], index, &cur_index);
1700 g_print("total track: %d, curr track: %d\n", count, cur_index);
1702 for (idx = 0; idx < count; idx++) {
1703 player_get_track_language_code(g_player[0], index, idx, &lang_code);
1704 g_print("track info = [%d] %s\n", idx, lang_code);
1707 g_print("no track\n");
1711 static void capture_video()
1713 if (player_capture_video(g_player[0], video_captured_cb, NULL) != PLAYER_ERROR_NONE)
1714 g_print("failed to player_capture_video\n");
1717 static void decoding_audio()
1721 char *suffix, *dump_path;
1722 GDateTime *time = g_date_time_new_now_local();
1724 suffix = g_date_time_format(time, "%Y%m%d_%H%M%S.pcm");
1725 dump_path = g_strjoin(NULL, PLAYER_TEST_DUMP_PATH_PREFIX, suffix, NULL);
1726 g_pcm_fd = fopen(dump_path, "w+");
1729 g_date_time_unref(time);
1731 g_print("Can not create debug dump file");
1733 ret = player_set_audio_frame_decoded_cb(g_player[0], 0, 0, audio_frame_decoded_cb, (void *)g_player[0]);
1734 if (ret != PLAYER_ERROR_NONE)
1735 g_print("player_set_audio_frame_decoded_cb is failed (errno = %d) \n", ret);
1739 static void set_audio_eq(int value)
1741 bool available = FALSE;
1742 int index, min = 0, max = 0;
1745 if (player_audio_effect_equalizer_is_available(g_player[0], &available) != PLAYER_ERROR_NONE)
1746 g_print("failed to player_audio_effect_equalizer_is_available\n");
1749 if ((player_audio_effect_get_equalizer_bands_count(g_player[0], &index) != PLAYER_ERROR_NONE) ||
1750 (player_audio_effect_get_equalizer_level_range(g_player[0], &min, &max) != PLAYER_ERROR_NONE) ||
1751 (player_audio_effect_set_equalizer_band_level(g_player[0], index / 2, max) != PLAYER_ERROR_NONE))
1752 g_print("failed to player_audio_effect_set_equalizer_band_level index %d, level %d\n", index / 2, max);
1757 if (player_audio_effect_equalizer_clear(g_player[0]) != PLAYER_ERROR_NONE)
1758 g_print("failed to player_audio_effect_equalizer_clear\n");
1763 static void get_audio_eq()
1765 int index, min, max, value;
1766 player_audio_effect_get_equalizer_bands_count(g_player[0], &index);
1767 g_print(" ==> [Player_Test] eq bands count: [%d] \n", index);
1768 player_audio_effect_get_equalizer_level_range(g_player[0], &min, &max);
1769 g_print(" ==> [Player_Test] eq bands range: [%d~%d] \n", min, max);
1770 player_audio_effect_get_equalizer_band_level(g_player[0], index / 2, &value);
1771 g_print(" ==> [Player_Test] eq bands level: [%d] \n", value);
1772 player_audio_effect_get_equalizer_band_frequency(g_player[0], 0, &value);
1773 g_print(" ==> [Player_Test] eq bands frequency: [%d] \n", value);
1774 player_audio_effect_get_equalizer_band_frequency_range(g_player[0], 0, &value);
1775 g_print(" ==> [Player_Test] eq bands frequency range: [%d] \n", value);
1784 if (g_player[0] != NULL || g_player[1] != NULL) {
1785 _player_unprepare();
1792 media_format_unref(g_audio_fmt);
1795 media_format_unref(g_video_fmt);
1798 void play_with_ini(char *file_path)
1800 input_filename(file_path);
1804 void _interpret_main_menu(char *cmd)
1806 int len = strlen(cmd);
1808 if (strncmp(cmd, "a", 1) == 0) {
1809 g_menu_state = CURRENT_STATUS_FILENAME;
1810 } else if (strncmp(cmd, "b", 1) == 0) {
1812 } else if (strncmp(cmd, "c", 1) == 0) {
1814 } else if (strncmp(cmd, "d", 1) == 0) {
1816 } else if (strncmp(cmd, "e", 1) == 0) {
1818 } else if (strncmp(cmd, "S", 1) == 0) {
1820 } else if (strncmp(cmd, "f", 1) == 0) {
1821 g_menu_state = CURRENT_STATUS_VOLUME;
1822 } else if (strncmp(cmd, "g", 1) == 0) {
1825 get_volume(&left, &right);
1826 } else if (strncmp(cmd, "z", 1) == 0) {
1827 g_menu_state = CURRENT_STATUS_SOUND_TYPE;
1828 } else if (strncmp(cmd, "k", 1) == 0) {
1829 g_menu_state = CURRENT_STATUS_SOUND_STREAM_INFO;
1830 } else if (strncmp(cmd, "h", 1) == 0) {
1831 g_menu_state = CURRENT_STATUS_MUTE;
1832 } else if (strncmp(cmd, "i", 1) == 0) {
1835 } else if (strncmp(cmd, "j", 1) == 0) {
1836 g_menu_state = CURRENT_STATUS_POSITION_TIME;
1837 } else if (strncmp(cmd, "l", 1) == 0) {
1839 } else if (strncmp(cmd, "m", 1) == 0) {
1841 } else if (strncmp(cmd, "n", 1) == 0) {
1843 } else if (strncmp(cmd, "o", 1) == 0) {
1844 g_menu_state = CURRENT_STATUS_LOOPING;
1845 } else if (strncmp(cmd, "p", 1) == 0) {
1847 get_looping(&looping);
1848 } else if (strncmp(cmd, "r", 1) == 0) {
1849 g_menu_state = CURRENT_STATUS_DISPLAY_MODE;
1850 } else if (strncmp(cmd, "s", 1) == 0) {
1852 } else if (strncmp(cmd, "t", 1) == 0) {
1853 g_menu_state = CURRENT_STATUS_DISPLAY_ROTATION;
1854 } else if (strncmp(cmd, "u", 1) == 0) {
1855 get_display_rotation();
1856 } else if (strncmp(cmd, "v", 1) == 0) {
1857 g_menu_state = CURRENT_STATUS_DISPLAY_VISIBLE;
1858 } else if (strncmp(cmd, "w", 1) == 0) {
1860 get_display_visible(&visible);
1861 } else if (strncmp(cmd, "A", 1) == 0) {
1862 g_menu_state = CURRENT_STATUS_SUBTITLE_FILENAME;
1863 } else if (strncmp(cmd, "C", 1) == 0) {
1865 } else if (strncmp(cmd, "D", 1) == 0) {
1867 } else if (strncmp(cmd, "q", 1) == 0) {
1868 quit_pushing = TRUE;
1870 } else if (strncmp(cmd, "E", 1) == 0) {
1871 g_menu_state = CURRENT_STATUS_AUDIO_EQUALIZER;
1872 } else if (strncmp(cmd, "H", 1) == 0) {
1875 g_print("unknown menu \n");
1877 } else if (len == 2) {
1878 if (strncmp(cmd, "pr", 2) == 0) {
1880 if (g_current_surface_type == -1) {
1881 g_print("You must set display surface type before setting prepare. please 'pr' after setting display surface type.\n");
1882 g_menu_state = CURRENT_STATUS_DISPLAY_SURFACE_CHANGE;
1884 _player_prepare(FALSE);
1885 } else if (strncmp(cmd, "pa", 2) == 0) {
1887 if (g_current_surface_type == -1) {
1888 g_print("You must set display surface type before setting prepare. please 'pr' after setting display surface type.\n");
1889 g_menu_state = CURRENT_STATUS_DISPLAY_SURFACE_CHANGE;
1891 _player_prepare(TRUE);
1892 } else if (strncmp(cmd, "un", 2) == 0) {
1893 _player_unprepare();
1894 } else if (strncmp(cmd, "dt", 2) == 0) {
1896 } else if (strncmp(cmd, "sp", 2) == 0) {
1897 _player_set_progressive_download();
1898 } else if (strncmp(cmd, "gp", 2) == 0) {
1899 _player_get_progressive_download_status();
1900 } else if (strncmp(cmd, "mp", 2) == 0) {
1901 g_memory_playback = (g_memory_playback ? FALSE : TRUE);
1902 g_print("memory playback = %d\n", g_memory_playback);
1903 } else if (strncmp(cmd, "ds", 2) == 0) {
1904 g_menu_state = CURRENT_STATUS_DISPLAY_SURFACE_CHANGE;
1905 } else if (strncmp(cmd, "dr", 2) == 0) {
1906 g_print("now, PLAYER_DISPLAY_MODE_DST_ROI(display mode) is set\n");
1907 g_menu_state = CURRENT_STATUS_DISPLAY_DST_ROI;
1908 } else if (strncmp(cmd, "nb", 2) == 0) {
1909 g_menu_state = CURRENT_STATUS_HANDLE_NUM;
1910 } else if (strncmp(cmd, "tr", 2) == 0) {
1911 g_menu_state = CURRENT_STATUS_PLAYBACK_RATE;
1912 } else if (strncmp(cmd, "ss", 2) == 0) {
1913 g_menu_state = CURRENT_STATUS_SWITCH_SUBTITLE;
1914 } else if (strncmp(cmd, "X3", 2) == 0) {
1915 audio_frame_decoded_cb_ex(TRUE);
1916 } else if (strncmp(cmd, "X4", 2) == 0) {
1917 audio_frame_decoded_cb_ex(FALSE);
1918 } else if (strncmp(cmd, "ep", 2) == 0) {
1919 _player_enable_tsurf_pool();
1920 } else if (strncmp(cmd, "su", 2) == 0) {
1921 g_menu_state = CURRENT_STATUS_NEXT_URI;
1922 } else if (strncmp(cmd, "gu", 2) == 0) {
1924 } else if (strncmp(cmd, "sg", 2) == 0) {
1925 g_menu_state = CURRENT_STATUS_GAPLESS;
1926 } else if (strncmp(cmd, "tl", 2) == 0) {
1927 g_menu_state = CURRENT_STATUS_GET_TRACK_INFO;
1929 g_print("unknown menu \n");
1932 if (strncmp(cmd, "trs", 3) == 0)
1933 g_menu_state = CURRENT_STATUS_STREAMING_PLAYBACK_RATE;
1935 g_print("unknown menu \n");
1939 void display_sub_basic()
1942 g_print("=========================================================================================\n");
1943 g_print(" Player Test (press q to quit) \n");
1944 g_print("-----------------------------------------------------------------------------------------\n");
1945 g_print("[playback] a. Create\t");
1946 g_print("pr. Prepare \t");
1947 g_print("pa. Prepare async \t");
1948 g_print("b. Play \t");
1949 g_print("c. Stop \t");
1950 g_print("d. Resume\t");
1951 g_print("e. Pause \t");
1952 g_print("un. Unprepare \t");
1953 g_print("dt. Destroy \n");
1954 g_print("[State] S. Player State \n");
1955 g_print("[ volume ] f. Set Volume\t");
1956 g_print("g. Get Volume\t");
1957 g_print("z. Set Sound type\t");
1958 g_print("k. Set Sound Stream Info.\n");
1959 g_print("[ mute ] h. Set Mute\t");
1960 g_print("i. Get Mute\n");
1961 g_print("[audio eq] E. Set Audio EQ\t");
1962 g_print("H. Get Audio EQ\n");
1963 g_print("[position] j. Set Position \t");
1964 g_print("l. Get Position\n");
1965 g_print("[trick] tr. set playback rate\n");
1966 g_print("[duration] m. Get Duration\n");
1967 g_print("[Stream Info] n. Get stream info (Video Size, codec, audio stream info, and tag info)\n");
1968 g_print("[Looping] o. Set Looping\t");
1969 g_print("p. Get Looping\n");
1970 g_print("[display] v. Set display visible\t");
1971 g_print("w. Get display visible\n");
1972 g_print("[display] ds. Change display surface type\n");
1973 g_print("[display] dr. set display roi area\n");
1974 g_print("[overlay display] r. Set display mode\t");
1975 g_print("s. Get display mode\n");
1976 g_print("[overlay display] t. Set display Rotation\n");
1977 g_print("[Track] tl. Get Track language info(single only)\n");
1978 g_print("[subtitle] A. Set(or change) subtitle path\n");
1979 g_print("[subtitle] ss. Select(or change) subtitle track\n");
1980 g_print("[Video Capture] C. Capture \n");
1981 g_print("[next uri] su. set next uri. \t");
1982 g_print("gu. get next uri. \t");
1983 g_print("sg. set gapless. \n");
1984 g_print("[audio_frame_decoded_cb_ex] X3. set audio_cb with sync\t");
1985 g_print("X4. set audio_cb with async \n");
1986 g_print("[video_frame_decoded_cb] ep. enable tbm surface pool\n");
1987 g_print("[etc] sp. Set Progressive Download\t");
1988 g_print("gp. Get Progressive Download status\t");
1989 g_print("mp. memory playback\n");
1991 g_print("=========================================================================================\n");
1994 static void displaymenu()
1996 if (g_menu_state == CURRENT_STATUS_MAINMENU) {
1997 display_sub_basic();
1998 } else if (g_menu_state == CURRENT_STATUS_HANDLE_NUM) {
1999 g_print("*** input number of handles.(recommended only for EVAS surface)\n");
2000 } else if (g_menu_state == CURRENT_STATUS_FILENAME) {
2001 g_print("*** input mediapath.\n");
2002 } else if (g_menu_state == CURRENT_STATUS_VOLUME) {
2003 g_print("*** input volume value.(0~1.0)\n");
2004 } else if (g_menu_state == CURRENT_STATUS_SOUND_TYPE) {
2005 g_print("*** input sound type.(0:SYSTEM 1:NOTIFICATION 2:ALARM 3:RINGTONE 4:MEDIA 5:CALL 6:VOIP 7:FIXED)\n");
2006 } else if (g_menu_state == CURRENT_STATUS_SOUND_STREAM_INFO) {
2007 g_print("*** input sound stream type.(0:MEDIA 1:SYSTEM 2:ALARM 3:NOTIFICATION 4:EMERGENCY 5:VOICE_INFORMATION 9:MEDIA_EXT_ONLY)\n");
2008 } else if (g_menu_state == CURRENT_STATUS_MUTE) {
2009 g_print("*** input mute value.(0: Not Mute, 1: Mute) \n");
2010 } else if (g_menu_state == CURRENT_STATUS_POSITION_TIME) {
2011 g_print("*** input position value(msec)\n");
2012 } else if (g_menu_state == CURRENT_STATUS_LOOPING) {
2013 g_print("*** input looping value.(0: Not Looping, 1: Looping) \n");
2014 } else if (g_menu_state == CURRENT_STATUS_DISPLAY_SURFACE_CHANGE) {
2015 g_print("*** input display surface type.(0: X surface, 1: EVAS surface) \n");
2016 } else if (g_menu_state == CURRENT_STATUS_DISPLAY_MODE) {
2017 g_print("*** input display mode value.(0: LETTER BOX, 1: ORIGIN SIZE, 2: FULL_SCREEN, 3: CROPPED_FULL, 4: ORIGIN_OR_LETTER) \n");
2018 } else if (g_menu_state == CURRENT_STATUS_DISPLAY_DST_ROI) {
2019 g_print("*** input display roi value sequentially.(x, y, w, h)\n");
2020 } else if (g_menu_state == CURRENT_STATUS_DISPLAY_ROTATION) {
2021 g_print("*** input display rotation value.(0: NONE, 1: 90, 2: 180, 3: 270, 4:F LIP_HORZ, 5: FLIP_VERT ) \n");
2022 } else if (g_menu_state == CURRENT_STATUS_DISPLAY_VISIBLE) {
2023 g_print("*** input display visible value.(0: HIDE, 1: SHOW) \n");
2024 } else if (g_menu_state == CURRENT_STATUS_SUBTITLE_FILENAME) {
2025 g_print(" *** input subtitle file path.\n");
2026 } else if (g_menu_state == CURRENT_STATUS_AUDIO_EQUALIZER) {
2027 g_print(" *** input audio eq value.(0: UNSET, 1: SET) \n");
2028 } else if (g_menu_state == CURRENT_STATUS_PLAYBACK_RATE || g_menu_state == CURRENT_STATUS_STREAMING_PLAYBACK_RATE) {
2029 g_print(" *** input playback rate.(-5.0 ~ 5.0)\n");
2030 } else if (g_menu_state == CURRENT_STATUS_SWITCH_SUBTITLE) {
2031 int count = 0, cur_index = 0;
2034 ret = player_get_track_count(g_player[0], PLAYER_STREAM_TYPE_TEXT, &count);
2035 if (ret != PLAYER_ERROR_NONE)
2036 g_print("player_get_track_count fail!!!!\n");
2038 g_print("Total subtitle tracks = %d \n", count);
2039 player_get_current_track(g_player[0], PLAYER_STREAM_TYPE_TEXT, &cur_index);
2040 g_print("Current index = %d \n", cur_index);
2041 g_print(" *** input correct index 0 to %d\n:", (count - 1));
2043 g_print("no track\n");
2044 } else if (g_menu_state == CURRENT_STATUS_NEXT_URI) {
2045 g_print("*** input next uri.\n");
2046 } else if (g_menu_state == CURRENT_STATUS_GAPLESS) {
2047 g_print("*** input gapless value.(0:disable, 1: enable) \n");
2048 } else if (g_menu_state == CURRENT_STATUS_GET_TRACK_INFO) {
2049 g_print("*** input stream type.(1:audio, 3:text) \n");
2051 g_print("*** unknown status.\n");
2057 gboolean timeout_menu_display(void *data)
2063 gboolean timeout_quit_program(void *data)
2069 void reset_menu_state(void)
2071 g_menu_state = CURRENT_STATUS_MAINMENU;
2074 static void interpret(char *cmd)
2076 switch (g_menu_state) {
2077 case CURRENT_STATUS_MAINMENU:
2079 _interpret_main_menu(cmd);
2082 case CURRENT_STATUS_HANDLE_NUM:
2084 int num_handle = atoi(cmd);
2085 if (0 >= num_handle || num_handle > MAX_HANDLE)
2086 g_print("not supported this number for handles(%d)\n", num_handle);
2088 g_handle_num = num_handle;
2093 case CURRENT_STATUS_FILENAME:
2095 input_filename(cmd);
2099 case CURRENT_STATUS_VOLUME:
2101 float level = atof(cmd);
2106 case CURRENT_STATUS_SOUND_TYPE:
2108 int type = atoi(cmd);
2109 set_sound_type(type);
2113 case CURRENT_STATUS_SOUND_STREAM_INFO:
2115 int type = atoi(cmd);
2116 set_sound_stream_info(type);
2120 case CURRENT_STATUS_MUTE:
2122 int mute = atoi(cmd);
2127 case CURRENT_STATUS_POSITION_TIME:
2129 long position = atol(cmd);
2130 set_position(position);
2134 case CURRENT_STATUS_LOOPING:
2136 int looping = atoi(cmd);
2137 set_looping(looping);
2141 case CURRENT_STATUS_GAPLESS:
2143 int gapless = atoi(cmd);
2144 set_gapless(gapless);
2148 case CURRENT_STATUS_DISPLAY_SURFACE_CHANGE:
2150 int type = atoi(cmd);
2151 change_surface(type);
2155 case CURRENT_STATUS_DISPLAY_MODE:
2157 int mode = atoi(cmd);
2158 set_display_mode(mode);
2162 case CURRENT_STATUS_DISPLAY_DST_ROI:
2164 int value = atoi(cmd);
2171 set_display_mode(PLAYER_DISPLAY_MODE_DST_ROI);
2188 set_display_roi_area(x, y, w, h);
2197 case CURRENT_STATUS_DISPLAY_ROTATION:
2199 int rotation = atoi(cmd);
2200 set_display_rotation(rotation);
2204 case CURRENT_STATUS_DISPLAY_VISIBLE:
2206 int visible = atoi(cmd);
2207 set_display_visible(visible);
2211 case CURRENT_STATUS_SUBTITLE_FILENAME:
2213 input_subtitle_filename(cmd);
2217 case CURRENT_STATUS_AUDIO_EQUALIZER:
2219 int value = atoi(cmd);
2220 set_audio_eq(value);
2224 case CURRENT_STATUS_PLAYBACK_RATE:
2226 float rate = atof(cmd);
2227 set_playback_rate(rate, FALSE);
2231 case CURRENT_STATUS_STREAMING_PLAYBACK_RATE:
2233 float rate = atof(cmd);
2234 set_playback_rate(rate, TRUE);
2238 case CURRENT_STATUS_SWITCH_SUBTITLE:
2240 int index = atoi(cmd);
2241 switch_subtitle(index);
2245 case CURRENT_STATUS_NEXT_URI:
2251 case CURRENT_STATUS_GET_TRACK_INFO:
2253 int index = atoi(cmd);
2254 get_track_info(index);
2260 g_timeout_add(100, timeout_menu_display, 0);
2263 gboolean input(GIOChannel * channel)
2265 gchar buf[MAX_STRING_LEN];
2267 GError *error = NULL;
2269 g_io_channel_read_chars(channel, buf, MAX_STRING_LEN, &read, &error);
2277 int main(int argc, char *argv[])
2279 GIOChannel *stdin_channel;
2280 stdin_channel = g_io_channel_unix_new(0);
2281 g_io_channel_set_flags(stdin_channel, G_IO_FLAG_NONBLOCK, NULL);
2282 g_io_add_watch(stdin_channel, G_IO_IN, (GIOFunc) input, NULL);
2285 memset(&ad, 0x0, sizeof(appdata));
2288 return appcore_efl_main(PACKAGE, &argc, &argv, &ops);