1 /* 2 * Copyright (C) 2010-2014 The Android Open Source Project 3 * 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 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 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. 15 */ 16 17 18 package android.bluetooth; 19 20 import android.Manifest; 21 import android.annotation.RequiresPermission; 22 23 import java.util.List; 24 25 /** 26 * Public APIs for the Bluetooth Profiles. 27 * 28 * <p> Clients should call {@link BluetoothAdapter#getProfileProxy}, 29 * to get the Profile Proxy. Each public profile implements this 30 * interface. 31 */ 32 public interface BluetoothProfile { 33 34 /** 35 * Extra for the connection state intents of the individual profiles. 36 * 37 * This extra represents the current connection state of the profile of the 38 * Bluetooth device. 39 */ 40 public static final String EXTRA_STATE = "android.bluetooth.profile.extra.STATE"; 41 42 /** 43 * Extra for the connection state intents of the individual profiles. 44 * 45 * This extra represents the previous connection state of the profile of the 46 * Bluetooth device. 47 */ 48 public static final String EXTRA_PREVIOUS_STATE = 49 "android.bluetooth.profile.extra.PREVIOUS_STATE"; 50 51 /** The profile is in disconnected state */ 52 public static final int STATE_DISCONNECTED = 0; 53 /** The profile is in connecting state */ 54 public static final int STATE_CONNECTING = 1; 55 /** The profile is in connected state */ 56 public static final int STATE_CONNECTED = 2; 57 /** The profile is in disconnecting state */ 58 public static final int STATE_DISCONNECTING = 3; 59 60 /** 61 * Headset and Handsfree profile 62 */ 63 public static final int HEADSET = 1; 64 65 /** 66 * A2DP profile. 67 */ 68 public static final int A2DP = 2; 69 70 /** 71 * Health Profile 72 */ 73 public static final int HEALTH = 3; 74 75 /** 76 * Input Device Profile 77 * @hide 78 */ 79 public static final int INPUT_DEVICE = 4; 80 81 /** 82 * PAN Profile 83 * @hide 84 */ 85 public static final int PAN = 5; 86 87 /** 88 * PBAP 89 * @hide 90 */ 91 public static final int PBAP = 6; 92 93 /** 94 * GATT 95 */ 96 static public final int GATT = 7; 97 98 /** 99 * GATT_SERVER 100 */ 101 static public final int GATT_SERVER = 8; 102 103 /** 104 * MAP Profile 105 * @hide 106 */ 107 public static final int MAP = 9; 108 109 /* 110 * SAP Profile 111 * @hide 112 */ 113 public static final int SAP = 10; 114 115 /** 116 * A2DP Sink Profile 117 * @hide 118 */ 119 public static final int A2DP_SINK = 11; 120 121 /** 122 * AVRCP Controller Profile 123 * @hide 124 */ 125 public static final int AVRCP_CONTROLLER = 12; 126 127 /** 128 * Headset Client - HFP HF Role 129 * @hide 130 */ 131 public static final int HEADSET_CLIENT = 16; 132 133 /** 134 * PBAP Client 135 * @hide 136 */ 137 public static final int PBAP_CLIENT = 17; 138 139 /** 140 * Max profile ID. This value should be updated whenever a new profile is added to match 141 * the largest value assigned to a profile. 142 * @hide 143 */ 144 public static final int MAX_PROFILE_ID = 17; 145 146 /** 147 * Default priority for devices that we try to auto-connect to and 148 * and allow incoming connections for the profile 149 * @hide 150 **/ 151 public static final int PRIORITY_AUTO_CONNECT = 1000; 152 153 /** 154 * Default priority for devices that allow incoming 155 * and outgoing connections for the profile 156 * @hide 157 **/ 158 public static final int PRIORITY_ON = 100; 159 160 /** 161 * Default priority for devices that does not allow incoming 162 * connections and outgoing connections for the profile. 163 * @hide 164 **/ 165 public static final int PRIORITY_OFF = 0; 166 167 /** 168 * Default priority when not set or when the device is unpaired 169 * @hide 170 * */ 171 public static final int PRIORITY_UNDEFINED = -1; 172 173 /** 174 * Get connected devices for this specific profile. 175 * 176 * <p> Return the set of devices which are in state {@link #STATE_CONNECTED} 177 * 178 * <p>Requires {@link android.Manifest.permission#BLUETOOTH} permission. 179 * 180 * @return List of devices. The list will be empty on error. 181 */ 182 @RequiresPermission(Manifest.permission.BLUETOOTH) getConnectedDevices()183 public List<BluetoothDevice> getConnectedDevices(); 184 185 /** 186 * Get a list of devices that match any of the given connection 187 * states. 188 * 189 * <p> If none of the devices match any of the given states, 190 * an empty list will be returned. 191 * 192 * <p>Requires {@link android.Manifest.permission#BLUETOOTH} permission. 193 * 194 * @param states Array of states. States can be one of 195 * {@link #STATE_CONNECTED}, {@link #STATE_CONNECTING}, 196 * {@link #STATE_DISCONNECTED}, {@link #STATE_DISCONNECTING}, 197 * @return List of devices. The list will be empty on error. 198 */ 199 @RequiresPermission(Manifest.permission.BLUETOOTH) getDevicesMatchingConnectionStates(int[] states)200 public List<BluetoothDevice> getDevicesMatchingConnectionStates(int[] states); 201 202 /** 203 * Get the current connection state of the profile 204 * 205 * <p>Requires {@link android.Manifest.permission#BLUETOOTH} permission. 206 * 207 * @param device Remote bluetooth device. 208 * @return State of the profile connection. One of 209 * {@link #STATE_CONNECTED}, {@link #STATE_CONNECTING}, 210 * {@link #STATE_DISCONNECTED}, {@link #STATE_DISCONNECTING} 211 */ 212 @RequiresPermission(Manifest.permission.BLUETOOTH) getConnectionState(BluetoothDevice device)213 public int getConnectionState(BluetoothDevice device); 214 215 /** 216 * An interface for notifying BluetoothProfile IPC clients when they have 217 * been connected or disconnected to the service. 218 */ 219 public interface ServiceListener { 220 /** 221 * Called to notify the client when the proxy object has been 222 * connected to the service. 223 * @param profile - One of {@link #HEALTH}, {@link #HEADSET} or 224 * {@link #A2DP} 225 * @param proxy - One of {@link BluetoothHealth}, {@link BluetoothHeadset} or 226 * {@link BluetoothA2dp} 227 */ onServiceConnected(int profile, BluetoothProfile proxy)228 public void onServiceConnected(int profile, BluetoothProfile proxy); 229 230 /** 231 * Called to notify the client that this proxy object has been 232 * disconnected from the service. 233 * @param profile - One of {@link #HEALTH}, {@link #HEADSET} or 234 * {@link #A2DP} 235 */ onServiceDisconnected(int profile)236 public void onServiceDisconnected(int profile); 237 } 238 } 239