MacawAudioStreamThread.smali
.class public Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;
.super Ljava/lang/Thread;
.source "SourceFile"
# static fields
.field private static final TAG:Ljava/lang/String; = "MacawAudioStreamThread"
.field private static final kPlayerSampleByteCount:I = 0x2
.field private static final kPlayerSampleConfig:I = 0x2
.field private static final kRecorderReadFailThreshold:I = 0x64
.field private static final kRecorderSampleByteCount:I = 0x2
.field private static final kRecorderSampleConfig:I = 0x2
# instance fields
.field private mAudioDeviceType:I
.field private volatile mMacawContext:J
.field private mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;
.field private mPlayer:Landroid/media/AudioTrack;
.field private mPlayerBuffer:[B
.field private mPlayerChannelCount:I
.field private mPlayerChannelCountConfig:I
.field private mPlayerFrameBytesSize:I
.field private mPlayerFrameSize:I
.field private mPlayerSampleRate:I
.field private mPlayerStream:I
.field private mPlayerSystemBufferSize:I
.field mRecorder:Landroid/media/AudioRecord;
.field private mRecorderBuffer:[B
.field private mRecorderChannelConfig:I
.field private mRecorderChannelCount:I
.field private mRecorderFailReadTimes:I
.field private mRecorderFrameBytesSize:I
.field private mRecorderFrameSampleSize:I
.field private mRecorderReadErrorTimes:I
.field private mRecorderSampleRate:I
.field private mRecorderSource:I
.field private mRecorderSystemBufferSize:I
.field private mRecorderTotalLength:I
.field private volatile mRunning:Z
# direct methods
.method public constructor <init>(Lcom/imo/android/imoim/av/macaw/MacawHandler;JI)V
.registers 12
.line 48
invoke-direct {p0}, Ljava/lang/Thread;-><init>()V
const-wide/16 v0, 0x0
.line 20
iput-wide v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J
const/4 v0, 0x0
.line 21
iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;
const/4 v1, -0x1
.line 22
iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
const/4 v1, 0x0
.line 23
iput-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z
.line 25
iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
.line 26
iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B
const/16 v2, 0x1400
.line 27
iput v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I
.line 28
iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I
const/16 v3, 0x3e80
.line 29
iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I
const/4 v4, 0x1
.line 30
iput v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I
const/16 v5, 0x10
.line 31
iput v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I
const/16 v5, 0x280
.line 32
iput v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I
const/16 v6, 0x140
.line 33
iput v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I
.line 34
iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I
.line 35
iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I
.line 36
iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I
.line 38
iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
.line 39
iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B
.line 40
iput v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I
.line 41
iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I
.line 42
iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I
.line 43
iput v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCount:I
const/4 v0, 0x4
.line 44
iput v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I
.line 45
iput v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I
.line 46
iput v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I
.line 49
iput-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z
.line 50
iput-wide p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J
.line 51
iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;
.line 52
iput p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
return-void
.end method
.method private initPlay(IIIZ)Z
.registers 13
.line 57
iput p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I
.line 58
iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCount:I
.line 59
iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I
const/4 p1, 0x2
mul-int/lit8 p3, p3, 0x2
mul-int p3, p3, p2
.line 60
iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I
const/4 p3, 0x1
if-ne p2, p3, :cond_12
const/4 p2, 0x4
goto :goto_14
:cond_12
const/16 p2, 0xc
.line 61
:goto_14
iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I
if-eqz p4, :cond_1b
const/4 p2, 0x3
.line 63
iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I
.line 65
:cond_1b
iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I
invoke-static {p2, p4, p1}, Landroid/media/AudioTrack;->getMinBufferSize(III)I
move-result p1
.line 66
iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I
div-int p4, p1, p2
rem-int p2, p1, p2
const/4 v0, 0x0
if-nez p2, :cond_2e
const/4 p2, 0x0
goto :goto_2f
:cond_2e
const/4 p2, 0x1
:goto_2f
add-int/2addr p4, p2
iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I
mul-int p4, p4, p2
iput p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I
.line 68
new-instance p2, Ljava/lang/StringBuilder;
const-string p4, "AudioTrack created: playMinSize="
invoke-direct {p2, p4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p1, ", mPlayerSystemBufferSize="
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "MacawAudioStreamThread"
.line 1071
invoke-static {p2, p1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 69
new-instance p1, Ljava/lang/StringBuilder;
const-string p4, "AudioTrack created: Source="
invoke-direct {p1, p4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p4, ", SampleRate="
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p4, ", ChannelCount="
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I
invoke-virtual {p1, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 2071
invoke-static {p2, p1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 p1, 0x0
.line 71
iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
.line 73
:try_start_7d
new-instance p4, Landroid/media/AudioTrack;
iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I
iget v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I
const/4 v5, 0x2
iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I
const/4 v7, 0x1
move-object v1, p4
invoke-direct/range {v1 .. v7}, Landroid/media/AudioTrack;-><init>(IIIIII)V
iput-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
:try_end_8f
.catch Ljava/lang/IllegalArgumentException; {:try_start_7d .. :try_end_8f} :catch_a9
.catch Ljava/lang/Exception; {:try_start_7d .. :try_end_8f} :catch_90
goto :goto_c1
:catch_90
move-exception p4
.line 80
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "AudioTrack created: encountered an unexpected exception: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p4}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object p4
invoke-virtual {v1, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
.line 3079
invoke-static {p2, p4, p3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 81
iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
goto :goto_c1
:catch_a9
move-exception p4
.line 76
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "AudioTrack created: failed due to illegal argument: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p4}, Ljava/lang/IllegalArgumentException;->getMessage()Ljava/lang/String;
move-result-object p4
invoke-virtual {v1, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
.line 2079
invoke-static {p2, p4, p3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 77
iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
.line 83
:goto_c1
iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
if-eqz p4, :cond_e9
invoke-virtual {p4}, Landroid/media/AudioTrack;->getState()I
move-result p4
if-eq p4, p3, :cond_e9
.line 84
new-instance p4, Ljava/lang/StringBuilder;
const-string v1, "AudioTrack created: Failed to create AudioTrack state="
invoke-direct {p4, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
invoke-virtual {v1}, Landroid/media/AudioTrack;->getState()I
move-result v1
invoke-virtual {p4, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
.line 4075
invoke-static {p2, p4}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 85
iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
invoke-virtual {p4}, Landroid/media/AudioTrack;->release()V
.line 86
iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
.line 89
:cond_e9
iget-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
if-nez p1, :cond_f3
const-string p1, "AudioTrack created: create Failed"
.line 5071
invoke-static {p2, p1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return v0
.line 93
:cond_f3
iget p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I
new-array p1, p1, [B
iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B
.line 94
iput-boolean p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z
return p3
.end method
.method private initRecord(IIIZ)Z
.registers 12
.line 99
iput p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I
.line 100
iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I
const/4 p1, 0x1
if-ne p2, p1, :cond_a
const/16 p2, 0x10
goto :goto_c
:cond_a
const/16 p2, 0xc
.line 101
:goto_c
iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I
.line 102
iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I
.line 103
iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I
mul-int p3, p3, p2
const/4 p2, 0x2
mul-int/lit8 p3, p3, 0x2
iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I
if-eqz p4, :cond_1e
const/4 p3, 0x7
.line 105
iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I
.line 107
:cond_1e
iget p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I
invoke-static {p3, p4, p2}, Landroid/media/AudioRecord;->getMinBufferSize(III)I
move-result p2
.line 108
iget p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I
div-int p4, p2, p3
rem-int p3, p2, p3
const/4 v0, 0x0
if-nez p3, :cond_31
const/4 p3, 0x0
goto :goto_32
:cond_31
const/4 p3, 0x1
:goto_32
add-int/2addr p4, p3
iget p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I
mul-int p4, p4, p3
iput p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I
.line 110
new-instance p3, Ljava/lang/StringBuilder;
const-string p4, "AudioRecord created: recordMinSize="
invoke-direct {p3, p4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p2, ", mRecorderSystemBufferSize="
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
const-string p3, "MacawAudioStreamThread"
.line 6071
invoke-static {p3, p2}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 111
new-instance p2, Ljava/lang/StringBuilder;
const-string p4, "AudioRecord created: Source="
invoke-direct {p2, p4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I
invoke-virtual {p2, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p4, ", SampleRate="
invoke-virtual {p2, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I
invoke-virtual {p2, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string p4, ", ChannelCount="
invoke-virtual {p2, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I
invoke-virtual {p2, p4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p2
.line 7071
invoke-static {p3, p2}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 p2, 0x0
.line 113
iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
.line 115
:try_start_80
new-instance p4, Landroid/media/AudioRecord;
iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I
iget v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I
const/4 v5, 0x2
iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I
move-object v1, p4
invoke-direct/range {v1 .. v6}, Landroid/media/AudioRecord;-><init>(IIIII)V
iput-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
:try_end_91
.catch Ljava/lang/IllegalArgumentException; {:try_start_80 .. :try_end_91} :catch_ab
.catch Ljava/lang/Exception; {:try_start_80 .. :try_end_91} :catch_92
goto :goto_c3
:catch_92
move-exception p4
.line 122
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "AudioRecord created: catched an unknown exception: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p4}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object p4
invoke-virtual {v1, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
.line 8079
invoke-static {p3, p4, p1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 123
iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
goto :goto_c3
:catch_ab
move-exception p4
.line 118
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "AudioRecord created: failed due to illegal argument: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p4}, Ljava/lang/IllegalArgumentException;->getMessage()Ljava/lang/String;
move-result-object p4
invoke-virtual {v1, p4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
.line 7079
invoke-static {p3, p4, p1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 119
iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
.line 126
:goto_c3
iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
if-eqz p4, :cond_eb
invoke-virtual {p4}, Landroid/media/AudioRecord;->getState()I
move-result p4
if-eq p4, p1, :cond_eb
.line 127
new-instance p4, Ljava/lang/StringBuilder;
const-string v1, "AudioRecord created: failed; state="
invoke-direct {p4, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
invoke-virtual {v1}, Landroid/media/AudioRecord;->getState()I
move-result v1
invoke-virtual {p4, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
.line 9075
invoke-static {p3, p4}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 128
iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
invoke-virtual {p4}, Landroid/media/AudioRecord;->release()V
.line 129
iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
.line 132
:cond_eb
iget-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
if-nez p2, :cond_f5
const-string p1, "AudioRecord created: create Failed"
.line 10071
invoke-static {p3, p1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return v0
.line 136
:cond_f5
iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I
new-array p2, p2, [B
iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B
.line 137
iput-boolean p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z
return p1
.end method
# virtual methods
.method public init(IIIZ)Z
.registers 7
.line 142
iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
if-nez v0, :cond_9
.line 143
invoke-direct {p0, p1, p2, p3, p4}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->initRecord(IIIZ)Z
move-result p1
return p1
:cond_9
const/4 v1, 0x1
if-ne v0, v1, :cond_11
.line 147
invoke-direct {p0, p1, p2, p3, p4}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->initPlay(IIIZ)Z
move-result p1
return p1
:cond_11
const/4 p1, 0x0
return p1
.end method
.method public playRun()V
.registers 8
const-string v0, "MacawAudioStreamThread"
const-string v1, "playThread run start"
.line 11071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
const/16 v1, -0x10
.line 166
invoke-static {v1}, Landroid/os/Process;->setThreadPriority(I)V
.line 168
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
if-nez v1, :cond_11
return-void
.line 172
:cond_11
iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I
new-array v3, v2, [B
const/4 v4, 0x0
invoke-virtual {v1, v3, v4, v2}, Landroid/media/AudioTrack;->write([BII)I
.line 174
:try_start_19
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
invoke-virtual {v1}, Landroid/media/AudioTrack;->play()V
:try_end_1e
.catch Ljava/lang/IllegalStateException; {:try_start_19 .. :try_end_1e} :catch_94
.catch Ljava/lang/Exception; {:try_start_19 .. :try_end_1e} :catch_1f
goto :goto_35
:catch_1f
move-exception v1
.line 181
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "AudioTrack.play() encountered an unexpected exception: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 12075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 184
:goto_35
iget-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z
if-eqz v1, :cond_65
.line 186
:try_start_39
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;
iget-wide v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J
iget-object v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B
iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I
invoke-virtual {v1, v2, v3, v5, v6}, Lcom/imo/android/imoim/av/macaw/MacawHandler;->readDataFromJavaDeviceStream(J[BI)I
.line 187
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
iget-object v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I
invoke-virtual {v1, v2, v4, v3}, Landroid/media/AudioTrack;->write([BII)I
:try_end_4d
.catch Ljava/lang/Exception; {:try_start_39 .. :try_end_4d} :catch_4e
goto :goto_35
:catch_4e
move-exception v1
.line 189
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "AudioTrack.play() encounter exception: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 13075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_35
.line 194
:cond_65
:try_start_65
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
invoke-virtual {v1}, Landroid/media/AudioTrack;->flush()V
.line 195
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
invoke-virtual {v1}, Landroid/media/AudioTrack;->stop()V
.line 196
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
invoke-virtual {v1}, Landroid/media/AudioTrack;->release()V
:try_end_74
.catch Ljava/lang/Exception; {:try_start_65 .. :try_end_74} :catch_75
goto :goto_8b
:catch_75
move-exception v1
.line 199
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "AudioTrack.play() flush/stop/release failed: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 14075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
:goto_8b
const/4 v1, 0x0
.line 201
iput-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
const-string v1, "playThread run end"
.line 15071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
:catch_94
move-exception v1
.line 177
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "AudioTrack.play() failed due to illegal argument: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x1
.line 11079
invoke-static {v0, v1, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
return-void
.end method
.method public recordRun()V
.registers 8
const-string v0, "MacawAudioStreamThread"
const-string v1, "recordthread run start"
.line 16071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
const/16 v1, -0x10
.line 207
invoke-static {v1}, Landroid/os/Process;->setThreadPriority(I)V
.line 209
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
if-nez v1, :cond_11
return-void
:cond_11
const/4 v2, 0x1
.line 214
:try_start_12
invoke-virtual {v1}, Landroid/media/AudioRecord;->startRecording()V
:try_end_15
.catch Ljava/lang/IllegalStateException; {:try_start_12 .. :try_end_15} :catch_163
.catch Ljava/lang/Exception; {:try_start_12 .. :try_end_15} :catch_16
goto :goto_2c
:catch_16
move-exception v1
.line 221
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Recorder.startRecording(): encountered an unexpected exception: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 17075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 224
:cond_2c
:goto_2c
iget-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z
if-eqz v1, :cond_112
const/4 v1, -0x1
const/4 v3, 0x0
.line 227
:try_start_32
iget-object v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
iget-object v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B
iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I
invoke-virtual {v4, v5, v3, v6}, Landroid/media/AudioRecord;->read([BII)I
move-result v1
:try_end_3c
.catch Ljava/lang/Exception; {:try_start_32 .. :try_end_3c} :catch_3d
goto :goto_53
:catch_3d
move-exception v4
.line 229
new-instance v5, Ljava/lang/StringBuilder;
const-string v6, "record read Exception: "
invoke-direct {v5, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v4}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v4
invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 18075
invoke-static {v0, v4}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
:goto_53
if-gtz v1, :cond_cd
const/4 v3, -0x2
if-eq v1, v3, :cond_5b
const/4 v3, -0x3
if-ne v1, v3, :cond_86
.line 234
:cond_5b
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I
const/16 v4, 0x1900
if-le v3, v4, :cond_bf
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I
const/16 v4, 0x14
if-ge v3, v4, :cond_bf
add-int/lit8 v3, v3, 0x1
.line 235
iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I
.line 236
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Mic may be rapped by another app, restart mRecorder to get it back, retrying "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v4, "errorcode="
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
.line 19075
invoke-static {v0, v3}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 242
:cond_86
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I
add-int/2addr v3, v2
iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I
const-wide/16 v3, 0x14
.line 245
:try_start_8d
invoke-static {v3, v4}, Ljava/lang/Thread;->sleep(J)V
:try_end_90
.catch Ljava/lang/InterruptedException; {:try_start_8d .. :try_end_90} :catch_91
goto :goto_9d
:catch_91
const-string v3, "audio record thread interrupted"
.line 21071
invoke-static {v0, v3}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 248
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/Thread;->interrupt()V
.line 251
:goto_9d
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I
const/16 v4, 0x64
if-lt v3, v4, :cond_2c
.line 252
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "audio record read error, readTimes="
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, ", threshold=100errorcode="
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 21075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_112
.line 238
:cond_bf
invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v1
const-string v2, "audio record read error:"
invoke-virtual {v2, v1}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
.line 20075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_112
.line 256
:cond_cd
iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I
.line 257
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I
if-ge v1, v3, :cond_e9
.line 258
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "mRecorder: read "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v4, " bytes"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
.line 22075
invoke-static {v0, v3}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
.line 261
:cond_e9
:try_start_e9
iget-object v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;
iget-wide v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J
iget-object v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B
invoke-virtual {v3, v4, v5, v6, v1}, Lcom/imo/android/imoim/av/macaw/MacawHandler;->writeDataToJavaDeviceStream(J[BI)I
move-result v1
.line 262
iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I
add-int/2addr v3, v1
iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I
:try_end_f8
.catch Ljava/lang/Exception; {:try_start_e9 .. :try_end_f8} :catch_fa
goto/16 :goto_2c
:catch_fa
move-exception v1
.line 264
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "audio record thread writeDataToJavaDeviceStream exception: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 23075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
goto/16 :goto_2c
.line 269
:cond_112
:goto_112
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
if-eqz v1, :cond_14f
.line 271
:try_start_116
invoke-virtual {v1}, Landroid/media/AudioRecord;->stop()V
.line 272
iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
invoke-virtual {v1}, Landroid/media/AudioRecord;->release()V
:try_end_11e
.catch Ljava/lang/IllegalStateException; {:try_start_116 .. :try_end_11e} :catch_136
.catch Ljava/lang/Exception; {:try_start_116 .. :try_end_11e} :catch_11f
goto :goto_14c
:catch_11f
move-exception v1
.line 277
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "stop mRecorder encountered an unexpected exception: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 25075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_14c
:catch_136
move-exception v1
.line 274
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "stop mRecorder IllegalStateException: "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 24075
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
:goto_14c
const/4 v1, 0x0
.line 279
iput-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
.line 281
:cond_14f
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "recordThread run end, totalReadLength="
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 26071
invoke-static {v0, v1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
:catch_163
move-exception v1
.line 217
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "Recorder.startRecording(): IllegalStateException: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;
move-result-object v1
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 16079
invoke-static {v0, v1, v2}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
return-void
.end method
.method public run()V
.registers 3
.line 155
iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
if-nez v0, :cond_7
.line 156
invoke-virtual {p0}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->recordRun()V
.line 159
:cond_7
iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
const/4 v1, 0x1
if-ne v0, v1, :cond_f
.line 160
invoke-virtual {p0}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->playRun()V
:cond_f
return-void
.end method
.method public stopThread(I)V
.registers 6
.line 285
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "Stop Audio Strem thread in devive type: "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "MacawAudioStreamThread"
.line 27071
invoke-static {v1, v0}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 v0, 0x0
.line 286
iput-boolean v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z
const-wide/16 v2, 0x0
.line 287
iput-wide v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J
.line 288
invoke-virtual {p0}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->interrupt()V
int-to-long v2, p1
const/4 p1, 0x1
.line 290
:try_start_21
invoke-virtual {p0, v2, v3}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->join(J)V
:try_end_24
.catch Ljava/lang/InterruptedException; {:try_start_21 .. :try_end_24} :catch_39
.catch Ljava/lang/Exception; {:try_start_21 .. :try_end_24} :catch_25
goto :goto_53
.line 296
:catch_25
new-instance v0, Ljava/lang/StringBuilder;
const-string v2, "Join Audio Strem thread encountered an unexpected exception: "
invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 28079
invoke-static {v1, v0, p1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
goto :goto_53
.line 292
:catch_39
new-instance v0, Ljava/lang/StringBuilder;
const-string v2, "Stop Audio Strem thread was interrupted devive type: "
invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 27079
invoke-static {v1, v0, p1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V
.line 293
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/Thread;->interrupt()V
.line 298
:goto_53
new-instance p1, Ljava/lang/StringBuilder;
const-string v0, "Stop Audio Strem thread out devive type: "
invoke-direct {p1, v0}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 29071
invoke-static {v1, p1}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method