DebugTextViewHelper.smali
.class public final Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;
.super Lcom/google/android/exoplayer2/Player$DefaultEventListener;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# static fields
.field private static final REFRESH_INTERVAL_MS:I = 0x3e8
# instance fields
.field private final player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
.field private started:Z
.field private final textView:Landroid/widget/TextView;
# direct methods
.method public constructor <init>(Lcom/google/android/exoplayer2/SimpleExoPlayer;Landroid/widget/TextView;)V
.registers 3
.line 43
invoke-direct {p0}, Lcom/google/android/exoplayer2/Player$DefaultEventListener;-><init>()V
.line 44
iput-object p1, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
.line 45
iput-object p2, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->textView:Landroid/widget/TextView;
return-void
.end method
.method private getAudioString()Ljava/lang/String;
.registers 4
.line 140
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
invoke-virtual {v0}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->getAudioFormat()Lcom/google/android/exoplayer2/Format;
move-result-object v0
if-nez v0, :cond_b
const-string v0, ""
return-object v0
.line 144
:cond_b
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "\n"
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v2, v0, Lcom/google/android/exoplayer2/Format;->sampleMimeType:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "(id:"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, v0, Lcom/google/android/exoplayer2/Format;->id:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " hz:"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, v0, Lcom/google/android/exoplayer2/Format;->sampleRate:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, " ch:"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v0, v0, Lcom/google/android/exoplayer2/Format;->channelCount:I
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
.line 146
invoke-virtual {v0}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->getAudioDecoderCounters()Lcom/google/android/exoplayer2/decoder/DecoderCounters;
move-result-object v0
invoke-static {v0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->getDecoderCountersBufferCountString(Lcom/google/android/exoplayer2/decoder/DecoderCounters;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, ")"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method private static getDecoderCountersBufferCountString(Lcom/google/android/exoplayer2/decoder/DecoderCounters;)Ljava/lang/String;
.registers 3
if-nez p0, :cond_5
const-string p0, ""
return-object p0
.line 153
:cond_5
invoke-virtual {p0}, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->ensureUpdated()V
.line 154
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, " sib:"
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v1, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->skippedInputBufferCount:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " sb:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->skippedOutputBufferCount:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " rb:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->renderedOutputBufferCount:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " db:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->droppedBufferCount:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " mcdb:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->maxConsecutiveDroppedBufferCount:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, " dk:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget p0, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->droppedToKeyframeCount:I
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
return-object p0
.end method
.method private static getPixelAspectRatioString(F)Ljava/lang/String;
.registers 5
const/high16 v0, -0x40800000 # -1.0f
cmpl-float v0, p0, v0
if-eqz v0, :cond_2e
const/high16 v0, 0x3f800000 # 1.0f
cmpl-float v0, p0, v0
if-nez v0, :cond_d
goto :goto_2e
.line 163
:cond_d
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, " par:"
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
sget-object v1, Ljava/util/Locale;->US:Ljava/util/Locale;
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
.line 164
invoke-static {p0}, Ljava/lang/Float;->valueOf(F)Ljava/lang/Float;
move-result-object p0
aput-object p0, v2, v3
const-string p0, "%.02f"
invoke-static {v1, p0, v2}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
return-object p0
:cond_2e
:goto_2e
const-string p0, ""
return-object p0
.end method
.method private getPlayerStateString()Ljava/lang/String;
.registers 4
.line 104
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "playWhenReady:"
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v1, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
invoke-virtual {v1}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->getPlayWhenReady()Z
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v1, " playbackState:"
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
.line 105
iget-object v1, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
invoke-virtual {v1}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->getPlaybackState()I
move-result v1
const/4 v2, 0x1
if-eq v1, v2, :cond_73
const/4 v2, 0x2
if-eq v1, v2, :cond_61
const/4 v2, 0x3
if-eq v1, v2, :cond_4f
const/4 v2, 0x4
if-eq v1, v2, :cond_3d
.line 119
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "unknown"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
goto :goto_84
.line 110
:cond_3d
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "ended"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
goto :goto_84
.line 116
:cond_4f
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "ready"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
goto :goto_84
.line 107
:cond_61
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "buffering"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
goto :goto_84
.line 113
:cond_73
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "idle"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
:goto_84
return-object v0
.end method
.method private getPlayerWindowIndexString()Ljava/lang/String;
.registers 3
.line 126
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, " window:"
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v1, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
invoke-virtual {v1}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->getCurrentWindowIndex()I
move-result v1
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
return-object v0
.end method
.method private getVideoString()Ljava/lang/String;
.registers 4
.line 130
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
invoke-virtual {v0}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->getVideoFormat()Lcom/google/android/exoplayer2/Format;
move-result-object v0
if-nez v0, :cond_b
const-string v0, ""
return-object v0
.line 134
:cond_b
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "\n"
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-object v2, v0, Lcom/google/android/exoplayer2/Format;->sampleMimeType:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "(id:"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, v0, Lcom/google/android/exoplayer2/Format;->id:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " r:"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, v0, Lcom/google/android/exoplayer2/Format;->width:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, "x"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, v0, Lcom/google/android/exoplayer2/Format;->height:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
iget v0, v0, Lcom/google/android/exoplayer2/Format;->pixelWidthHeightRatio:F
.line 135
invoke-static {v0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->getPixelAspectRatioString(F)Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
.line 136
invoke-virtual {v0}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->getVideoDecoderCounters()Lcom/google/android/exoplayer2/decoder/DecoderCounters;
move-result-object v0
invoke-static {v0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->getDecoderCountersBufferCountString(Lcom/google/android/exoplayer2/decoder/DecoderCounters;)Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, ")"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method private updateAndPost()V
.registers 4
.line 97
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->textView:Landroid/widget/TextView;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->getPlayerStateString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->getPlayerWindowIndexString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->getVideoString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 98
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->getAudioString()Ljava/lang/String;
move-result-object v2
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
.line 97
invoke-virtual {v0, v1}, Landroid/widget/TextView;->setText(Ljava/lang/CharSequence;)V
.line 99
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->textView:Landroid/widget/TextView;
invoke-virtual {v0, p0}, Landroid/widget/TextView;->removeCallbacks(Ljava/lang/Runnable;)Z
.line 100
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->textView:Landroid/widget/TextView;
const-wide/16 v1, 0x3e8
invoke-virtual {v0, p0, v1, v2}, Landroid/widget/TextView;->postDelayed(Ljava/lang/Runnable;J)Z
return-void
.end method
# virtual methods
.method public final onPlayerStateChanged(ZI)V
.registers 3
.line 78
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public final onPositionDiscontinuity(I)V
.registers 2
.line 83
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public final run()V
.registers 1
.line 90
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public final start()V
.registers 2
.line 53
iget-boolean v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->started:Z
if-eqz v0, :cond_5
return-void
:cond_5
const/4 v0, 0x1
.line 56
iput-boolean v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->started:Z
.line 57
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
invoke-virtual {v0, p0}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->addListener(Lcom/google/android/exoplayer2/Player$EventListener;)V
.line 58
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public final stop()V
.registers 2
.line 66
iget-boolean v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->started:Z
if-nez v0, :cond_5
return-void
:cond_5
const/4 v0, 0x0
.line 69
iput-boolean v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->started:Z
.line 70
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
invoke-virtual {v0, p0}, Lcom/google/android/exoplayer2/SimpleExoPlayer;->removeListener(Lcom/google/android/exoplayer2/Player$EventListener;)V
.line 71
iget-object v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->textView:Landroid/widget/TextView;
invoke-virtual {v0, p0}, Landroid/widget/TextView;->removeCallbacks(Ljava/lang/Runnable;)Z
return-void
.end method