[0.6.143] resolve audio pipeline complexity issue
[platform/core/multimedia/libmm-player.git] / src / include / mm_player.h
1 /*
2  * libmm-player
3  *
4  * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
5  *
6  * Contact: JongHyuk Choi <jhchoi.choi@samsung.com>, YeJin Cho <cho.yejin@samsung.com>,
7  * Seungbae Shin <seungbae.shin@samsung.com>, YoungHwan An <younghwan_.an@samsung.com>
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  * http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  */
22
23 #ifndef __MM_PLAYER_H__
24 #define __MM_PLAYER_H__
25
26
27 /*===========================================================================================
28 |                                                                                           |
29 |  INCLUDE FILES                                        |
30 |                                                                                           |
31 ========================================================================================== */
32
33 #include <glib.h>
34
35 #include <mm_types.h>
36 #include <mm_message.h>
37 #include <media_packet.h>
38
39 #ifdef __cplusplus
40         extern "C" {
41 #endif
42
43 /*===========================================================================================
44 |                                                                                           |
45 |  GLOBAL DEFINITIONS AND DECLARATIONS                                        |
46 |                                                                                           |
47 ========================================================================================== */
48
49 /**
50  * MM_PLAYER_URI:
51  *
52  * uri to play (string)
53  *
54  */
55 #define MM_PLAYER_CONTENT_URI               "profile_uri"
56 /**
57  * MM_PLAYER_VIDEO_ROTATION
58  *
59  * can change video angle (int)
60  * @see MMDisplayRotationType
61  */
62 #define MM_PLAYER_VIDEO_ROTATION            "display_rotation"
63 /**
64  * MM_PLAYER_VIDEO_WIDTH:
65  *
66  * get the video width (int), It's guaranteed after calling mm_player_start() or
67  * receiving MM_MESSAGE_BEGIN_OF_STREAM.
68  *
69  */
70 #define MM_PLAYER_VIDEO_WIDTH               "content_video_width"
71 /**
72  * MM_PLAYER_VIDEO_HEIGHT:
73  *
74  * get the video height (int), It's guaranteed after calling mm_player_start() or
75  * receiving MM_MESSAGE_BEGIN_OF_STREAM.
76  *
77  */
78 #define MM_PLAYER_VIDEO_HEIGHT              "content_video_height"
79 /**
80  * MM_PLAYER_VIDEO_EVAS_SURFACE_SINK:
81  *
82  * get the video evas surface sink plugin name (string), It's guaranteed after calling mm_player_create()
83  *
84  */
85 #define MM_PLAYER_VIDEO_EVAS_SURFACE_SINK          "display_evas_surface_sink"
86 /**
87  * MM_PLAYER_MEM_SRC:
88  *
89  * set memory pointer to play (data)
90  *
91  */
92 #define MM_PLAYER_MEMORY_SRC                "profile_user_param"
93 /**
94  * MM_PLAYER_PLAYBACK_COUNT
95  *
96  * can set playback count (int), Default value is 1 and -1 is for infinity playing until releasing it.
97  *
98  */
99 #define MM_PLAYER_PLAYBACK_COUNT            "profile_play_count"
100 /**
101  * MM_PLAYER_SUBTITLE_URI
102  *
103  * set the subtitle path (string)
104  */
105 #define MM_PLAYER_SUBTITLE_URI              "subtitle_uri"
106 /**
107  * MM_PLAYER_STREAMING_USER_AGENT
108  *
109  * set the streaming user agent (string)
110  */
111 #define MM_PLAYER_STREAMING_USER_AGENT      "streaming_user_agent"
112 /**
113  * MM_PLAYER_STREAMING_COOKIE
114  *
115  * set the streaming cookie (int)
116  */
117 #define MM_PLAYER_STREAMING_COOKIE          "streaming_cookie"
118 /**
119  * MM_PLAYER_VIDEO_CODEC
120  *
121  * codec the video data is stored in (string)
122  */
123 #define MM_PLAYER_VIDEO_CODEC               "content_video_codec"
124 /**
125  * MM_PLAYER_AUDIO_CODEC
126  *
127  * codec the audio data is stored in (string)
128  */
129 #define MM_PLAYER_AUDIO_CODEC               "content_audio_codec"
130 /**
131  * MM_PLAYER_AUDIO_BITRATE
132  *
133  * set the streaming proxy port (int)
134  */
135 #define MM_PLAYER_AUDIO_BITRATE             "content_audio_bitrate"
136 /**
137  * MM_PLAYER_AUDIO_CHANNEL
138  *
139  * the number of audio channel (int)
140  */
141 #define MM_PLAYER_AUDIO_CHANNEL             "content_audio_channels"
142 /**
143  * MM_PLAYER_AUDIO_SAMPLERATE
144  *
145  * audio samplerate  (int)
146  */
147 #define MM_PLAYER_AUDIO_SAMPLERATE          "content_audio_samplerate"
148 /**
149  * MM_PLAYER_AUDIO_TRACK_NUM
150  *
151  * track number inside a collection (int)
152  */
153 #define MM_PLAYER_AUDIO_TRACK_NUM           "content_audio_track_num"
154 /**
155  * MM_PLAYER_TEXT_TRACK_NUM
156  *
157  * track number inside a collection (int)
158  */
159 #define MM_PLAYER_TEXT_TRACK_NUM            "content_text_track_num"
160 /**
161  * MM_PLAYER_TAG_ARTIST
162  *
163  * person(s) responsible for the recording (string)
164  */
165 #define MM_PLAYER_TAG_ARTIST                "tag_artist"
166 /**
167  * MM_PLAYER_TAG_TITLE
168  *
169  * title (string)
170  */
171 #define MM_PLAYER_TAG_TITLE                 "tag_title"
172 /**
173  * MM_PLAYER_TAG_ALBUM
174  *
175  * album containing this data (string)
176  */
177 #define MM_PLAYER_TAG_ALBUM                 "tag_album"
178 /**
179  * MM_PLAYER_TAG_GENRE
180  *
181  * genre this data belongs to (string)
182  */
183 #define MM_PLAYER_TAG_GENRE                 "tag_genre"
184 /**
185  * MM_PLAYER_TAG_AUTHOUR
186  *
187  * author (string)
188  */
189 #define MM_PLAYER_TAG_AUTHOUR               "tag_author"
190 /**
191  * MM_PLAYER_TAG_COPYRIGHT
192  *
193  * copyright notice of the data (string)
194  */
195 #define MM_PLAYER_TAG_COPYRIGHT             "tag_copyright"
196 /**
197  * MM_PLAYER_TAG_DATE
198  *
199  * date the data was created (string)
200  */
201 #define MM_PLAYER_TAG_DATE                  "tag_date"
202 /**
203  * MM_PLAYER_TAG_DESCRIPRION
204  *
205  * short text describing the content of the data (string)
206  */
207 #define MM_PLAYER_TAG_DESCRIPRION           "tag_description"
208 /**
209  * MM_PLAYER_TAG_TRACK_NUM
210  *
211  * track number inside a collection (int)
212  */
213 #define MM_PLAYER_TAG_TRACK_NUM             "tag_track_num"
214 /**
215  * MM_PLAYER_PD_MODE
216  *
217  * progressive download mode (int)
218  */
219 #define MM_PLAYER_PD_MODE                   "pd_mode"
220
221 /**
222  * MM_PLAYER_DRC_MODE
223  *
224  * dynamic resolution change mode (int)
225  */
226 #define MM_PLAYER_DRC_MODE                  "drc_mode"
227
228 /**
229  * MM_PLAYER_GAPLESS_MODE
230  *
231  * gapless playback mode (int)
232  */
233 #define MM_PLAYER_GAPLESS_MODE              "gapless_mode"
234
235 /**
236  * MM_PLAYER_ENABLE_VIDEO_DECODED_CB
237  *
238  * enable video decoded callback (int)
239  */
240 #define MM_PLAYER_ENABLE_VIDEO_DECODED_CB   "enable_video_decoded_cb"
241
242 /**
243  * MM_PLAYER_VIDEO_CODEC_TYPE
244  *
245  * video codec type (int)
246  */
247 #define MM_PLAYER_VIDEO_CODEC_TYPE          "video_codec_type"
248
249 /**
250  * MM_PLAYER_AUDIO_CODEC_TYPE
251  *
252  * audio codec type (int)
253  */
254 #define MM_PLAYER_AUDIO_CODEC_TYPE          "audio_codec_type"
255
256 #define BUFFER_MAX_PLANE_NUM (4)
257
258 typedef struct {
259         MMPixelFormatType format;              /**< image format */
260         int width;                             /**< width of video buffer */
261         int height;                            /**< height of video buffer */
262         unsigned int timestamp;                /**< timestamp of stream buffer (msec)*/
263         unsigned int length_total;             /**< total length of stream buffer (in byte)*/
264         void *data[BUFFER_MAX_PLANE_NUM];
265         void *bo[BUFFER_MAX_PLANE_NUM];        /**< TBM buffer object */
266         void *internal_buffer;                 /**< Internal buffer pointer */
267         int stride[BUFFER_MAX_PLANE_NUM];      /**< stride of plane */
268         int elevation[BUFFER_MAX_PLANE_NUM];   /**< elevation of plane */
269         int orientation;                       /**< orientation */
270         int bo_size;                           /**< TBM buffer object size */
271 } MMPlayerVideoStreamDataType;
272
273 /**
274  * Enumerations of player state.
275  */
276 typedef enum {
277         MM_PLAYER_STATE_NULL,                           /**< Player is created, but not realized yet */
278         MM_PLAYER_STATE_READY,                          /**< Player is ready to play media */
279         MM_PLAYER_STATE_PLAYING,                        /**< Player is now playing media */
280         MM_PLAYER_STATE_PAUSED,                         /**< Player is paused while playing media */
281         MM_PLAYER_STATE_NONE,                           /**< Player is not created yet */
282         MM_PLAYER_STATE_NUM,                            /**< Number of player states */
283 } MMPlayerStateType;
284
285 /**
286  * Enumerations of position formats.
287  */
288 typedef enum {
289         MM_PLAYER_POS_FORMAT_TIME,                      /**< Format for time based */
290         MM_PLAYER_POS_FORMAT_PERCENT,                   /**< Format for percentage */
291         MM_PLAYER_POS_FORMAT_NUM,                       /**< Number of position formats */
292 } MMPlayerPosFormatType;
293
294 /**
295  * Enumeration for attribute values types.
296  */
297 typedef enum {
298         MM_PLAYER_ATTRS_TYPE_INVALID = -1,        /**< Type is invalid */
299         MM_PLAYER_ATTRS_TYPE_INT,                 /**< Integer type */
300         MM_PLAYER_ATTRS_TYPE_DOUBLE,              /**< Double type */
301         MM_PLAYER_ATTRS_TYPE_STRING,              /**< UTF-8 String type */
302         MM_PLAYER_ATTRS_TYPE_DATA,                /**< Pointer type */
303         MM_PLAYER_ATTRS_TYPE_ARRAY,               /**< Array type */
304         MM_PLAYER_ATTRS_TYPE_RANGE,               /**< Range type */
305         MM_PLAYER_ATTRS_TYPE_NUM,                 /**< Number of attribute type */
306 } MMPlayerAttrsType;
307
308 /**
309  * Enumeration for attribute validation type.
310  */
311 typedef enum {
312         MM_PLAYER_ATTRS_VALID_TYPE_INVALID = -1,                /**< Invalid validation type */
313         MM_PLAYER_ATTRS_VALID_TYPE_NONE,                                /**< Do not check validity */
314         MM_PLAYER_ATTRS_VALID_TYPE_INT_ARRAY,          /**< validity checking type of integer array */
315         MM_PLAYER_ATTRS_VALID_TYPE_INT_RANGE,          /**< validity checking type of integer range */
316         MM_PLAYER_ATTRS_VALID_TYPE_DOUBLE_ARRAY,                /**< validity checking type of double array */
317         MM_PLAYER_ATTRS_VALID_TYPE_DOUBLE_RANGE,       /**< validity checking type of double range */
318 } MMPlayerAttrsValidType;
319
320 /**
321  * Enumeration for attribute access flag.
322  */
323 typedef enum {
324         MM_PLAYER_ATTRS_FLAG_NONE = 0,                                  /**< None flag is set */
325         MM_PLAYER_ATTRS_FLAG_READABLE = 1 << 0,                 /**< Readable */
326         MM_PLAYER_ATTRS_FLAG_WRITABLE = 1 << 1,                 /**< Writable */
327         MM_PLAYER_ATTRS_FLAG_MODIFIED = 1 << 2,                 /**< Modified */
328
329         MM_PLAYER_ATTRS_FLAG_RW = MM_PLAYER_ATTRS_FLAG_READABLE | MM_PLAYER_ATTRS_FLAG_WRITABLE, /**< Readable and Writable */
330 } MMPlayerAttrsFlag;
331
332 /**
333  * Enumeration for progressive download
334  */
335 typedef enum {
336         MM_PLAYER_PD_MODE_NONE,
337         MM_PLAYER_PD_MODE_URI,
338         MM_PLAYER_PD_MODE_FILE  // not tested yet, because of no fixed scenario
339 } MMPlayerPDMode;
340
341 /**
342  * Enumeration of track types
343  */
344 typedef enum {
345         MM_PLAYER_TRACK_TYPE_AUDIO = 0,
346         MM_PLAYER_TRACK_TYPE_VIDEO,
347         MM_PLAYER_TRACK_TYPE_TEXT,
348         MM_PLAYER_TRACK_TYPE_MAX
349 } MMPlayerTrackType;
350
351 /**
352  * Enumeration of runtime buffering mode
353  */
354 typedef enum {
355         MM_PLAYER_BUFFERING_MODE_ADAPTIVE = 0,  /**< default, If buffering is occurred, player will consider the bandwidth to adjust buffer setting. */
356         MM_PLAYER_BUFFERING_MODE_FIXED,                 /**< player will set buffer size with this fixed size value. */
357         MM_PLAYER_BUFFERING_MODE_MAX,
358 } MMPlayerBufferingMode;
359
360 /**
361  * Edge Properties of the text.
362  */
363 typedef enum {
364         MM_PLAYER_EDGE_NO,
365         MM_PLAYER_EDGE_RAISED,
366         MM_PLAYER_EDGE_DEPRESSED,
367         MM_PLAYER_EDGE_UNIFORM,
368         MM_PLAYER_EDGE_DROPSHADOW
369 } MMPlayerSubtitleEdge;
370
371 /**
372  * Enumeration of media stream buffer status
373  */
374 typedef enum {
375         MM_PLAYER_MEDIA_STREAM_BUFFER_UNDERRUN,
376         MM_PLAYER_MEDIA_STREAM_BUFFER_OVERFLOW,
377 } MMPlayerMediaStreamBufferStatus;
378
379 /**
380  * Enumeration for stream type.
381  */
382 typedef enum {
383         MM_PLAYER_STREAM_TYPE_DEFAULT,  /**< Container type */
384         MM_PLAYER_STREAM_TYPE_AUDIO,    /**< Audio element stream type */
385         MM_PLAYER_STREAM_TYPE_VIDEO,    /**< Video element stream type */
386         MM_PLAYER_STREAM_TYPE_TEXT,     /**< Text type */
387         MM_PLAYER_STREAM_TYPE_MAX,
388 } MMPlayerStreamType;
389
390 typedef enum {
391         MM_PLAYER_CODEC_TYPE_DEFAULT = 0, /**< codec is selected by the priority */
392         MM_PLAYER_CODEC_TYPE_HW,          /**< HW codec can only be selected */
393         MM_PLAYER_CODEC_TYPE_SW,          /**< SW codec can only be selected */
394 } MMPlayerVideoCodecType;
395
396 /**
397  * Attribute validity structure
398  */
399 typedef struct {
400          MMPlayerAttrsType type;
401          MMPlayerAttrsValidType validity_type;
402          MMPlayerAttrsFlag flag;
403         /**
404           * a union that describes validity of the attribute.
405           * Only when type is 'MM_ATTRS_TYPE_INT' or 'MM_ATTRS_TYPE_DOUBLE',
406           * the attribute can have validity.
407          */
408          union {
409                 /**
410                    * Validity structure for integer array.
411                  */
412                 struct {
413                         int *array;  /**< a pointer of array */
414                         int count;   /**< size of array */
415                         int d_val;
416                 } int_array;
417                 /**
418                    * Validity structure for integer range.
419                  */
420                 struct {
421                         int min;   /**< minimum range */
422                         int max;   /**< maximum range */
423                         int d_val;
424                 } int_range;
425                 /**
426                 * Validity structure for double array.
427                 */
428                 struct {
429                         double   * array;  /**< a pointer of array */
430                         int    count;   /**< size of array */
431                         double d_val;
432                 } double_array;
433                 /**
434                 * Validity structure for double range.
435                 */
436                 struct {
437                         double   min;   /**< minimum range */
438                         double   max;   /**< maximum range */
439                         double d_val;
440                 } double_range;
441         };
442 } MMPlayerAttrsInfo;
443
444 /**
445  * Volume type.
446  *
447  * @see         mm_player_set_volume, mm_player_get_volume
448  */
449 typedef struct {
450         float   level[MM_VOLUME_CHANNEL_NUM];   /**< Relative volume factor for each channels */
451 } MMPlayerVolumeType;
452
453 /**
454  * Video stream info in external demux case
455  *
456 **/
457 typedef struct _VideoStreamInfo {
458         const char *mime;
459         unsigned int framerate_num;
460         unsigned int framerate_den;
461         unsigned int width;
462         unsigned int height;
463         unsigned char *codec_extradata;
464         unsigned int extradata_size;
465         unsigned int version;
466 } MMPlayerVideoStreamInfo;
467
468 /**
469  * Audio stream info in external demux case
470  *
471 **/
472 typedef struct _AudioStreamInfo {
473         const char *mime;
474         unsigned int channels;
475         unsigned int sample_rate;
476         unsigned char *codec_extradata;
477         unsigned int extradata_size;
478         unsigned int version;
479         unsigned int user_info;
480
481         /* for pcm */
482 //      unsigned int width;
483 //      unsigned int depth;
484 //      unsigned int endianness;
485 //      bool signedness;
486 } MMPlayerAudioStreamInfo;
487
488 /**
489  * Subtitle stream info in external demux case
490  *
491 **/
492 typedef struct _SubtitleStreamInfo {
493         const char *mime;
494         unsigned int codec_tag;
495         void *context;  //for smpte text
496 } MMPlayerSubtitleStreamInfo;
497
498 /**
499  * selected subtitle track number callback function type.
500  *
501  * @param       track_num       [in]    Track number of subtitle
502  * @param       user_param      [in]    User defined parameter
503  *
504  *
505  * @return      This callback function have to return MM_ERROR_NONE.
506  */
507 typedef bool            (*mm_player_track_selected_subtitle_language_callback)(int track_num, void *user_param);
508
509 /**
510  * Buffer underrun / overflow data callback function type.
511  *
512  * @param       status     [in] buffer status
513  * @param       user_param [in] User defined parameter which is passed when set
514  *                          to enough data callback or need data callback
515  *
516  * @return      This callback function have to return MM_ERROR_NONE.
517  */
518 typedef bool    (*mm_player_media_stream_buffer_status_callback) (MMPlayerStreamType type, MMPlayerMediaStreamBufferStatus status, unsigned long long bytes, void *user_param);
519
520 /**
521  * Buffer seek data callback function type.
522  *
523  * @param       offset     [in] offset for the buffer playback
524  * @param       user_param [in] User defined parameter which is passed when set
525  *                          to seek data callback
526  *
527  * @return      This callback function have to return MM_ERROR_NONE.
528  */
529 typedef bool    (*mm_player_media_stream_seek_data_callback) (MMPlayerStreamType type, unsigned long long offset, void *user_param);
530
531 /**
532  * Called to notify the stream changed.
533  *
534  * @param user_data [in] The user data passed from the callback registration function
535  *
536  * @return      This callback function have to return MM_ERROR_NONE.
537  */
538 typedef bool    (*mm_player_stream_changed_callback) (void *user_param);
539
540
541 /*===========================================================================================
542 |                                                                                           |
543 |  GLOBAL FUNCTION PROTOTYPES                                        |
544 |                                                                                           |
545 ========================================================================================== */
546
547 /**
548  * This function creates a player object for playing multimedia contents. \n
549  * The attributes of player are created to get/set some values with application. \n
550  * And, mutex, gstreamer and other resources are initialized at this time. \n
551  * If player is created, the state will become MM_PLAYER_STATE_NULL.
552  *
553  * @param   player [out] Handle of player
554  *
555  * @return  This function returns zero on success, or negative value with error code. \n
556  *          Please refer 'mm_error.h' to know it in detail.
557  * @pre     None
558  * @post    MM_PLAYER_STATE_NULL
559  * @see     mm_player_destroy
560  * @remark  You can create multiple handles on a context at the same time. \n
561  *          However, player cannot guarantee proper operation because of limitation of resources, \n
562  *          such as audio device or display device.
563  *
564  * @par Example
565  * @code
566 char *g_err_attr_name = NULL;
567
568 if (mm_player_create(&g_player) != MM_ERROR_NONE) {
569         LOGE("failed to create player\n");
570 }
571
572 if (mm_player_set_attribute(g_player,
573                                                 &g_err_attr_name,
574                                                 "profile_uri", filename, strlen(filename),
575                                                 "display_overlay", (void*)&g_win.xid, sizeof(g_win.xid),
576                                                 NULL) != MM_ERROR_NONE) {
577         LOGE("failed to set %s attribute\n", g_err_attr_name);
578         free(g_err_attr_name);
579 }
580
581 mm_player_set_message_callback(g_player, msg_callback, (void*)g_player);
582  * @endcode
583  */
584 int mm_player_create(MMHandleType *player);
585
586 /**
587  * This function releases player object and all resources which were created by mm_player_create(). \n
588  * And, player handle will also be destroyed.
589  *
590  * @param   player [in] Handle of player
591  *
592  * @return  This function returns zero on success, or negative value with error code.
593  * @pre     Player state may be MM_PLAYER_STATE_NULL. \n
594  *          But, it can be called in any state.
595  * @post    Because handle is released, there is no any state.
596  * @see     mm_player_create
597  * @remark  This method can be called with a valid player handle from any state to \n
598  *          completely shutdown the player operation.
599  *
600  * @par Example
601  * @code
602 if (mm_player_destroy(g_player) != MM_ERROR_NONE) {
603         LOGE("failed to destroy player\n");
604 }
605  * @endcode
606  */
607 int mm_player_destroy(MMHandleType player);
608
609 /**
610  * This function parses uri and makes gstreamer pipeline by uri scheme. \n
611  * So, uri should be set before realizing with mm_player_set_attribute(). \n
612  *
613  * @param   player [in] Handle of player
614  *
615  * @return  This function returns zero on success, or negative value with error code.
616  *
617  * @pre     Player state should be MM_PLAYER_STATE_NULL.
618  * @post    player state will be MM_PLAYER_STATE_READY.
619  * @see     mm_player_unrealize
620  * @remark  None
621  * @par Example
622  * @code
623 if (mm_player_realize(g_player) != MM_ERROR_NONE) {
624         LOGE("failed to realize player\n");
625 }
626  * @endcode
627  */
628 int mm_player_realize(MMHandleType player);
629
630 /**
631  * This function uninitializes player object. So, resources and allocated memory \n
632  * will be freed. And, gstreamer pipeline is also destroyed. So, if you want to play \n
633  * other contents, player should be created again after destruction or realized with new uri.
634  *
635  * @param   player [in] Handle of player
636  *
637  * @return  This function returns zero on success, or negative value with error code.
638  * @pre     Player state may be MM_PLAYER_STATE_READY to unrealize. \n
639  *          But, it can be called in any state.
640  * @post    Player state will be MM_PLAYER_STATE_NULL.
641  * @see     mm_player_realize
642  * @remark  This method can be called with a valid player handle from any state.
643  *
644  * @par Example
645  * @code
646 if (mm_player_unrealize(g_player) != MM_ERROR_NONE) {
647         LOGE("failed to unrealize player\n");
648 }
649  * @endcode
650  */
651 int mm_player_unrealize(MMHandleType player);
652
653 /**
654  * This function is to abort pause state transition
655  * for unrealize or destroy.
656  */
657 int mm_player_abort_pause(MMHandleType player);
658
659 /**
660  * This function is to get current state of player. \n
661  * Application have to check current state before doing some action.
662  *
663  * @param player [in]  Handle of player
664  * @param state  [out] current state of player on success
665  *
666  * @return   This function returns zero on success, or negative value with error code.
667  *
668  * @see      MMPlayerStateType
669  * @remark   None
670  * @par Example
671  * @code
672 if (mm_player_get_state(g_player, &state) != MM_ERROR_NONE) {
673         LOGE("failed to get state\n");
674 }
675  * @endcode
676  */
677 int mm_player_get_state(MMHandleType player, MMPlayerStateType *state);
678
679 /**
680  * This function is to set relative volume of player. \n
681  * So, It controls logical volume value. \n
682  * But, if developer want to change system volume, mm sound api should be used.
683  *
684  * @param       player          [in]    Handle of player
685  * @param       volume          [in]    Volume factor of each channel
686  *
687  * @return      This function returns zero on success, or negative value with error code.
688  * @see         MMPlayerVolumeType, mm_player_get_volume
689  * @remark      The range of factor range is from 0 to 1.0. (1.0 = 100%) And, default value is 1.0.
690  * @par Example
691  * @code
692 MMPlayerVolumeType volume;
693 int i = 0;
694
695 for (i = 0; i < MM_VOLUME_CHANNEL_NUM; i++)
696         volume.level[i] = MM_VOLUME_LEVEL_MAX;
697
698 if (mm_player_set_volume(g_player, &volume) != MM_ERROR_NONE)
699 {
700     LOGE("failed to set volume\n");
701 }
702  * @endcode
703  */
704 int mm_player_set_volume(MMHandleType player, MMPlayerVolumeType *volume);
705
706 /**
707  * This function is to get current volume factor of player.
708  *
709  * @param       player          [in]    Handle of player.
710  * @param       volume          [out]   Volume factor of each channel.
711  *
712  * @return      This function returns zero on success, or negative value with error code.
713  *
714  * @see         MMPlayerVolumeType, mm_player_set_volume
715  * @remark  None
716  * @par Example
717  * @code
718 MMPlayerVolumeType volume;
719 int i;
720
721 if (mm_player_get_volume(g_player, &volume) != MM_ERROR_NONE)
722 {
723         LOGW("failed to get volume\n");
724 }
725
726 for (i = 0; i < MM_VOLUME_CHANNEL_NUM; i++)
727         LOGD("channel[%d] = %d \n", i, volume.level[i]);
728  * @endcode
729  */
730 int mm_player_get_volume(MMHandleType player, MMPlayerVolumeType *volume);
731
732 /**
733  * This function is to start playing media contents. Demux(parser), codec and related plugins are decided \n
734  * at this time. And, MM_MESSAGE_BEGIN_OF_STREAM will be posted through callback function registered \n
735  * by mm_player_set_message_callback().
736  *
737  * @param       player          [in]    Handle of player
738  *
739  * @return      This function returns zero on success, or negative value with error code.
740  * @remark
741  *
742  * @pre         Player state may be MM_PLAYER_STATE_READY.
743  * @post                Player state will be MM_PLAYER_STATE_PLAYING.
744  * @see         mm_player_stop
745  * @remark  None
746  * @par Example
747  * @code
748 if (mm_player_start(g_player) != MM_ERROR_NONE)
749 {
750         LOGE("failed to start player\n");
751 }
752  * @endcode
753  */
754 int mm_player_start(MMHandleType player);
755
756 /**
757  * This function is to stop playing media contents and it's different with pause. \n
758  * If mm_player_start() is called after this, content will be started again from the beginning. \n
759  * So, it can be used to close current playback.
760  *
761  * @param       player          [in]    Handle of player
762  *
763  * @return      This function returns zero on success, or negative value with error code.
764  *
765  * @pre         Player state may be MM_PLAYER_STATE_PLAYING.
766  * @post                Player state will be MM_PLAYER_STATE_READY.
767  * @see         mm_player_start
768  * @remark  None
769  * @par Example
770  * @code
771 if (mm_player_stop(g_player) != MM_ERROR_NONE)
772 {
773         LOGE("failed to stop player\n");
774 }
775  * @endcode
776  */
777 int mm_player_stop(MMHandleType player);
778
779 /**
780  * This function is to pause playing media contents.
781  *
782  * @param       player          [in]    Handle of player.
783  *
784  * @return      This function returns zero on success, or negative value with error code.
785  *
786  * @pre         Player state may be MM_PLAYER_STATE_PLAYING.
787  * @post                Player state will be MM_PLAYER_STATE_PAUSED.
788  * @see         mm_player_resume
789  * @remark  None
790  * @par Example
791  * @code
792 if (mm_player_pause(g_player) != MM_ERROR_NONE)
793 {
794         LOGE("failed to pause player\n");
795 }
796  * @endcode
797  */
798 int mm_player_pause(MMHandleType player);
799
800 /**
801  * This function is to resume paused media contents.
802  *
803  * @param       player          [in]    Handle of player.
804  *
805  * @return      This function returns zero on success, or negative value with error code.
806  *
807  * @pre         Player state may be MM_PLAYER_STATE_PAUSED.
808  * @post                Player state will be MM_PLAYER_STATE_PLAYING.
809  * @see         mm_player_pause
810  * @remark  None
811  * @par Example
812  * @code
813 if (mm_player_resume(g_player) != MM_ERROR_NONE)
814 {
815         LOGE("failed to resume player\n");
816 }
817  * @endcode
818  */
819 int mm_player_resume(MMHandleType player);
820
821 /**
822  * This function is to set the position for playback. \n
823  * So, it can be seeked to requested position. \n
824  *
825  * @param       player          [in]    Handle of player
826  * @param       pos                     [in]    Position for playback
827  *
828  * @return      This function returns zero on success, or negative value with error code.
829  * @see         mm_player_get_position
830  * @remark  the unit of time-based format is millisecond and other case is percent.
831  */
832 int mm_player_set_position(MMHandleType player, int64_t pos);
833
834 /**
835  * This function is to get current position of playback content.
836  *
837  * @param       player          [in]    Handle of player.
838  * @param       format          [in]    Format of position.
839  * @param    pos        [out] contains current position on success or zero in case of failure.
840  *
841  * @return      This function returns zero on success, or negative value with errors
842  * @see         mm_player_set_position
843  * @remark  the unit of time-based format is millisecond and other case is percent.
844  */
845 int mm_player_get_position(MMHandleType player, int64_t *pos);
846
847 /**
848  * This function is to get the content time duration.
849  */
850 int mm_player_get_duration(MMHandleType player, int64_t *dur);
851
852 /**
853  * This function is to get current buffer position of playback content.
854  *
855  * @param   player      [in]    Handle of player.
856  * @param   format      [in]    Format of position.
857  * @param   start_pos   [out] contains buffer start  position on success or zero in case of failure.
858  * @param   stop_pos    [out] contains buffer current  position on success or zero in case of failure.
859  *
860  * @return      This function returns zero on success, or negative value with errors
861  * @see         MMPlayerPosFormatType, mm_player_set_position
862  * @remark  the unit of time-based format is millisecond and other case is percent.
863  * @par Example
864  * @code
865 int start_pos = 0, stop_pos = 0;
866
867 mm_player_get_buffer_position(g_player, MM_PLAYER_POS_FORMAT_PERCENT, &start_pos, &stop_pos );
868
869 LOGD("buffer position: [%d] ~ [%d] \%\n", start_pos, stop_pos );
870  * @endcode
871  */
872 int mm_player_get_buffer_position(MMHandleType player, MMPlayerPosFormatType format, unsigned long *start_pos, unsigned long *stop_pos);
873
874 /**
875  * This function sets callback function for receiving messages from player.
876  * So, player can notify warning, error and normal cases to application.
877  *
878  * @param       player          [in]    Handle of player.
879  * @param       callback        [in]    Message callback function.
880  * @param       user_param      [in]    User parameter which is passed to callback function.
881  *
882  * @return      This function returns zero on success, or negative value with error code.
883  * @see         MMMessageCallback
884  * @remark  None
885  * @par Example
886  * @code
887 int msg_callback(int message, MMMessageParamType *param, void *user_param)
888 {
889         switch (message)
890         {
891                 case MM_MESSAGE_ERROR:
892                         //do something
893                         break;
894
895                 case MM_MESSAGE_END_OF_STREAM:
896                         //do something
897                         break;
898
899                 case MM_MESSAGE_STATE_CHANGED:
900                         //do something
901                         break;
902
903                 case MM_MESSAGE_BEGIN_OF_STREAM:
904                         //do something
905                         break;
906
907                 default:
908                         break;
909         }
910         return TRUE;
911 }
912
913 mm_player_set_message_callback(g_player, msg_callback, (void*)g_player);
914  * @endcode
915  */
916 int mm_player_set_message_callback(MMHandleType player, MMMessageCallback callback, void *user_param);
917
918 /**
919  * This function is to mute volume of player
920  *
921  * @param       player  [in]    Handle of player
922  * @param       mute    [in]    Mute(1) or not mute(0)
923  *
924  * @return      This function returns zero on success, or negative value with error code
925  * @see         mm_player_get_mute
926  * @remark  None
927  * @par Example
928  * @code
929 if (mm_player_set_mute(g_player, TRUE) != MM_ERROR_NONE)
930 {
931         LOGW("failed to set mute\n");
932 }
933  * @endcode
934  */
935 int mm_player_set_mute(MMHandleType player, int mute);
936
937 /**
938  * This function is to get mute value of player
939  *
940  * @param       player  [in]    Handle of player
941  * @param       mute    [out]   Sound is muted
942  *
943  * @return      This function returns zero on success, or negative value with error code
944  * @see         mm_player_set_mute
945  * @remark  None
946  * @par Example
947  * @code
948 int mute;
949
950 if (mm_player_get_mute(g_player, &mute) != MM_ERROR_NONE)
951 {
952         LOGW("failed to get mute\n");
953 }
954
955 LOGD("mute status:%d\n", mute);
956  * @endcode
957  */
958 int mm_player_get_mute(MMHandleType player, int *mute);
959
960 /**
961  * This function is to adjust subtitle postion. So, subtitle can show at the adjusted position. \n
962  * If pos is negative, subtitle will be displayed previous time, the other hand forward time. \n
963  *
964  * @param       player  [in]    Handle of player
965  * @param       pos             [in]    postion to be adjusted
966  *
967  * @return      This function returns zero on success, or negative value with error
968  *                      code
969  * @see         mm_player_adjust_subtitle_position
970  * @remark  None
971  * @par Example
972  * @code
973 int pos;
974
975 pos = 5000;
976 if (mm_player_adjust_subtitle_position(g_player, MM_PLAYER_POS_FORMAT_TIME, pos) != MM_ERROR_NONE)
977 {
978         LOGW("failed to adjust subtitle postion.\n");
979 }
980  * @endcode
981  */
982
983 int mm_player_adjust_subtitle_position(MMHandleType player, MMPlayerPosFormatType format, int pos);
984
985 /**
986  * This function is to set subtitle silent status. So, subtitle can show or hide during playback \n
987  * by this value. But, one subtitle file should be set with "subtitle_uri" attribute before calling mm_player_realize(); \n
988  * Player FW parses subtitle file and send text data including timestamp to application \n
989  * through message callback with MM_MESSAGE_UPDATE_SUBTITLE will be. \n
990  * So, application have to render it. And, subtitle can be supported only in a seprate file. \n
991  * So, it's not supported for embedded case.
992  *
993  * @param       player  [in]    Handle of player
994  * @param       silent  [in]    silent(integer value except 0) or not silent(0)
995  *
996  * @return      This function returns zero on success, or negative value with error
997  *                      code
998  * @see         mm_player_get_subtitle_silent, MM_MESSAGE_UPDATE_SUBTITLE
999  * @remark  None
1000  * @par Example
1001  * @code
1002 mm_player_set_attribute(g_player,
1003                                         &g_err_name,
1004                                         "subtitle_uri", g_subtitle_uri, strlen(g_subtitle_uri),
1005                                         NULL
1006                                         );
1007
1008 if (mm_player_set_subtitle_silent(g_player, TRUE) != MM_ERROR_NONE)
1009 {
1010         LOGW("failed to set subtitle silent\n");
1011 }
1012  * @endcode
1013  */
1014 int mm_player_set_subtitle_silent(MMHandleType player, int silent);
1015
1016 /**
1017  * This function is to get silent status of subtitle.
1018  *
1019  * @param       player  [in]    Handle of player
1020  * @param       silent  [out]   subtitle silent property
1021  *
1022  * @return      This function returns zero on success, or negative value with error
1023  *                      code
1024  * @see         mm_player_set_subtitle_silent, MM_MESSAGE_UPDATE_SUBTITLE
1025  * @remark  None
1026  * @par Example
1027  * @code
1028 int silent = FALSE;
1029
1030 if (mm_player_get_subtitle_silent(g_player, &silent) != MM_ERROR_NONE)
1031 {
1032         LOGW("failed to set subtitle silent\n");
1033 }
1034  * @endcode
1035  */
1036 int mm_player_get_subtitle_silent(MMHandleType player, int *silent);
1037
1038 /**
1039  * This function is to set attributes into player. Multiple attributes can be set simultaneously. \n
1040  * If one of attribute fails, this function will stop at the point and let you know the name which is failed. \n
1041  *
1042  * @param   player                 [in]   Handle of player.
1043  * @param   err_attr_name          [out]  Name of attribute which is failed to set
1044  * @param   first_attribute_name   [in]   Name of the first attribute to set
1045  * @param   ...                    [in]   Value for the first attribute, followed optionally by more name/value pairs, terminated by NULL.
1046  *                                        But, in the case of data or string type, it should be name/value/size.
1047  *
1048  * @return  This function returns zero on success, or negative value with error code.
1049  *
1050  * @see     mm_player_get_attribute
1051  * @remark  This function must be terminated by NULL argument.
1052  *          And, if this function is failed, err_attr_name param must be free.
1053  * @par Example
1054  * @code
1055 char *g_err_attr_name = NULL;
1056
1057 if (mm_player_set_attribute(g_player,
1058                                                 &g_err_attr_name,
1059                                                 "profile_uri", filename, strlen(filename),
1060                                                 "profile_play_count", count,
1061                                                 NULL) != MM_ERROR_NONE) {
1062         LOGW("failed to set %s attribute\n", g_err_attr_name);
1063         free(g_err_attr_name);
1064 }
1065
1066  * @endcode
1067  */
1068 int mm_player_set_attribute(MMHandleType player,  char **err_attr_name, const char *first_attribute_name, ...)G_GNUC_NULL_TERMINATED;
1069
1070 /**
1071  * This function is to get attributes from player. Multiple attributes can be got simultaneously.
1072  *
1073  * @param   player                [in]  Handle of player.
1074  * @param   err_attr_name         [out] Name of attribute which is failed to get
1075  * @param   first_attribute_name  [in]  Name of the first attribute to get
1076  * @param   ...                   [out] Value for the first attribute, followed optionally by more name/value pairs, terminated by NULL.
1077  *                                      But, in the case of data or string type, it should be name/value/size.
1078  *
1079  * @return  This function returns zero on success, or negative value with error
1080  *          code.
1081  * @see     mm_player_set_attribute
1082  * @remark  This function must be terminated by NULL argument.
1083  *          And, if this function is failed, err_attr_name param must be free.
1084  */
1085 int mm_player_get_attribute(MMHandleType player,  char **err_attr_name, const char *first_attribute_name, ...)G_GNUC_NULL_TERMINATED;
1086
1087 /**
1088  * This function is to get detail information of attribute.
1089  *
1090  * @param   player          [in]  Handle of player.
1091  * @param   attribute_name  [in]  Name of the attribute to get
1092  * @param   info            [out] Attribute infomation
1093  *
1094  * @return  This function returns zero on success, or negative value with error
1095  *          code.
1096  *
1097  * @see     mm_player_set_attribute, mm_player_get_attribute
1098  * @remark  None
1099  * @par Example
1100  * @code
1101 if (mm_player_get_attribute_info(g_player, "display_method", &method_info) != MM_ERROR_NONE) {
1102         LOGW("failed to get info\n");
1103 }
1104
1105 LOGD("type:%d \n", method_info.type); //int, double..
1106 LOGD("flag:%d \n", method_info.flag); //readable, writable..
1107 LOGD("validity type:%d \n", method_info.validity_type); //range, array..
1108
1109 if (method_info. validity_type == MM_PLAYER_ATTRS_VALID_TYPE_INT_RANGE) {
1110         LOGD("range min:%d\n", method_info.int_range.min);
1111         LOGD("range max:%d\n", method_info.int_range.max);
1112 }
1113  * @endcode
1114  */
1115 int mm_player_get_attribute_info(MMHandleType player,  const char *attribute_name, MMPlayerAttrsInfo *info);
1116
1117 /**
1118  * This function is to get download position and total size of progressive download
1119  *
1120  * @param   player      [in] Handle of player.
1121  * @param   current_pos [in] Download position currently (bytes)
1122  * @param   total_size  [in] Total size of file (bytes)
1123  *
1124  * @return  This function returns zero on success, or negative value with error code.
1125  * @par Example
1126  * @code
1127 guint64 current_pos = 0LLU;
1128 guint64 total_size = 0LLU;
1129
1130 if (mm_player_get_pd_status(g_player, &current_pos, &total_size, NULL) != MM_ERROR_NONE)
1131 {
1132         LOGD("current download pos = %llu, total size = %llu\n", current_pos, total_size);
1133 }
1134  * @endcode
1135  */
1136 int mm_player_get_pd_status(MMHandleType player, guint64 *current_pos, guint64 *total_size);
1137
1138 /**
1139  * This function sets callback function for receiving messages of PD downloader.
1140  *
1141  * @param   player     [in] Handle of player.
1142  * @param   callback   [in] Message callback function.
1143  * @param   user_param [in] User parameter which is passed to callback function.
1144  *
1145  * @return  This function returns zero on success, or negative value with error code.
1146  * @see
1147  * @remark  None
1148  * @par Example
1149  * @code
1150 int msg_callback(int message, MMMessageParamType *param, void *user_param)
1151 {
1152         switch (message)
1153         {
1154                 case MM_MESSAGE_PD_DOWNLOADER_START:
1155                         LOGD("Progressive download is started...\n");
1156                         break;
1157                 case MM_MESSAGE_PD_DOWNLOADER_END:
1158                         LOGD("Progressive download is ended...\n");
1159                         break;
1160                 default:
1161                         break;
1162         }
1163         return TRUE;
1164 }
1165
1166 mm_player_set_pd_message_callback(g_player, msg_callback, NULL);
1167  * @endcode
1168  */
1169 int mm_player_set_pd_message_callback(MMHandleType player, MMMessageCallback callback, void *user_param);
1170
1171 /**
1172  * This function is to get the track count
1173  *
1174  * @param   player [in]  handle of player.
1175  * @param   track  [in]  type of the track type
1176  * @param   info   [out] the count of the track
1177  *
1178  * @return  This function returns zero on success, or negative value with error
1179  *          code.
1180  *
1181  * @par Example
1182  * @code
1183 gint audio_count = 0;
1184
1185 if (mm_player_get_track_count(g_player, MM_PLAYER_TRACK_TYPE_AUDIO, &audio_count) != MM_ERROR_NONE) {
1186         LOGW("failed to get audio track count\n");
1187 }
1188
1189 LOGD("audio track count : %d \n", audio_count);
1190  * @endcode
1191  */
1192 int mm_player_get_track_count(MMHandleType player,  MMPlayerTrackType type, int *count);
1193
1194 /**
1195  * This function is to select the track
1196  *
1197  * @param   player [in] handle of player.
1198  * @param   type   [in] type of the track type
1199  * @param   index  [in] the index of the track
1200  *
1201  * @return  This function returns zero on success, or negative value with error
1202  *          code.
1203  */
1204 int mm_player_select_track(MMHandleType player, MMPlayerTrackType type, int index);
1205 #ifdef _MULTI_TRACK
1206 /**
1207  * This function is to add the track when user want multi subtitle
1208  *
1209  * @param   player              [in]    handle of player.
1210  * @param   index               [in]    the index of the track
1211  *
1212  * @return  This function returns zero on success, or negative value with error
1213  *          code.
1214  */
1215 int mm_player_track_add_subtitle_language(MMHandleType player, int index);
1216
1217 /**
1218  * This function is to remove the track when user want multi subtitle
1219  *
1220  * @param   player  [in] handle of player.
1221  * @param   index   [in] the index of the track
1222  *
1223  * @return  This function returns zero on success, or negative value with error
1224  *          code.
1225  */
1226 int mm_player_track_remove_subtitle_language(MMHandleType player, int index);
1227
1228 /**
1229  * This function is to notify which sutitle track is in use
1230  *
1231  * @param   player    [in] handle of player.
1232  * @param   callback  [in] callback function to register
1233  * @param   user_data [in] user data to be passed to the callback function
1234  *
1235  * @return  This function returns zero on success, or negative value with error
1236  *          code.
1237  */
1238 int mm_player_track_foreach_selected_subtitle_language(MMHandleType player, mm_player_track_selected_subtitle_language_callback callback, void *user_param);
1239 #endif
1240 /**
1241  * This function is to get the track language
1242  *
1243  * @param   player [in]  handle of player.
1244  * @param   type   [in]  type of the track type
1245  * @param   index  [in]  the index of the track
1246  * @param   code   [out] language code in ISO 639-1(string)
1247  *
1248  * @return  This function returns zero on success, or negative value with error
1249  *          code.
1250  */
1251 int mm_player_get_track_language_code(MMHandleType player,  MMPlayerTrackType type, int index, char **code);
1252
1253 /**
1254  * This function is to get the current running track
1255  *
1256  * @param       player          [in]    handle of player.
1257  * @param       type                    [in]    type of the track type
1258  * @param       index           [out]    the index of the track
1259  *
1260  * @return      This function returns zero on success, or negative value with error
1261  *                      code.
1262  */
1263
1264 int mm_player_get_current_track(MMHandleType hplayer, MMPlayerTrackType type, int *index);
1265
1266 /**
1267  * This function is to set the subtitle path
1268  *
1269  * @param       player  [in]    handle of player
1270  * @param       path    [in]    subtitle path
1271  *
1272  * @return      This function returns zero on success, or negative value with error code.
1273  */
1274 int mm_player_set_external_subtitle_path(MMHandleType player, const char* path);
1275
1276 /**
1277  * This function is to set the clock which is from master player
1278  *
1279  * @param       player  [in]    handle of player
1280  * @param       clock   [in]    clock of master player
1281  * @param       clock_delta [in]        clock difference between master and slave
1282  * @param       video_time      [in]    current playing position
1283  * @param       media_clock     [in]    media clock information
1284  * @param       audio_time      [in]    audio timestamp information
1285  * @return      This function returns zero on success, or negative value with error code.
1286  */
1287 int mm_player_set_video_share_master_clock(MMHandleType player, int64_t clock, int64_t clock_delta, int64_t video_time, int64_t media_clock, int64_t audio_time);
1288 /**
1289  * This function is to get the master clock
1290  *
1291  * @param       player          [in]    handle of player
1292  * @param       video_time      [out]   current playing position
1293  * @param       media_clock     [out]   media clock information
1294  * @param       audio_time      [out]   audio timestamp information
1295  * @return      This function returns zero on success, or negative value with error code.
1296  */
1297 int mm_player_get_video_share_master_clock(MMHandleType player, int64_t *video_time, int64_t *media_clock, int64_t *audio_time);
1298
1299 /**
1300  * This function is to set download mode of video hub
1301  *
1302  * @param       player          [in]    handle of player
1303  * @param       mode            [in]    download mode
1304  * @return      This function returns zero on success, or negative value with error code.
1305  */
1306 int mm_player_set_video_hub_download_mode(MMHandleType player, bool mode);
1307
1308 /**
1309  * This function is to set using sync handler.
1310  *
1311  * @param       player          [in]    handle of player
1312  * @param       enable          [in]    enable/disable
1313  * @return      This function returns zero on success, or negative value with error code.
1314  */
1315 int mm_player_enable_sync_handler(MMHandleType player, bool enable);
1316
1317 /**
1318  * This function is to set uri.
1319  *
1320  * @param   player [in] handle of player
1321  * @param   uri    [in] uri
1322  * @return  This function returns zero on success, or negative value with error code.
1323  */
1324 int mm_player_set_uri(MMHandleType player, const char *uri);
1325
1326 /**
1327  * This function is to set next uri.
1328  *
1329  * @param   player [in] handle of player
1330  * @param   uri    [in] uri
1331  * @return  This function returns zero on success, or negative value with error code.
1332  */
1333 int mm_player_set_next_uri(MMHandleType player, const char *uri);
1334
1335 /**
1336  * This function is to get next uri.
1337  *
1338  * @param   player   [in]  handle of player
1339  * @param   uri      [out] uri
1340  * @return  This function returns zero on success, or negative value with error code.
1341  */
1342 int mm_player_get_next_uri(MMHandleType player, char **uri);
1343
1344 /**
1345  * This function is to decrease reference count of internal buffer.
1346  *
1347  * @param    buffer [in] video callback internal buffer
1348  * @return   None;
1349  */
1350 void mm_player_video_stream_internal_buffer_unref(void *buffer);
1351
1352 /**mm_player_submit_packet
1353  * This function is to submit buffer to appsrc.  \n
1354  * @param   player                      [in]    Handle of player.
1355  * @param   buf             [in]    buffer to be submit in appsrc in external feeder case.
1356  * @param   len                         [in]    length of buffer.
1357  * @param   pts                         [in]    timestamp of buffer.
1358  * @param   streamtype          [in]    stream type of buffer.
1359  * @return  This function returns zero on success, or negative value with error code.
1360  */
1361 int mm_player_submit_packet(MMHandleType player, media_packet_h packet);
1362
1363 /**mm_player_set_video_info
1364  * This function is to set caps of src pad of video appsrc in external feeder case.  \n
1365  * @param   player         [in] Handle of player.
1366  * @param   media_format_h [in] Video stream info.
1367  * @return  This function returns zero on success, or negative value with error code.
1368  */
1369 int mm_player_set_video_info(MMHandleType player, media_format_h format);
1370
1371 /**mm_player_set_audio_info
1372  * This function is to set caps of src pad of Audio appsrc in external feeder case.  \n
1373  * @param       player                       [in]    Handle of player.
1374  * @param       media_format_h               [in]    Audio stream info.
1375  * @return      This function returns zero on success, or negative value with error code.
1376  */
1377 int mm_player_set_audio_info(MMHandleType player, media_format_h format);
1378
1379 /**mm_player_set_subtitle_info
1380  * This function is to set caps of src pad of subtitle appsrc in external feeder case.  \n
1381  * @param       player                          [in]    Handle of player.
1382  * @param       subtitle_stream_info               [in]    Subtitle stream info.
1383  * @return      This function returns zero on success, or negative value with error code.
1384  */
1385 int mm_player_set_subtitle_info(MMHandleType player, MMPlayerSubtitleStreamInfo *info);
1386
1387 /**
1388  * This function set callback function for receiving need or enough data message from player.
1389  *
1390  * @param   player     [in] Handle of player.
1391  * @param   type       [in] stream type
1392  * @param   callback   [in] data callback function for stream type.
1393  * @param   user_param [in] User parameter.
1394  *
1395  * @return  This function returns zero on success, or negative value with error
1396  *          code.
1397  */
1398 int mm_player_set_media_stream_buffer_status_callback(MMHandleType player, MMPlayerStreamType type, mm_player_media_stream_buffer_status_callback callback, void * user_param);
1399
1400 /**
1401  * This function set callback function for receiving seek data message from player.
1402  *
1403  * @param       player          [in]    Handle of player.
1404  * @param       type            [in]    stream type
1405  * @param       callback        [in]    Seek data callback function for stream type.
1406  * @param       user_param      [in]    User parameter.
1407  *
1408  * @return      This function returns zero on success, or negative value with error
1409  *                      code.
1410  */
1411 int mm_player_set_media_stream_seek_data_callback(MMHandleType player, MMPlayerStreamType type, mm_player_media_stream_seek_data_callback callback, void * user_param);
1412
1413 /**
1414  * This function is to set max size of buffer(appsrc).
1415  *
1416  * @param       player          [in]    Handle of player.
1417  * @param       type            [in]    stream type
1418  * @param       max_size        [in]    max bytes of buffer.
1419  *
1420  * @return      This function returns zero on success, or negative value with error
1421  *                      code.
1422  */
1423 int mm_player_set_media_stream_buffer_max_size(MMHandleType player, MMPlayerStreamType type, unsigned long long max_size);
1424
1425 /**
1426  * This function is to get max size of buffer(appsrc).
1427  *
1428  * @param       player          [in]    Handle of player.
1429  * @param       type            [in]    stream type
1430  * @param       max_size        [out]   max bytes of buffer.
1431  *
1432  * @return      This function returns zero on success, or negative value with error
1433  *                      code.
1434  */
1435 int mm_player_get_media_stream_buffer_max_size(MMHandleType player, MMPlayerStreamType type, unsigned long long *max_size);
1436
1437 /**
1438  * This function is to set min percent of buffer(appsrc).
1439  *
1440  * @param       player          [in]    Handle of player.
1441  * @param       type            [in]    stream type
1442  * @param       min_percent     [in]    min percent of buffer.
1443  *
1444  * @return      This function returns zero on success, or negative value with error
1445  *                      code.
1446  */
1447 int mm_player_set_media_stream_buffer_min_percent(MMHandleType player, MMPlayerStreamType type, unsigned min_percent);
1448
1449 /**
1450  * This function is to get min percent of buffer(appsrc).
1451  *
1452  * @param       player          [in]    Handle of player.
1453  * @param       type            [in]    stream type
1454  * @param       min_percent     [out]   min percent of buffer.
1455  *
1456  * @return      This function returns zero on success, or negative value with error
1457  *                      code.
1458  */
1459 int mm_player_get_media_stream_buffer_min_percent(MMHandleType player, MMPlayerStreamType type, unsigned int *min_percent);
1460
1461 /**
1462  * This function set callback function for changing audio stream from player. \n
1463  * It's only supported when audio stream is included in file. \n
1464  *
1465  * @param       player   [in] Handle of player.
1466  * @param       callback [in] Audio stream changed callback function.
1467  * @param       user_param [in] User parameter.
1468  *
1469  * @return      This function returns zero on success, or negative value with error
1470  *                      code.
1471  * @see         mm_player_stream_changed_callback
1472  * @since
1473  */
1474 int mm_player_set_audio_stream_changed_callback(MMHandleType player, mm_player_stream_changed_callback callback, void *user_param);
1475
1476 /**
1477  * This function set callback function for changing video stream from player. \n
1478  * It's only supported when video stream is included in file. \n
1479  *
1480  * @param       player   [in] Handle of player.
1481  * @param       callback [in] Video stream changed callback function.
1482  * @param       user_param [in] User parameter.
1483  *
1484  * @return      This function returns zero on success, or negative value with error
1485  *                      code.
1486  * @see         mm_player_stream_changed_callback
1487  */
1488 int mm_player_set_video_stream_changed_callback(MMHandleType player, mm_player_stream_changed_callback callback, void *user_param);
1489
1490 /**
1491  * This function is to get timeout value according to the content type for muse. \n
1492  * It's only supported when video stream is included in file. \n
1493  *
1494  * @param       player  [in] Handle of player.
1495  * @param       timeout [out] timeout value (sec).
1496  *
1497  * @return      This function returns zero on success, or negative value with error
1498  *                      code.
1499  * @since 3.0
1500  */
1501 int mm_player_get_timeout(MMHandleType player, int *timeout);
1502
1503 /**
1504  * This function is to get the number of video output buffers. \n
1505  * It's only supported when video stream is included in file. \n
1506  *
1507  * @param       player  [in] Handle of player.
1508  * @param       num     [out] num of buffers.
1509  * @param       extra_num [out] extra num of buffers.
1510  *
1511  * @return      This function returns zero on success, or negative value with error
1512  *                      code.
1513  * @since 3.0
1514  */
1515 int mm_player_get_num_of_video_out_buffers(MMHandleType player, int *num, int *extra_num);
1516
1517 /**
1518  * This function is to set the dynamic resolution information. \n
1519  * It's only supported when video stream is included in file. \n
1520  *
1521  * @param       player  [in] Handle of player.
1522  * @param       drc     [in] dynamic resolution info of media stream data
1523  *
1524  * @return      This function returns zero on success, or negative value with error
1525  *                      code.
1526  * @since 3.0
1527  */
1528 int mm_player_set_media_stream_dynamic_resolution(MMHandleType player, bool drc);
1529
1530 /**
1531  * This function is to release the video stream bo to reuse. \n
1532  * It's only supported when sw codec is used to decode video stream. \n
1533  *
1534  * @param       player  [in] Handle of player.
1535  * @param       bo     [in] bo address to be released
1536  *
1537  * @return      This function returns zero on success, or negative value with error
1538  *                      code.
1539  * @since 3.0
1540  */
1541 int mm_player_release_video_stream_bo(MMHandleType player, void* bo);
1542
1543 /**
1544  * This function is to set http file buffering path
1545  *
1546  * @param       player          [in]    handle of player
1547  * @param       file_path       [in]    file path
1548  * @return      This function returns zero on success, or negative value with error code.
1549  */
1550 int mm_player_set_file_buffering_path(MMHandleType player, const char *file_path);
1551
1552 /**
1553  * This function is to set sound stream info
1554  */
1555 int mm_player_set_sound_stream_info(MMHandleType player, char *stream_type, int stream_index);
1556
1557 /**
1558  * This function is to manage the playback according to the external storage state
1559  */
1560 int mm_player_manage_external_storage_state(MMHandleType player, int id, int state);
1561
1562 /**
1563  * These functions are to set/get the max variant of HAS
1564  */
1565 int mm_player_get_adaptive_variant_info(MMHandleType player, int *num, char **var_info);
1566 int mm_player_set_max_adaptive_variant_limit(MMHandleType player, int bandwidth, int width, int height);
1567 int mm_player_get_max_adaptive_variant_limit(MMHandleType player, int *bandwidth, int *width, int *height);
1568
1569 /**
1570  * These functions are to set/get the audio only mode
1571  */
1572 int mm_player_set_audio_only(MMHandleType player, bool audio_only);
1573 int mm_player_get_audio_only(MMHandleType player, bool *audio_only);
1574
1575 /**
1576  * These functions are to set/get the streaming bufferint time
1577  */
1578 int mm_player_set_streaming_buffering_time(MMHandleType player, int buffer_ms, int rebuffer_ms);
1579 int mm_player_get_streaming_buffering_time(MMHandleType player, int *buffer_ms, int *rebuffer_ms);
1580
1581 /**
1582  * These functions are to display the 360 video content
1583  */
1584 int mm_player_360_is_content_spherical(MMHandleType player, bool *is_spherical);
1585 int mm_player_360_set_enabled(MMHandleType player, bool enabled);
1586 int mm_player_360_is_enabled(MMHandleType player, bool *enabled);
1587
1588 int mm_player_360_set_direction_of_view(MMHandleType player, float yaw, float pitch);
1589 int mm_player_360_get_direction_of_view(MMHandleType player, float *yaw, float *pitch);
1590
1591 int mm_player_360_set_zoom(MMHandleType player, float level);
1592 int mm_player_360_get_zoom(MMHandleType player, float *level);
1593
1594 int mm_player_360_set_field_of_view(MMHandleType player, int horizontal_degrees, int vertical_degrees);
1595 int mm_player_360_get_field_of_view(MMHandleType player, int *horizontal_degrees, int *vertical_degrees);
1596
1597 /**
1598  * This function is to set codec type
1599  */
1600 int mm_player_set_codec_type(MMHandleType player, MMPlayerStreamType stream_type, MMPlayerVideoCodecType codec_type);
1601
1602 /**
1603  * These functions are to apply the replaygain
1604  */
1605 int mm_player_set_replaygain_enabled(MMHandleType player, bool enabled);
1606 int mm_player_is_replaygain_enabled(MMHandleType player, bool *enabled);
1607
1608 /**
1609  * This function is to set/get video content ROI area
1610  */
1611 int mm_player_set_video_roi_area(MMHandleType player, double scale_x, double scale_y, double scale_width, double scale_height);
1612 int mm_player_get_video_roi_area(MMHandleType player, double *scale_x, double *scale_y, double *scale_width, double *scale_height);
1613
1614 /**
1615         @}
1616  */
1617
1618 #ifdef __cplusplus
1619         }
1620 #endif
1621
1622 #endif  /* __MM_PLAYER_H__ */