16983e65eSMilanka Ringwald /* 26983e65eSMilanka Ringwald * Copyright (C) 2016 BlueKitchen GmbH 36983e65eSMilanka Ringwald * 46983e65eSMilanka Ringwald * Redistribution and use in source and binary forms, with or without 56983e65eSMilanka Ringwald * modification, are permitted provided that the following conditions 66983e65eSMilanka Ringwald * are met: 76983e65eSMilanka Ringwald * 86983e65eSMilanka Ringwald * 1. Redistributions of source code must retain the above copyright 96983e65eSMilanka Ringwald * notice, this list of conditions and the following disclaimer. 106983e65eSMilanka Ringwald * 2. Redistributions in binary form must reproduce the above copyright 116983e65eSMilanka Ringwald * notice, this list of conditions and the following disclaimer in the 126983e65eSMilanka Ringwald * documentation and/or other materials provided with the distribution. 136983e65eSMilanka Ringwald * 3. Neither the name of the copyright holders nor the names of 146983e65eSMilanka Ringwald * contributors may be used to endorse or promote products derived 156983e65eSMilanka Ringwald * from this software without specific prior written permission. 166983e65eSMilanka Ringwald * 4. Any redistribution, use, or modification is done solely for 176983e65eSMilanka Ringwald * personal benefit and not for any commercial purpose or for 186983e65eSMilanka Ringwald * monetary gain. 196983e65eSMilanka Ringwald * 206983e65eSMilanka Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 216983e65eSMilanka Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 226983e65eSMilanka Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 232fca4dadSMilanka Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN 242fca4dadSMilanka Ringwald * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 256983e65eSMilanka Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 266983e65eSMilanka Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 276983e65eSMilanka Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 286983e65eSMilanka Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 296983e65eSMilanka Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 306983e65eSMilanka Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 316983e65eSMilanka Ringwald * SUCH DAMAGE. 326983e65eSMilanka Ringwald * 336983e65eSMilanka Ringwald * Please inquire about commercial licensing options at 346983e65eSMilanka Ringwald * [email protected] 356983e65eSMilanka Ringwald * 366983e65eSMilanka Ringwald */ 376983e65eSMilanka Ringwald 38fe5a6c4eSMilanka Ringwald /** 39fe5a6c4eSMilanka Ringwald * @title AVRCP Controller 406983e65eSMilanka Ringwald * 416983e65eSMilanka Ringwald */ 426983e65eSMilanka Ringwald 4380e33422SMatthias Ringwald #ifndef AVRCP_CONTROLLER_H 4480e33422SMatthias Ringwald #define AVRCP_CONTROLLER_H 456983e65eSMilanka Ringwald 466983e65eSMilanka Ringwald #include <stdint.h> 476983e65eSMilanka Ringwald #include "btstack_run_loop.h" 486983e65eSMilanka Ringwald #include "btstack_linked_list.h" 493311c2d5SMatthias Ringwald #include "classic/avrcp.h" 506983e65eSMilanka Ringwald 516983e65eSMilanka Ringwald #if defined __cplusplus 526983e65eSMilanka Ringwald extern "C" { 536983e65eSMilanka Ringwald #endif 546983e65eSMilanka Ringwald 556983e65eSMilanka Ringwald /* API_START */ 5611014891SMilanka Ringwald 5711014891SMilanka Ringwald typedef enum { 5811014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_PLAYER_OR_RECORDER = 0, 5911014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_MONITOR_OR_AMPLIFIER, 6011014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_TUNER, 6111014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_CATEGORY_MENU, 6211014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_RESERVED_4, 6311014891SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_RESERVED_5, 64c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_BROWSING, 65c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_COVER_ART_GET_IMAGE_PROPERTIES, 66c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_COVER_ART_GET_IMAGE, 67c4a41e65SMilanka Ringwald AVRCP_CONTROLLER_SUPPORTED_FEATURE_COVER_ART_GET_LINKED_THUMBNAIL 6811014891SMilanka Ringwald } avrcp_controller_supported_feature_t; 6911014891SMilanka Ringwald 706983e65eSMilanka Ringwald /** 71f65a5459SMilanka Ringwald * @brief AVRCP Controller service record. 726983e65eSMilanka Ringwald * @param service 736983e65eSMilanka Ringwald * @param service_record_handle 74e2f25417SMilanka Ringwald * @param supported_features 16-bit bitmap, see AVRCP_FEATURE_MASK_* in avrcp.h 75141dff40SMatthias Ringwald * @param service_name or NULL for default value. Provide "" (empty string) to skip attribute 76141dff40SMatthias Ringwald * @param service_provider_name or NULL for default value. Provide "" (empty string) to skip attribute 776983e65eSMilanka Ringwald */ 784f0111ebSMilanka Ringwald void avrcp_controller_create_sdp_record(uint8_t * service, uint32_t service_record_handle, uint16_t supported_features, const char * service_name, const char * service_provider_name); 796983e65eSMilanka Ringwald 806983e65eSMilanka Ringwald /** 813734adacSMilanka Ringwald * @brief Set up AVRCP Controller service. 826983e65eSMilanka Ringwald */ 836983e65eSMilanka Ringwald void avrcp_controller_init(void); 846983e65eSMilanka Ringwald 856983e65eSMilanka Ringwald /** 86e30788a3SMilanka Ringwald * @brief Register callback for the AVRCP Controller client. 876983e65eSMilanka Ringwald * @param callback 886983e65eSMilanka Ringwald */ 896983e65eSMilanka Ringwald void avrcp_controller_register_packet_handler(btstack_packet_handler_t callback); 906983e65eSMilanka Ringwald 916983e65eSMilanka Ringwald /** 928b2b4034SMilanka Ringwald * @brief Set max num fragments in whuch message can be transmited. 938b2b4034SMilanka Ringwald * @param avrcp_cid 948b2b4034SMilanka Ringwald * @param max_num_fragments 956b65794dSMilanka Ringwald * @return status 968b2b4034SMilanka Ringwald */ 978b2b4034SMilanka Ringwald uint8_t avrcp_controller_set_max_num_fragments(uint16_t avrcp_cid, uint8_t max_num_fragments); 988b2b4034SMilanka Ringwald 998b2b4034SMilanka Ringwald 1008b2b4034SMilanka Ringwald /** 1016983e65eSMilanka Ringwald * @brief Unit info. 1026983e65eSMilanka Ringwald * @param avrcp_cid 1036b65794dSMilanka Ringwald * @return status 1046983e65eSMilanka Ringwald */ 1056983e65eSMilanka Ringwald uint8_t avrcp_controller_unit_info(uint16_t avrcp_cid); 1066983e65eSMilanka Ringwald 1076983e65eSMilanka Ringwald /** 108ad75da14SMilanka Ringwald * @brief Subunit info. 109ad75da14SMilanka Ringwald * @param avrcp_cid 1106b65794dSMilanka Ringwald * @return status 111ad75da14SMilanka Ringwald */ 112ad75da14SMilanka Ringwald uint8_t avrcp_controller_subunit_info(uint16_t avrcp_cid); 113ad75da14SMilanka Ringwald 114ad75da14SMilanka Ringwald /** 1156983e65eSMilanka Ringwald * @brief Get capabilities. 1166983e65eSMilanka Ringwald * @param avrcp_cid 1176b65794dSMilanka Ringwald * @return status 1186983e65eSMilanka Ringwald */ 1196983e65eSMilanka Ringwald uint8_t avrcp_controller_get_supported_company_ids(uint16_t avrcp_cid); 1206983e65eSMilanka Ringwald 1216983e65eSMilanka Ringwald /** 1226983e65eSMilanka Ringwald * @brief Get supported Events. 1236983e65eSMilanka Ringwald * @param avrcp_cid 1246b65794dSMilanka Ringwald * @return status 1256983e65eSMilanka Ringwald */ 1266983e65eSMilanka Ringwald uint8_t avrcp_controller_get_supported_events(uint16_t avrcp_cid); 1276983e65eSMilanka Ringwald 1288c79e168SMilanka Ringwald 12937a7ced0SMatthias Ringwald /** 13037a7ced0SMatthias Ringwald * @brief Start continuous cmd (play, pause, volume up, ...). Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 13137a7ced0SMatthias Ringwald * @param avrcp_cid 1326b65794dSMilanka Ringwald * @return status 13337a7ced0SMatthias Ringwald */ 13437a7ced0SMatthias Ringwald uint8_t avrcp_controller_start_press_and_hold_cmd(uint16_t avrcp_cid, avrcp_operation_id_t operation_id); 1358c79e168SMilanka Ringwald 1368c79e168SMilanka Ringwald /** 1378c79e168SMilanka Ringwald * @brief Stops continuous cmd (play, pause, volume up, ...). Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1388c79e168SMilanka Ringwald * @param avrcp_cid 1396b65794dSMilanka Ringwald * @return status 1408c79e168SMilanka Ringwald */ 1418c79e168SMilanka Ringwald uint8_t avrcp_controller_release_press_and_hold_cmd(uint16_t avrcp_cid); 1428c79e168SMilanka Ringwald 1436983e65eSMilanka Ringwald /** 1446983e65eSMilanka Ringwald * @brief Play. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1456983e65eSMilanka Ringwald * @param avrcp_cid 1466b65794dSMilanka Ringwald * @return status 1476983e65eSMilanka Ringwald */ 1486983e65eSMilanka Ringwald uint8_t avrcp_controller_play(uint16_t avrcp_cid); 1498c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_play(uint16_t avrcp_cid); 1506983e65eSMilanka Ringwald 1516983e65eSMilanka Ringwald /** 1526983e65eSMilanka Ringwald * @brief Stop. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1536983e65eSMilanka Ringwald * @param avrcp_cid 1546b65794dSMilanka Ringwald * @return status 1556983e65eSMilanka Ringwald */ 1566983e65eSMilanka Ringwald uint8_t avrcp_controller_stop(uint16_t avrcp_cid); 1578c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_stop(uint16_t avrcp_cid); 1586983e65eSMilanka Ringwald 1596983e65eSMilanka Ringwald /** 1606983e65eSMilanka Ringwald * @brief Pause. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1616983e65eSMilanka Ringwald * @param avrcp_cid 1626b65794dSMilanka Ringwald * @return status 1636983e65eSMilanka Ringwald */ 1646983e65eSMilanka Ringwald uint8_t avrcp_controller_pause(uint16_t avrcp_cid); 1658c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_pause(uint16_t avrcp_cid); 1666983e65eSMilanka Ringwald 1676983e65eSMilanka Ringwald /** 1686983e65eSMilanka Ringwald * @brief Single step - fast forward. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1696983e65eSMilanka Ringwald * @param avrcp_cid 1706b65794dSMilanka Ringwald * @return status 1716983e65eSMilanka Ringwald */ 1726983e65eSMilanka Ringwald uint8_t avrcp_controller_fast_forward(uint16_t avrcp_cid); 1738c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_fast_forward(uint16_t avrcp_cid); 1746983e65eSMilanka Ringwald 1756983e65eSMilanka Ringwald 1766983e65eSMilanka Ringwald /** 1776983e65eSMilanka Ringwald * @brief Single step rewind. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1786983e65eSMilanka Ringwald * @param avrcp_cid 1796b65794dSMilanka Ringwald * @return status 1806983e65eSMilanka Ringwald */ 1816983e65eSMilanka Ringwald uint8_t avrcp_controller_rewind(uint16_t avrcp_cid); 1828c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_rewind(uint16_t avrcp_cid); 1836983e65eSMilanka Ringwald 1846983e65eSMilanka Ringwald /** 1856983e65eSMilanka Ringwald * @brief Forward. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1866983e65eSMilanka Ringwald * @param avrcp_cid 1876b65794dSMilanka Ringwald * @return status 1886983e65eSMilanka Ringwald */ 1896983e65eSMilanka Ringwald uint8_t avrcp_controller_forward(uint16_t avrcp_cid); 1908c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_forward(uint16_t avrcp_cid); 1916983e65eSMilanka Ringwald 1926983e65eSMilanka Ringwald /** 1936983e65eSMilanka Ringwald * @brief Backward. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 1946983e65eSMilanka Ringwald * @param avrcp_cid 1956b65794dSMilanka Ringwald * @return status 1966983e65eSMilanka Ringwald */ 1976983e65eSMilanka Ringwald uint8_t avrcp_controller_backward(uint16_t avrcp_cid); 1988c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_backward(uint16_t avrcp_cid); 1996983e65eSMilanka Ringwald 2008c79e168SMilanka Ringwald /** 2018c79e168SMilanka Ringwald * @brief Turns the volume to high. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2028c79e168SMilanka Ringwald * @param avrcp_cid 2036b65794dSMilanka Ringwald * @return status 2048c79e168SMilanka Ringwald */ 2058c79e168SMilanka Ringwald uint8_t avrcp_controller_volume_up(uint16_t avrcp_cid); 2068c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_volume_up(uint16_t avrcp_cid); 2078c79e168SMilanka Ringwald /** 2088c79e168SMilanka Ringwald * @brief Turns the volume to low. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2098c79e168SMilanka Ringwald * @param avrcp_cid 2106b65794dSMilanka Ringwald * @return status 2118c79e168SMilanka Ringwald */ 2128c79e168SMilanka Ringwald uint8_t avrcp_controller_volume_down(uint16_t avrcp_cid); 2138c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_volume_down(uint16_t avrcp_cid); 2148c79e168SMilanka Ringwald 2158c79e168SMilanka Ringwald /** 2168c79e168SMilanka Ringwald * @brief Puts the sound out. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 2178c79e168SMilanka Ringwald * @param avrcp_cid 2186b65794dSMilanka Ringwald * @return status 2198c79e168SMilanka Ringwald */ 2208c79e168SMilanka Ringwald uint8_t avrcp_controller_mute(uint16_t avrcp_cid); 2218c79e168SMilanka Ringwald uint8_t avrcp_controller_press_and_hold_mute(uint16_t avrcp_cid); 2226983e65eSMilanka Ringwald 223f98d1041SMilanka Ringwald // Basic Group Navigation 224f98d1041SMilanka Ringwald /** 225f98d1041SMilanka Ringwald * @brief Move to the first song in the next group. 226f98d1041SMilanka Ringwald * @param avrcp_cid 227f98d1041SMilanka Ringwald */ 228f98d1041SMilanka Ringwald uint8_t avrcp_controller_next_group(uint16_t avrcp_cid); 229f98d1041SMilanka Ringwald 230f98d1041SMilanka Ringwald /** 231f98d1041SMilanka Ringwald * @brief Move to the first song in the previous group. 232f98d1041SMilanka Ringwald * @param avrcp_cid 233f98d1041SMilanka Ringwald */ 234f98d1041SMilanka Ringwald uint8_t avrcp_controller_previous_group(uint16_t avrcp_cid); 235f98d1041SMilanka Ringwald 23655849d48SMilanka Ringwald // Category 3 23755849d48SMilanka Ringwald uint8_t avrcp_controller_0(uint16_t avrcp_cid); 23855849d48SMilanka Ringwald uint8_t avrcp_controller_1(uint16_t avrcp_cid); 23955849d48SMilanka Ringwald uint8_t avrcp_controller_2(uint16_t avrcp_cid); 24055849d48SMilanka Ringwald uint8_t avrcp_controller_3(uint16_t avrcp_cid); 24155849d48SMilanka Ringwald uint8_t avrcp_controller_4(uint16_t avrcp_cid); 24255849d48SMilanka Ringwald uint8_t avrcp_controller_5(uint16_t avrcp_cid); 24355849d48SMilanka Ringwald uint8_t avrcp_controller_6(uint16_t avrcp_cid); 24455849d48SMilanka Ringwald uint8_t avrcp_controller_7(uint16_t avrcp_cid); 24555849d48SMilanka Ringwald uint8_t avrcp_controller_8(uint16_t avrcp_cid); 24655849d48SMilanka Ringwald uint8_t avrcp_controller_9(uint16_t avrcp_cid); 24755849d48SMilanka Ringwald uint8_t avrcp_controller_dot(uint16_t avrcp_cid); 24855849d48SMilanka Ringwald uint8_t avrcp_controller_enter(uint16_t avrcp_cid); 24955849d48SMilanka Ringwald uint8_t avrcp_controller_clear(uint16_t avrcp_cid); 25055849d48SMilanka Ringwald uint8_t avrcp_controller_channel_up(uint16_t avrcp_cid); 25155849d48SMilanka Ringwald uint8_t avrcp_controller_channel_down(uint16_t avrcp_cid); 25255849d48SMilanka Ringwald uint8_t avrcp_controller_previous_channel(uint16_t avrcp_cid); 25355849d48SMilanka Ringwald uint8_t avrcp_controller_sound_select(uint16_t avrcp_cid); 25455849d48SMilanka Ringwald uint8_t avrcp_controller_input_select(uint16_t avrcp_cid); 25555849d48SMilanka Ringwald uint8_t avrcp_controller_display_information(uint16_t avrcp_cid); 25655849d48SMilanka Ringwald uint8_t avrcp_controller_help(uint16_t avrcp_cid); 25755849d48SMilanka Ringwald uint8_t avrcp_controller_power(uint16_t avrcp_cid); 25855849d48SMilanka Ringwald uint8_t avrcp_controller_angle(uint16_t avrcp_cid); 25955849d48SMilanka Ringwald uint8_t avrcp_controller_subpicture(uint16_t avrcp_cid); 26055849d48SMilanka Ringwald uint8_t avrcp_controller_F1(uint16_t avrcp_cid); 26155849d48SMilanka Ringwald uint8_t avrcp_controller_F2(uint16_t avrcp_cid); 26255849d48SMilanka Ringwald uint8_t avrcp_controller_F3(uint16_t avrcp_cid); 26355849d48SMilanka Ringwald uint8_t avrcp_controller_F4(uint16_t avrcp_cid); 26455849d48SMilanka Ringwald uint8_t avrcp_controller_F5(uint16_t avrcp_cid); 265f98d1041SMilanka Ringwald 266093e4ee8SMilanka Ringwald // Category 4 267093e4ee8SMilanka Ringwald uint8_t avrcp_controller_select(uint16_t avrcp_cid); 268093e4ee8SMilanka Ringwald uint8_t avrcp_controller_up(uint16_t avrcp_cid); 269093e4ee8SMilanka Ringwald uint8_t avrcp_controller_down(uint16_t avrcp_cid); 270093e4ee8SMilanka Ringwald uint8_t avrcp_controller_left(uint16_t avrcp_cid); 271093e4ee8SMilanka Ringwald uint8_t avrcp_controller_right(uint16_t avrcp_cid); 272093e4ee8SMilanka Ringwald uint8_t avrcp_controller_right_up(uint16_t avrcp_cid); 273093e4ee8SMilanka Ringwald uint8_t avrcp_controller_right_down(uint16_t avrcp_cid); 274093e4ee8SMilanka Ringwald uint8_t avrcp_controller_left_up(uint16_t avrcp_cid); 275093e4ee8SMilanka Ringwald uint8_t avrcp_controller_left_down(uint16_t avrcp_cid); 276093e4ee8SMilanka Ringwald uint8_t avrcp_controller_root_menu(uint16_t avrcp_cid); 277093e4ee8SMilanka Ringwald uint8_t avrcp_controller_setup_menu(uint16_t avrcp_cid); 278093e4ee8SMilanka Ringwald uint8_t avrcp_controller_contents_menu(uint16_t avrcp_cid); 279093e4ee8SMilanka Ringwald uint8_t avrcp_controller_favorite_menu(uint16_t avrcp_cid); 280093e4ee8SMilanka Ringwald uint8_t avrcp_controller_exit(uint16_t avrcp_cid); 281093e4ee8SMilanka Ringwald uint8_t avrcp_controller_page_up(uint16_t avrcp_cid); 282093e4ee8SMilanka Ringwald uint8_t avrcp_controller_page_down(uint16_t avrcp_cid); 2836983e65eSMilanka Ringwald /** 2846983e65eSMilanka Ringwald * @brief Get play status. Returns event of type AVRCP_SUBEVENT_PLAY_STATUS (length, position, play_status). 2856983e65eSMilanka Ringwald * If TG does not support SongLength And SongPosition on TG, then TG shall return 0xFFFFFFFF. 2866983e65eSMilanka Ringwald * @param avrcp_cid 2876b65794dSMilanka Ringwald * @return status 2886983e65eSMilanka Ringwald */ 2896983e65eSMilanka Ringwald uint8_t avrcp_controller_get_play_status(uint16_t avrcp_cid); 2906983e65eSMilanka Ringwald 2916983e65eSMilanka Ringwald /** 292b2e02b8dSMilanka Ringwald * @brief Enable notification. Response via AVRCP_SUBEVENT_NOTIFICATION_STATE. 2936983e65eSMilanka Ringwald * @param avrcp_cid 2946983e65eSMilanka Ringwald * @param event_id 2956b65794dSMilanka Ringwald * @return status 2966983e65eSMilanka Ringwald */ 2976983e65eSMilanka Ringwald uint8_t avrcp_controller_enable_notification(uint16_t avrcp_cid, avrcp_notification_event_id_t event_id); 2986983e65eSMilanka Ringwald 2996983e65eSMilanka Ringwald /** 300b2e02b8dSMilanka Ringwald * @brief Disable notification. Response via AVRCP_SUBEVENT_NOTIFICATION_STATE. 3016983e65eSMilanka Ringwald * @param avrcp_cid 3026983e65eSMilanka Ringwald * @param event_id 3036b65794dSMilanka Ringwald * @return status 3046983e65eSMilanka Ringwald */ 3056983e65eSMilanka Ringwald uint8_t avrcp_controller_disable_notification(uint16_t avrcp_cid, avrcp_notification_event_id_t event_id); 3066983e65eSMilanka Ringwald 3076983e65eSMilanka Ringwald /** 30861920526SMilanka Ringwald * @brief Get info on now playing media using subset of attribute IDs 30961920526SMilanka Ringwald * @param avrcp_cid 3106b65794dSMilanka Ringwald * @return status 31161920526SMilanka Ringwald */ 31261920526SMilanka Ringwald uint8_t avrcp_controller_get_element_attributes(uint16_t avrcp_cid, uint8_t num_attributes, avrcp_media_attribute_id_t * attributes); 31361920526SMilanka Ringwald 31461920526SMilanka Ringwald /** 31561920526SMilanka Ringwald * @brief Get info on now playing media using all IDs. 3166983e65eSMilanka Ringwald * @param avrcp_cid 3176b65794dSMilanka Ringwald * @return status 3186983e65eSMilanka Ringwald */ 3196983e65eSMilanka Ringwald uint8_t avrcp_controller_get_now_playing_info(uint16_t avrcp_cid); 3206983e65eSMilanka Ringwald 3216983e65eSMilanka Ringwald /** 32266e22952SMilanka Ringwald * @brief Get info on now playing media using specific media attribute ID. 32366e22952SMilanka Ringwald * @param media_attribute_id 32466e22952SMilanka Ringwald * @param avrcp_cid 32566e22952SMilanka Ringwald * @return status 32666e22952SMilanka Ringwald */ 32766e22952SMilanka Ringwald uint8_t avrcp_controller_get_now_playing_info_for_media_attribute_id(uint16_t avrcp_cid, avrcp_media_attribute_id_t media_attribute_id); 32866e22952SMilanka Ringwald 32966e22952SMilanka Ringwald /** 3306983e65eSMilanka Ringwald * @brief Set absolute volume 0-127 (corresponds to 0-100%). Response via AVRCP_SUBEVENT_SET_ABSOLUTE_VOLUME_RESPONSE 3316983e65eSMilanka Ringwald * @param avrcp_cid 3326b65794dSMilanka Ringwald * @return status 3336983e65eSMilanka Ringwald */ 3346983e65eSMilanka Ringwald uint8_t avrcp_controller_set_absolute_volume(uint16_t avrcp_cid, uint8_t volume); 3356983e65eSMilanka Ringwald 3366983e65eSMilanka Ringwald 3376983e65eSMilanka Ringwald /** 3386983e65eSMilanka Ringwald * @brief Skip to next playing media. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 3396983e65eSMilanka Ringwald * @param avrcp_cid 3406b65794dSMilanka Ringwald * @return status 3416983e65eSMilanka Ringwald */ 3426983e65eSMilanka Ringwald uint8_t avrcp_controller_skip(uint16_t avrcp_cid); 3436983e65eSMilanka Ringwald 344*a7d2a6bfSMilanka Ringwald uint8_t avrcp_controller_query_player_application_setting_attributes(uint16_t avrcp_cid); 345*a7d2a6bfSMilanka Ringwald uint8_t avrcp_controller_query_player_application_setting_values(uint16_t avrcp_cid, avrcp_player_application_setting_attribute_id_t attribute_id); 346*a7d2a6bfSMilanka Ringwald 347*a7d2a6bfSMilanka Ringwald uint8_t avrcp_controller_query_player_application_setting_attribute_text(uint16_t avrcp_cid); 348*a7d2a6bfSMilanka Ringwald uint8_t avrcp_controller_query_player_application_setting_value_text(uint16_t avrcp_cid); 349*a7d2a6bfSMilanka Ringwald 350*a7d2a6bfSMilanka Ringwald uint8_t avrcp_controller_inform_displayable_characterset(uint16_t avrcp_cid, uint8_t character_set_num, uint16_t * character_set); 351*a7d2a6bfSMilanka Ringwald uint8_t avrcp_controller_inform_battery_status(uint16_t avrcp_cid, avrcp_battery_status_t battery_status); 352*a7d2a6bfSMilanka Ringwald 3536983e65eSMilanka Ringwald /** 3546983e65eSMilanka Ringwald * @brief Query repeat and shuffle mode. Response via AVRCP_SUBEVENT_SHUFFLE_AND_REPEAT_MODE. 3556983e65eSMilanka Ringwald * @param avrcp_cid 3566b65794dSMilanka Ringwald * @return status 3576983e65eSMilanka Ringwald */ 3586983e65eSMilanka Ringwald uint8_t avrcp_controller_query_shuffle_and_repeat_modes(uint16_t avrcp_cid); 3596983e65eSMilanka Ringwald 3606983e65eSMilanka Ringwald /** 3616983e65eSMilanka Ringwald * @brief Set shuffle mode. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 3626983e65eSMilanka Ringwald * @param avrcp_cid 3636b65794dSMilanka Ringwald * @return status 3646983e65eSMilanka Ringwald */ 3656983e65eSMilanka Ringwald uint8_t avrcp_controller_set_shuffle_mode(uint16_t avrcp_cid, avrcp_shuffle_mode_t mode); 3666983e65eSMilanka Ringwald 3676983e65eSMilanka Ringwald /** 3686983e65eSMilanka Ringwald * @brief Set repeat mode. Event AVRCP_SUBEVENT_OPERATION_COMPLETE returns operation id and status. 3696983e65eSMilanka Ringwald * @param avrcp_cid 3706b65794dSMilanka Ringwald * @return status 3716983e65eSMilanka Ringwald */ 3726983e65eSMilanka Ringwald uint8_t avrcp_controller_set_repeat_mode(uint16_t avrcp_cid, avrcp_repeat_mode_t mode); 373be65baf4SMilanka Ringwald 374be65baf4SMilanka Ringwald /** 375be65baf4SMilanka Ringwald * @brief The PlayItem command starts playing an item indicated by the UID. It is routed to the Addressed Player. 376be65baf4SMilanka Ringwald * @param avrcp_cid 377be65baf4SMilanka Ringwald * @param uid 378be65baf4SMilanka Ringwald * @param uid_counter 3794614c049SMilanka Ringwald * @param scope 380be65baf4SMilanka Ringwald **/ 3814614c049SMilanka Ringwald uint8_t avrcp_controller_play_item_for_scope(uint16_t avrcp_cid, uint8_t * uid, uint16_t uid_counter, avrcp_browsing_scope_t scope); 382864d08b0SMilanka Ringwald 383864d08b0SMilanka Ringwald /** 3844931e24aSMilanka Ringwald * @brief Adds an item indicated by the UID to the Now Playing queue. 3854931e24aSMilanka Ringwald * @param avrcp_cid 3864931e24aSMilanka Ringwald * @param uid 3874931e24aSMilanka Ringwald * @param uid_counter 3884931e24aSMilanka Ringwald * @param scope 3894931e24aSMilanka Ringwald **/ 3904931e24aSMilanka Ringwald uint8_t avrcp_controller_add_item_from_scope_to_now_playing_list(uint16_t avrcp_cid, uint8_t * uid, uint16_t uid_counter, avrcp_browsing_scope_t scope); 3914931e24aSMilanka Ringwald 3924931e24aSMilanka Ringwald /** 393864d08b0SMilanka Ringwald * @brief Set addressed player. 394864d08b0SMilanka Ringwald * @param avrcp_cid 395864d08b0SMilanka Ringwald * @param addressed_player_id 396864d08b0SMilanka Ringwald */ 397864d08b0SMilanka Ringwald uint8_t avrcp_controller_set_addressed_player(uint16_t avrcp_cid, uint16_t addressed_player_id); 398864d08b0SMilanka Ringwald 399c4b5c3d5SMatthias Ringwald /** 400c4b5c3d5SMatthias Ringwald * @brief Send custom command 401c4b5c3d5SMatthias Ringwald * @param avrcp_cid 402c4b5c3d5SMatthias Ringwald * @param command_type 403c4b5c3d5SMatthias Ringwald * @param subunit_type 4045d3671d9SMilanka Ringwald * @param subunit_id 4055d3671d9SMilanka Ringwald * @param pdu_id 4065d3671d9SMilanka Ringwald * @param company_id 4075d3671d9SMilanka Ringwald * @param data 4085d3671d9SMilanka Ringwald * @param data_len 409c4b5c3d5SMatthias Ringwald */ 4105d3671d9SMilanka Ringwald uint8_t avrcp_controller_send_custom_command(uint16_t avrcp_cid, 4115d3671d9SMilanka Ringwald avrcp_command_type_t command_type, 4125d3671d9SMilanka Ringwald avrcp_subunit_type_t subunit_type, avrcp_subunit_id_t subunit_id, 4135d3671d9SMilanka Ringwald avrcp_pdu_id_t pdu_id, uint32_t company_id, 4145d3671d9SMilanka Ringwald const uint8_t * data, uint16_t data_len); 415c4b5c3d5SMatthias Ringwald 416680af5dcSMatthias Ringwald /** 417680af5dcSMatthias Ringwald * @brief De-Init AVRCP Controller 418680af5dcSMatthias Ringwald */ 419680af5dcSMatthias Ringwald void avrcp_controller_deinit(void); 420680af5dcSMatthias Ringwald 421680af5dcSMatthias Ringwald /* API_END */ 422680af5dcSMatthias Ringwald 42339b456a8SMatthias Ringwald // send press command if connection is open. use with great care and only if there's no other option 42439b456a8SMatthias Ringwald uint8_t avrcp_controller_force_send_press_cmd(uint16_t avrcp_cid, avrcp_operation_id_t operation_id); 42539b456a8SMatthias Ringwald 4264adb0765SMatthias Ringwald // Used by AVRCP controller and AVRCP browsing controller 4274adb0765SMatthias Ringwald extern avrcp_context_t avrcp_controller_context; 428247956eaSMilanka Ringwald 4296983e65eSMilanka Ringwald #if defined __cplusplus 4306983e65eSMilanka Ringwald } 4316983e65eSMilanka Ringwald #endif 4326983e65eSMilanka Ringwald 43380e33422SMatthias Ringwald #endif // AVRCP_CONTROLLER_H 434