CameraVideoCapturer$CameraStatistics$1.smali

.class Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;
.super Ljava/lang/Object;
.source "CameraVideoCapturer.java"

# interfaces
.implements Ljava/lang/Runnable;


# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
    value = Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0x0
    name = null
.end annotation


# instance fields
.field final synthetic this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    return-void
.end method

.method constructor <init>(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)V
    .registers 2
    .param p1, "this$0"    # Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    .line 105
    iput-object p1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    return-void
.end method


# virtual methods
.method public run()V
    .registers 6

    .line 108
    iget-object v0, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->frameCount:I
    invoke-static {v0}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$000(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)I

    move-result v0

    int-to-float v0, v0

    const/high16 v1, 0x447a0000    # 1000.0f

    mul-float v0, v0, v1

    const/high16 v1, 0x44fa0000    # 2000.0f

    div-float/2addr v0, v1

    invoke-static {v0}, Ljava/lang/Math;->round(F)I

    move-result v0

    .line 109
    .local v0, "cameraFps":I
    new-instance v1, Ljava/lang/StringBuilder;

    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V

    const-string v2, "Camera fps: "

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    const-string 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

    const-string v2, "CameraStatistics"

    invoke-static {v2, v1}, Lorg/webrtc/ali/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 110
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->frameCount:I
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$000(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)I

    move-result v1

    const/4 v3, 0x0

    if-nez v1, :cond_78

    .line 111
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # ++operator for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->freezePeriodCount:I
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$104(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)I

    .line 112
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->freezePeriodCount:I
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$100(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)I

    move-result v1

    mul-int/lit16 v1, v1, 0x7d0

    const/16 v4, 0xfa0

    if-lt v1, v4, :cond_7d

    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    .line 113
    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->eventsHandler:Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$200(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;

    move-result-object v1

    if-eqz v1, :cond_7d

    .line 114
    const-string v1, "Camera freezed."

    invoke-static {v2, v1}, Lorg/webrtc/ali/Logging;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 115
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->surfaceTextureHelper:Lorg/webrtc/ali/SurfaceTextureHelper;
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$300(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)Lorg/webrtc/ali/SurfaceTextureHelper;

    move-result-object v1

    invoke-virtual {v1}, Lorg/webrtc/ali/SurfaceTextureHelper;->isTextureInUse()Z

    move-result v1

    if-eqz v1, :cond_6c

    .line 117
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->eventsHandler:Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$200(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;

    move-result-object v1

    const-string v2, "Camera failure. Client must return video buffers."

    invoke-interface {v1, v2}, Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;->onCameraFreezed(Ljava/lang/String;)V

    goto :goto_77

    .line 119
    :cond_6c
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->eventsHandler:Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$200(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;

    move-result-object v1

    const-string v2, "Camera failure."

    invoke-interface {v1, v2}, Lorg/webrtc/ali/CameraVideoCapturer$CameraEventsHandler;->onCameraFreezed(Ljava/lang/String;)V

    .line 121
    :goto_77
    return-void

    .line 124
    :cond_78
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # setter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->freezePeriodCount:I
    invoke-static {v1, v3}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$102(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;I)I

    .line 126
    :cond_7d
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # setter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->frameCount:I
    invoke-static {v1, v3}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$002(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;I)I

    .line 127
    iget-object v1, p0, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics$1;->this$0:Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;

    # getter for: Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->surfaceTextureHelper:Lorg/webrtc/ali/SurfaceTextureHelper;
    invoke-static {v1}, Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;->access$300(Lorg/webrtc/ali/CameraVideoCapturer$CameraStatistics;)Lorg/webrtc/ali/SurfaceTextureHelper;

    move-result-object v1

    invoke-virtual {v1}, Lorg/webrtc/ali/SurfaceTextureHelper;->getHandler()Landroid/os/Handler;

    move-result-object v1

    const-wide/16 v2, 0x7d0

    invoke-virtual {v1, p0, v2, v3}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z

    .line 128
    return-void
.end method