DebugTextViewHelper.smali
.class public final Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;
.super Ljava/lang/Object;
.source "DebugTextViewHelper.java"
# interfaces
.implements Ljava/lang/Runnable;
.implements Lcom/google/android/exoplayer2/ExoPlayer$EventListener;
# 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 45
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 46
iput-object p1, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->player:Lcom/google/android/exoplayer2/SimpleExoPlayer;
.line 47
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 161
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 165
:cond_b
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "\n"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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 167
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 174
:cond_5
invoke-virtual {p0}, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->ensureUpdated()V
.line 175
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
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, " 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, " db:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->droppedOutputBufferCount: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 p0, p0, Lcom/google/android/exoplayer2/decoder/DecoderCounters;->maxConsecutiveDroppedOutputBufferCount: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 getPlayerStateString()Ljava/lang/String;
.registers 4
.line 125
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "playWhenReady:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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 126
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_77
const/4 v2, 0x2
if-eq v1, v2, :cond_65
const/4 v2, 0x3
if-eq v1, v2, :cond_53
const/4 v2, 0x4
if-eq v1, v2, :cond_41
.line 140
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/jumbo 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_88
.line 131
:cond_41
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_88
.line 137
:cond_53
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_88
.line 128
:cond_65
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_88
.line 134
:cond_77
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_88
return-object v0
.end method
.method private getPlayerWindowIndexString()Ljava/lang/String;
.registers 3
.line 147
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, " window:"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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 151
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 155
:cond_b
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "\n"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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/jumbo v2, "x"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v0, v0, Lcom/google/android/exoplayer2/Format;->height: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 156
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 118
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 119
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 118
invoke-virtual {v0, v1}, Landroid/widget/TextView;->setText(Ljava/lang/CharSequence;)V
.line 120
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 121
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 onLoadingChanged(Z)V
.registers 2
return-void
.end method
.method public onPlayerError(Lcom/google/android/exoplayer2/ExoPlaybackException;)V
.registers 2
return-void
.end method
.method public onPlayerStateChanged(ZI)V
.registers 3
.line 85
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public onPositionDiscontinuity()V
.registers 1
.line 90
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public onTimelineChanged(Lcom/google/android/exoplayer2/Timeline;Ljava/lang/Object;)V
.registers 3
return-void
.end method
.method public onTracksChanged(Lcom/google/android/exoplayer2/source/TrackGroupArray;Lcom/google/android/exoplayer2/trackselection/TrackSelectionArray;)V
.registers 3
return-void
.end method
.method public run()V
.registers 1
.line 112
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public start()V
.registers 2
.line 55
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 58
iput-boolean v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->started:Z
.line 59
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/ExoPlayer$EventListener;)V
.line 60
invoke-direct {p0}, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->updateAndPost()V
return-void
.end method
.method public stop()V
.registers 2
.line 68
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 71
iput-boolean v0, p0, Lcom/google/android/exoplayer2/ui/DebugTextViewHelper;->started:Z
.line 72
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/ExoPlayer$EventListener;)V
.line 73
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