AppRTCBluetoothManager.smali
.class public Lorg/webrtc/audio/AppRTCBluetoothManager;
.super Ljava/lang/Object;
.source "AppRTCBluetoothManager.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothHeadsetBroadcastReceiver;,
Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothServiceListener;,
Lorg/webrtc/audio/AppRTCBluetoothManager$State;
}
.end annotation
# static fields
.field private static final BLUETOOTH_SCO_TIMEOUT_MS:I
.field private static final MAX_SCO_CONNECTION_ATTEMPTS:I
.field private static final TAG:Ljava/lang/String; = "AppRTCBluetoothManager"
# instance fields
.field private final apprtcAudioManager:Lorg/webrtc/audio/AppRTCAudioManager;
.field private final apprtcContext:Landroid/content/Context;
.field private final audioManager:Landroid/media/AudioManager;
.field private bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
.field private bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.field private bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
.field private final bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;
.field private final bluetoothServiceListener:Landroid/bluetooth/BluetoothProfile$ServiceListener;
.field private bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.field private final bluetoothTimeoutRunnable:Ljava/lang/Runnable;
.field private mHandler:Landroid/os/Handler;
.field scoConnectionAttempts:I
# direct methods
.method static constructor <clinit>()V
.registers 1
const v0, 0x1acf
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lorg/webrtc/audio/AppRTCBluetoothManager;->BLUETOOTH_SCO_TIMEOUT_MS:I
const v0, 0x156d
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lorg/webrtc/audio/AppRTCBluetoothManager;->MAX_SCO_CONNECTION_ATTEMPTS:I
return-void
.end method
.method protected constructor <init>(Landroid/content/Context;Lorg/webrtc/audio/AppRTCAudioManager;)V
.registers 5
.param p1, "context" # Landroid/content/Context;
.param p2, "audioManager" # Lorg/webrtc/audio/AppRTCAudioManager;
.line 205
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 46
new-instance v0, Landroid/os/Handler;
invoke-direct {v0}, Landroid/os/Handler;-><init>()V
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->mHandler:Landroid/os/Handler;
.line 83
new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager$1;
invoke-direct {v0, p0}, Lorg/webrtc/audio/AppRTCBluetoothManager$1;-><init>(Lorg/webrtc/audio/AppRTCBluetoothManager;)V
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeoutRunnable:Ljava/lang/Runnable;
.line 206
const-string v0, "AppRTCBluetoothManager"
const-string v1, "ctor"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 207
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 208
iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;
.line 209
iput-object p2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcAudioManager:Lorg/webrtc/audio/AppRTCAudioManager;
.line 210
invoke-virtual {p0, p1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->getAudioManager(Landroid/content/Context;)Landroid/media/AudioManager;
move-result-object v0
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;
.line 211
sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 212
new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothServiceListener;
const/4 v1, 0x0
invoke-direct {v0, p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothServiceListener;-><init>(Lorg/webrtc/audio/AppRTCBluetoothManager;Lorg/webrtc/audio/AppRTCBluetoothManager$1;)V
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothServiceListener:Landroid/bluetooth/BluetoothProfile$ServiceListener;
.line 213
new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothHeadsetBroadcastReceiver;
invoke-direct {v0, p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager$BluetoothHeadsetBroadcastReceiver;-><init>(Lorg/webrtc/audio/AppRTCBluetoothManager;Lorg/webrtc/audio/AppRTCBluetoothManager$1;)V
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;
.line 214
return-void
.end method
.method static synthetic access$000(Lorg/webrtc/audio/AppRTCBluetoothManager;)V
.registers 1
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.line 38
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeout()V
return-void
.end method
.method static synthetic access$100(Lorg/webrtc/audio/AppRTCBluetoothManager;)Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.registers 2
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.line 38
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
return-object v0
.end method
.method static synthetic access$102(Lorg/webrtc/audio/AppRTCBluetoothManager;Lorg/webrtc/audio/AppRTCBluetoothManager$State;)Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.registers 2
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.param p1, "x1" # Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 38
iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
return-object p1
.end method
.method static synthetic access$202(Lorg/webrtc/audio/AppRTCBluetoothManager;Landroid/bluetooth/BluetoothHeadset;)Landroid/bluetooth/BluetoothHeadset;
.registers 2
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.param p1, "x1" # Landroid/bluetooth/BluetoothHeadset;
.line 38
iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
return-object p1
.end method
.method static synthetic access$300(Lorg/webrtc/audio/AppRTCBluetoothManager;)V
.registers 1
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.line 38
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->updateAudioDeviceState()V
return-void
.end method
.method static synthetic access$402(Lorg/webrtc/audio/AppRTCBluetoothManager;Landroid/bluetooth/BluetoothDevice;)Landroid/bluetooth/BluetoothDevice;
.registers 2
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.param p1, "x1" # Landroid/bluetooth/BluetoothDevice;
.line 38
iput-object p1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
return-object p1
.end method
.method static synthetic access$500(Lorg/webrtc/audio/AppRTCBluetoothManager;I)Ljava/lang/String;
.registers 3
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.param p1, "x1" # I
.line 38
invoke-direct {p0, p1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method static synthetic access$600(Lorg/webrtc/audio/AppRTCBluetoothManager;)Landroid/os/Handler;
.registers 2
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.line 38
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->mHandler:Landroid/os/Handler;
return-object v0
.end method
.method static synthetic access$700(Lorg/webrtc/audio/AppRTCBluetoothManager;)V
.registers 1
.param p0, "x0" # Lorg/webrtc/audio/AppRTCBluetoothManager;
.line 38
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->cancelTimer()V
return-void
.end method
.method private bluetoothTimeout()V
.registers 7
.line 471
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 472
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v1, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v0, v1, :cond_c3
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
if-nez v0, :cond_f
goto/16 :goto_c3
.line 475
:cond_f
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "bluetoothTimeout: BT state="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v1, ", attempts: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, ", SCO is on: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 477
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 475
const-string v1, "AppRTCBluetoothManager"
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 478
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v0, v2, :cond_44
.line 479
return-void
.line 482
:cond_44
const/4 v0, 0x0
.line 483
.local v0, "scoConnected":Z
iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
invoke-virtual {v2}, Landroid/bluetooth/BluetoothHeadset;->getConnectedDevices()Ljava/util/List;
move-result-object v2
.line 484
.local v2, "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v3
const/4 v4, 0x0
if-lez v3, :cond_98
.line 485
invoke-interface {v2, v4}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Landroid/bluetooth/BluetoothDevice;
iput-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 486
iget-object v5, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
invoke-virtual {v5, v3}, Landroid/bluetooth/BluetoothHeadset;->isAudioConnected(Landroid/bluetooth/BluetoothDevice;)Z
move-result v3
if-eqz v3, :cond_7e
.line 487
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "SCO connected with "
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
invoke-virtual {v5}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;
move-result-object v5
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v1, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 488
const/4 v0, 0x1
goto :goto_98
.line 490
:cond_7e
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "SCO is not connected with "
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
invoke-virtual {v5}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;
move-result-object v5
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v1, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 493
:cond_98
:goto_98
if-eqz v0, :cond_a1
.line 495
sget-object v3, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 496
iput v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I
goto :goto_a9
.line 499
:cond_a1
const-string v3, "BT failed to connect after timeout"
invoke-static {v1, v3}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 500
invoke-virtual {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stopScoAudio()V
.line 502
:goto_a9
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->updateAudioDeviceState()V
.line 503
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "bluetoothTimeout done: BT state="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v1, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 504
return-void
.line 473
.end local v0 # "scoConnected":Z
.end local v2 # "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
:cond_c3
:goto_c3
return-void
.end method
.method private cancelTimer()V
.registers 3
.line 461
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 462
const-string v0, "AppRTCBluetoothManager"
const-string v1, "cancelTimer"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 463
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeoutRunnable:Ljava/lang/Runnable;
invoke-static {v0}, Lorg/webrtc/ali/ThreadUtils;->runOnUiThread(Ljava/lang/Runnable;)V
.line 464
return-void
.end method
.method static create(Landroid/content/Context;Lorg/webrtc/audio/AppRTCAudioManager;)Lorg/webrtc/audio/AppRTCBluetoothManager;
.registers 4
.param p0, "context" # Landroid/content/Context;
.param p1, "audioManager" # Lorg/webrtc/audio/AppRTCAudioManager;
.line 201
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "create"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Lorg/webrtc/utils/AppRTCUtils;->getThreadInfo()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "AppRTCBluetoothManager"
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 202
new-instance v0, Lorg/webrtc/audio/AppRTCBluetoothManager;
invoke-direct {v0, p0, p1}, Lorg/webrtc/audio/AppRTCBluetoothManager;-><init>(Landroid/content/Context;Lorg/webrtc/audio/AppRTCAudioManager;)V
return-object v0
.end method
.method private isScoOn()Z
.registers 2
.line 508
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;
invoke-virtual {v0}, Landroid/media/AudioManager;->isBluetoothScoOn()Z
move-result v0
return v0
.end method
.method private startTimer()V
.registers 4
.line 454
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 455
const-string v0, "AppRTCBluetoothManager"
const-string v1, "startTimer"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 456
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothTimeoutRunnable:Ljava/lang/Runnable;
const-wide/16 v1, 0xfa0
invoke-static {v0, v1, v2}, Lorg/webrtc/ali/ThreadUtils;->postOnUiThread(Ljava/lang/Runnable;J)V
.line 457
return-void
.end method
.method private stateToString(I)Ljava/lang/String;
.registers 3
.param p1, "state" # I
.line 513
if-eqz p1, :cond_26
const/4 v0, 0x1
if-eq p1, v0, :cond_23
const/4 v0, 0x2
if-eq p1, v0, :cond_20
const/4 v0, 0x3
if-eq p1, v0, :cond_1d
packed-switch p1, :pswitch_data_2a
.line 535
const-string v0, "INVALID"
return-object v0
.line 529
:pswitch_11
const-string v0, "TURNING_OFF"
return-object v0
.line 525
:pswitch_14
const-string v0, "ON"
return-object v0
.line 533
:pswitch_17
const-string v0, "TURNING_ON"
return-object v0
.line 523
:pswitch_1a
const-string v0, "OFF"
return-object v0
.line 521
:cond_1d
const-string v0, "DISCONNECTING"
return-object v0
.line 517
:cond_20
const-string v0, "CONNECTED"
return-object v0
.line 519
:cond_23
const-string v0, "CONNECTING"
return-object v0
.line 515
:cond_26
const-string v0, "DISCONNECTED"
return-object v0
nop
:pswitch_data_2a
.packed-switch 0xa
:pswitch_1a
:pswitch_17
:pswitch_14
:pswitch_11
.end packed-switch
.end method
.method private updateAudioDeviceState()V
.registers 3
.line 447
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 448
const-string v0, "AppRTCBluetoothManager"
const-string v1, "updateAudioDeviceState"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 449
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcAudioManager:Lorg/webrtc/audio/AppRTCAudioManager;
invoke-virtual {v0}, Lorg/webrtc/audio/AppRTCAudioManager;->updateAudioDeviceState()V
.line 450
return-void
.end method
# virtual methods
.method protected getAudioManager(Landroid/content/Context;)Landroid/media/AudioManager;
.registers 3
.param p1, "context" # Landroid/content/Context;
.line 398
const-string v0, "audio"
invoke-virtual {p1, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Landroid/media/AudioManager;
return-object v0
.end method
.method protected getBluetoothProfileProxy(Landroid/content/Context;Landroid/bluetooth/BluetoothProfile$ServiceListener;I)Z
.registers 5
.param p1, "context" # Landroid/content/Context;
.param p2, "listener" # Landroid/bluetooth/BluetoothProfile$ServiceListener;
.param p3, "profile" # I
.line 419
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
invoke-virtual {v0, p1, p2, p3}, Landroid/bluetooth/BluetoothAdapter;->getProfileProxy(Landroid/content/Context;Landroid/bluetooth/BluetoothProfile$ServiceListener;I)Z
move-result v0
return v0
.end method
.method public getState()Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.registers 2
.line 218
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 219
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
return-object v0
.end method
.method protected hasPermission(Landroid/content/Context;Ljava/lang/String;)Z
.registers 6
.param p1, "context" # Landroid/content/Context;
.param p2, "permission" # Ljava/lang/String;
.line 423
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;
invoke-static {}, Landroid/os/Process;->myPid()I
move-result v1
invoke-static {}, Landroid/os/Process;->myUid()I
move-result v2
invoke-virtual {v0, p2, v1, v2}, Landroid/content/Context;->checkPermission(Ljava/lang/String;II)I
move-result v0
if-nez v0, :cond_12
const/4 v0, 0x1
goto :goto_13
:cond_12
const/4 v0, 0x0
:goto_13
return v0
.end method
.method protected logBluetoothAdapterInfo(Landroid/bluetooth/BluetoothAdapter;)V
.registers 9
.param p1, "localAdapter" # Landroid/bluetooth/BluetoothAdapter;
.line 430
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "BluetoothAdapter: enabled="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 431
invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->isEnabled()Z
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v1, ", state="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 432
invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getState()I
move-result v1
invoke-direct {p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ", name="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 433
invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, ", address="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 434
invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getAddress()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 430
const-string v2, "AppRTCBluetoothManager"
invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 436
invoke-virtual {p1}, Landroid/bluetooth/BluetoothAdapter;->getBondedDevices()Ljava/util/Set;
move-result-object v0
.line 437
.local v0, "pairedDevices":Ljava/util/Set;, "Ljava/util/Set<Landroid/bluetooth/BluetoothDevice;>;"
invoke-interface {v0}, Ljava/util/Set;->isEmpty()Z
move-result v3
if-nez v3, :cond_84
.line 438
const-string v3, "paired devices:"
invoke-static {v2, v3}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 439
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_55
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_84
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Landroid/bluetooth/BluetoothDevice;
.line 440
.local v4, "device":Landroid/bluetooth/BluetoothDevice;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, " name="
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Landroid/bluetooth/BluetoothDevice;->getAddress()Ljava/lang/String;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v2, v5}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 441
.end local v4 # "device":Landroid/bluetooth/BluetoothDevice;
goto :goto_55
.line 443
:cond_84
return-void
.end method
.method protected registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)V
.registers 4
.param p1, "receiver" # Landroid/content/BroadcastReceiver;
.param p2, "filter" # Landroid/content/IntentFilter;
.line 403
:try_start_0
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;
invoke-virtual {v0, p1, p2}, Landroid/content/Context;->registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)Landroid/content/Intent;
:try_end_5
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_5} :catch_6
.line 406
goto :goto_a
.line 404
:catch_6
move-exception v0
.line 405
.local v0, "e":Ljava/lang/Exception;
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
.line 407
.end local v0 # "e":Ljava/lang/Exception;
:goto_a
return-void
.end method
.method public start()V
.registers 6
.line 236
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 237
const-string v0, "AppRTCBluetoothManager"
const-string v1, "start"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 238
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;
const-string v2, "android.permission.BLUETOOTH"
invoke-virtual {p0, v1, v2}, Lorg/webrtc/audio/AppRTCBluetoothManager;->hasPermission(Landroid/content/Context;Ljava/lang/String;)Z
move-result v1
if-nez v1, :cond_32
.line 239
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Process (pid="
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Landroid/os/Process;->myPid()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, ") lacks BLUETOOTH permission"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 240
return-void
.line 242
:cond_32
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v1, v2, :cond_3e
.line 243
const-string v1, "Invalid BT state"
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 244
return-void
.line 246
:cond_3e
const/4 v1, 0x0
iput-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
.line 247
iput-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 248
const/4 v1, 0x0
iput v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I
.line 250
invoke-static {}, Landroid/bluetooth/BluetoothAdapter;->getDefaultAdapter()Landroid/bluetooth/BluetoothAdapter;
move-result-object v1
iput-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
.line 251
if-nez v1, :cond_54
.line 252
const-string v1, "Device does not support Bluetooth"
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
.line 253
return-void
.line 256
:cond_54
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;
invoke-virtual {v1}, Landroid/media/AudioManager;->isBluetoothScoAvailableOffCall()Z
move-result v1
if-nez v1, :cond_62
.line 257
const-string v1, "Bluetooth SCO audio is not available off call"
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 258
return-void
.line 260
:cond_62
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
invoke-virtual {p0, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->logBluetoothAdapterInfo(Landroid/bluetooth/BluetoothAdapter;)V
.line 263
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;
iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothServiceListener:Landroid/bluetooth/BluetoothProfile$ServiceListener;
const/4 v3, 0x1
invoke-virtual {p0, v1, v2, v3}, Lorg/webrtc/audio/AppRTCBluetoothManager;->getBluetoothProfileProxy(Landroid/content/Context;Landroid/bluetooth/BluetoothProfile$ServiceListener;I)Z
move-result v1
if-nez v1, :cond_78
.line 265
const-string v1, "BluetoothAdapter.getProfileProxy(HEADSET) failed"
invoke-static {v0, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 266
return-void
.line 269
:cond_78
new-instance v1, Landroid/content/IntentFilter;
invoke-direct {v1}, Landroid/content/IntentFilter;-><init>()V
.line 271
.local v1, "bluetoothHeadsetFilter":Landroid/content/IntentFilter;
const-string v2, "android.bluetooth.headset.profile.action.CONNECTION_STATE_CHANGED"
invoke-virtual {v1, v2}, Landroid/content/IntentFilter;->addAction(Ljava/lang/String;)V
.line 273
const-string v2, "android.bluetooth.headset.profile.action.AUDIO_STATE_CHANGED"
invoke-virtual {v1, v2}, Landroid/content/IntentFilter;->addAction(Ljava/lang/String;)V
.line 274
iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;
invoke-virtual {p0, v2, v1}, Lorg/webrtc/audio/AppRTCBluetoothManager;->registerReceiver(Landroid/content/BroadcastReceiver;Landroid/content/IntentFilter;)V
.line 275
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "HEADSET profile state: "
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
.line 276
invoke-virtual {v4, v3}, Landroid/bluetooth/BluetoothAdapter;->getProfileConnectionState(I)I
move-result v3
invoke-direct {p0, v3}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 275
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 277
const-string v2, "Bluetooth proxy for headset profile has started"
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 278
sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_UNAVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 279
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "start done: BT state="
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 280
return-void
.end method
.method public startScoAudio()Z
.registers 6
.line 319
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 320
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "startSco: BT state="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v1, ", attempts: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, ", SCO is on: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 322
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z
move-result v2
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 320
const-string v2, "AppRTCBluetoothManager"
invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 323
iget v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I
const/4 v3, 0x0
const/4 v4, 0x2
if-lt v0, v4, :cond_3d
.line 324
const-string v0, "BT SCO connection fails - no more attempts"
invoke-static {v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 325
return v3
.line 327
:cond_3d
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v4, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_AVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v0, v4, :cond_49
.line 328
const-string v0, "BT SCO connection fails - no headset available"
invoke-static {v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 329
return v3
.line 332
:cond_49
const-string v0, "Starting Bluetooth SCO and waits for ACTION_AUDIO_STATE_CHANGED..."
invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 336
sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 337
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;
invoke-virtual {v0}, Landroid/media/AudioManager;->startBluetoothSco()V
.line 338
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;
const/4 v3, 0x1
invoke-virtual {v0, v3}, Landroid/media/AudioManager;->setBluetoothScoOn(Z)V
.line 339
iget v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I
add-int/2addr v0, v3
iput v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->scoConnectionAttempts:I
.line 340
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->startTimer()V
.line 341
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "startScoAudio done: BT state="
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 342
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 341
invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 343
return v3
.end method
.method public stop()V
.registers 6
.line 284
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 285
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadsetReceiver:Landroid/content/BroadcastReceiver;
invoke-virtual {p0, v0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V
.line 286
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "stop: BT state="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "AppRTCBluetoothManager"
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 287
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
if-eqz v0, :cond_45
.line 289
invoke-virtual {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stopScoAudio()V
.line 291
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v0, v2, :cond_45
.line 292
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->cancelTimer()V
.line 293
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
const/4 v2, 0x0
if-eqz v0, :cond_3d
.line 294
iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
const/4 v4, 0x1
invoke-virtual {v3, v4, v0}, Landroid/bluetooth/BluetoothAdapter;->closeProfileProxy(ILandroid/bluetooth/BluetoothProfile;)V
.line 295
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
.line 297
:cond_3d
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothAdapter:Landroid/bluetooth/BluetoothAdapter;
.line 298
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 299
sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 302
:cond_45
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "stop done: BT state="
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 303
return-void
.end method
.method public stopScoAudio()V
.registers 5
.line 348
invoke-static {}, Lorg/webrtc/ali/ThreadUtils;->checkIsOnMainThread()V
.line 349
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "stopScoAudio: BT state="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v1, ", SCO is on: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 350
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z
move-result v2
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 349
const-string v2, "AppRTCBluetoothManager"
invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 351
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v3, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v0, v3, :cond_34
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v3, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_CONNECTED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v0, v3, :cond_34
.line 352
return-void
.line 354
:cond_34
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->cancelTimer()V
.line 355
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;
invoke-virtual {v0}, Landroid/media/AudioManager;->stopBluetoothSco()V
.line 356
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->audioManager:Landroid/media/AudioManager;
const/4 v3, 0x0
invoke-virtual {v0, v3}, Landroid/media/AudioManager;->setBluetoothScoOn(Z)V
.line 357
sget-object v0, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->SCO_DISCONNECTING:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 358
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "stopScoAudio done: BT state="
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 359
invoke-direct {p0}, Lorg/webrtc/audio/AppRTCBluetoothManager;->isScoOn()Z
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 358
invoke-static {v2, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 360
return-void
.end method
.method protected unregisterReceiver(Landroid/content/BroadcastReceiver;)V
.registers 3
.param p1, "receiver" # Landroid/content/BroadcastReceiver;
.line 411
:try_start_0
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->apprtcContext:Landroid/content/Context;
invoke-virtual {v0, p1}, Landroid/content/Context;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V
:try_end_5
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_5} :catch_6
.line 414
goto :goto_a
.line 412
:catch_6
move-exception v0
.line 413
.local v0, "e":Ljava/lang/Exception;
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
.line 415
.end local v0 # "e":Ljava/lang/Exception;
:goto_a
return-void
.end method
.method public updateDevice()V
.registers 6
.line 370
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
sget-object v1, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->UNINITIALIZED:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
if-eq v0, v1, :cond_8e
iget-object v0, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
if-nez v0, :cond_c
goto/16 :goto_8e
.line 373
:cond_c
const-string v0, "AppRTCBluetoothManager"
const-string v1, "updateDevice"
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 377
iget-object v1, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
invoke-virtual {v1}, Landroid/bluetooth/BluetoothHeadset;->getConnectedDevices()Ljava/util/List;
move-result-object v1
.line 378
.local v1, "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
invoke-interface {v1}, Ljava/util/List;->isEmpty()Z
move-result v2
if-eqz v2, :cond_2c
.line 379
const/4 v2, 0x0
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 380
sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_UNAVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 381
const-string v2, "No connected bluetooth headset"
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_77
.line 384
:cond_2c
const/4 v2, 0x0
invoke-interface {v1, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Landroid/bluetooth/BluetoothDevice;
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 385
sget-object v2, Lorg/webrtc/audio/AppRTCBluetoothManager$State;->HEADSET_AVAILABLE:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
iput-object v2, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
.line 386
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Connected bluetooth headset: name="
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 387
invoke-virtual {v3}, Landroid/bluetooth/BluetoothDevice;->getName()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, ", state="
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 388
invoke-virtual {v3, v4}, Landroid/bluetooth/BluetoothHeadset;->getConnectionState(Landroid/bluetooth/BluetoothDevice;)I
move-result v3
invoke-direct {p0, v3}, Lorg/webrtc/audio/AppRTCBluetoothManager;->stateToString(I)Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, ", SCO audio="
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothHeadset:Landroid/bluetooth/BluetoothHeadset;
iget-object v4, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothDevice:Landroid/bluetooth/BluetoothDevice;
.line 389
invoke-virtual {v3, v4}, Landroid/bluetooth/BluetoothHeadset;->isAudioConnected(Landroid/bluetooth/BluetoothDevice;)Z
move-result v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 386
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 391
:goto_77
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "updateDevice done: BT state="
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lorg/webrtc/audio/AppRTCBluetoothManager;->bluetoothState:Lorg/webrtc/audio/AppRTCBluetoothManager$State;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v0, v2}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 392
return-void
.line 371
.end local v1 # "devices":Ljava/util/List;, "Ljava/util/List<Landroid/bluetooth/BluetoothDevice;>;"
:cond_8e
:goto_8e
return-void
.end method