Camera1Session.smali

.class Lorg/webrtc/ali/Camera1Session;
.super Ljava/lang/Object;
.source "Camera1Session.java"

# interfaces
.implements Lorg/webrtc/ali/CameraSession;


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lorg/webrtc/ali/Camera1Session$SessionState;
    }
.end annotation


# static fields
.field private static final NUMBER_OF_CAPTURE_BUFFERS:I = 0x3

.field private static final TAG:Ljava/lang/String; = "Camera1Session"

.field private static final camera1ResolutionHistogram:Lorg/webrtc/ali/Histogram;

.field private static final camera1StartTimeMsHistogram:Lorg/webrtc/ali/Histogram;

.field private static final camera1StopTimeMsHistogram:Lorg/webrtc/ali/Histogram;


# instance fields
.field private final applicationContext:Landroid/content/Context;

.field private final camera:Landroid/hardware/Camera;

.field private final cameraId:I

.field private final cameraThreadHandler:Landroid/os/Handler;

.field private final captureFormat:Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;

.field private final captureToTexture:Z

.field private final constructionTimeNs:J

.field private final events:Lorg/webrtc/ali/CameraSession$Events;

.field private firstFrameReported:Z

.field private final info:Landroid/hardware/Camera$CameraInfo;

.field private state:Lorg/webrtc/ali/Camera1Session$SessionState;

.field private final surfaceTextureHelper:Lorg/webrtc/ali/SurfaceTextureHelper;


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

    .line 30
    nop

    .line 31
    const/16 v0, 0x32

    const/16 v1, 0x2710

    const/4 v2, 0x1

    const-string v3, "WebRTC.Android.Camera1.StartTimeMs"

    invoke-static {v3, v2, v1, v0}, Lorg/webrtc/ali/Histogram;->createCounts(Ljava/lang/String;III)Lorg/webrtc/ali/Histogram;

    move-result-object v3

    sput-object v3, Lorg/webrtc/ali/Camera1Session;->camera1StartTimeMsHistogram:Lorg/webrtc/ali/Histogram;

    .line 32
    nop

    .line 33
    const-string v3, "WebRTC.Android.Camera1.StopTimeMs"

    invoke-static {v3, v2, v1, v0}, Lorg/webrtc/ali/Histogram;->createCounts(Ljava/lang/String;III)Lorg/webrtc/ali/Histogram;

    move-result-object v0

    sput-object v0, Lorg/webrtc/ali/Camera1Session;->camera1StopTimeMsHistogram:Lorg/webrtc/ali/Histogram;

    .line 34
    sget-object v0, Lorg/webrtc/ali/CameraEnumerationAndroid;->COMMON_RESOLUTIONS:Ljava/util/ArrayList;

    .line 35
    invoke-virtual {v0}, Ljava/util/ArrayList;->size()I

    move-result v0

    .line 34
    const-string v1, "WebRTC.Android.Camera1.Resolution"

    invoke-static {v1, v0}, Lorg/webrtc/ali/Histogram;->createEnumeration(Ljava/lang/String;I)Lorg/webrtc/ali/Histogram;

    move-result-object v0

    sput-object v0, Lorg/webrtc/ali/Camera1Session;->camera1ResolutionHistogram:Lorg/webrtc/ali/Histogram;

    return-void
.end method

.method private constructor <init>(Lorg/webrtc/ali/CameraSession$Events;ZLandroid/content/Context;Lorg/webrtc/ali/SurfaceTextureHelper;Landroid/media/MediaRecorder;ILandroid/hardware/Camera;Landroid/hardware/Camera$CameraInfo;Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;J)V
    .registers 14
    .param p1, "events"    # Lorg/webrtc/ali/CameraSession$Events;
    .param p2, "captureToTexture"    # Z
    .param p3, "applicationContext"    # Landroid/content/Context;
    .param p4, "surfaceTextureHelper"    # Lorg/webrtc/ali/SurfaceTextureHelper;
    .param p5, "mediaRecorder"    # Landroid/media/MediaRecorder;
    .param p6, "cameraId"    # I
    .param p7, "camera"    # Landroid/hardware/Camera;
    .param p8, "info"    # Landroid/hardware/Camera$CameraInfo;
    .param p9, "captureFormat"    # Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    .param p10, "constructionTimeNs"    # J

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

    .line 52
    const/4 v0, 0x0

    iput-boolean v0, p0, Lorg/webrtc/ali/Camera1Session;->firstFrameReported:Z

    .line 153
    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string v1, "Create new camera1 session on camera "

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

    invoke-virtual {v0, p6}, 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, "Camera1Session"

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

    .line 155
    new-instance v0, Landroid/os/Handler;

    invoke-direct {v0}, Landroid/os/Handler;-><init>()V

    iput-object v0, p0, Lorg/webrtc/ali/Camera1Session;->cameraThreadHandler:Landroid/os/Handler;

    .line 156
    iput-object p1, p0, Lorg/webrtc/ali/Camera1Session;->events:Lorg/webrtc/ali/CameraSession$Events;

    .line 157
    iput-boolean p2, p0, Lorg/webrtc/ali/Camera1Session;->captureToTexture:Z

    .line 158
    iput-object p3, p0, Lorg/webrtc/ali/Camera1Session;->applicationContext:Landroid/content/Context;

    .line 159
    iput-object p4, p0, Lorg/webrtc/ali/Camera1Session;->surfaceTextureHelper:Lorg/webrtc/ali/SurfaceTextureHelper;

    .line 160
    iput p6, p0, Lorg/webrtc/ali/Camera1Session;->cameraId:I

    .line 161
    iput-object p7, p0, Lorg/webrtc/ali/Camera1Session;->camera:Landroid/hardware/Camera;

    .line 162
    iput-object p8, p0, Lorg/webrtc/ali/Camera1Session;->info:Landroid/hardware/Camera$CameraInfo;

    .line 163
    iput-object p9, p0, Lorg/webrtc/ali/Camera1Session;->captureFormat:Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;

    .line 164
    iput-wide p10, p0, Lorg/webrtc/ali/Camera1Session;->constructionTimeNs:J

    .line 166
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->startCapturing()V

    .line 168
    if-eqz p5, :cond_40

    .line 169
    invoke-virtual {p7}, Landroid/hardware/Camera;->unlock()V

    .line 170
    invoke-virtual {p5, p7}, Landroid/media/MediaRecorder;->setCamera(Landroid/hardware/Camera;)V

    .line 172
    :cond_40
    return-void
.end method

.method static synthetic access$000(Lorg/webrtc/ali/Camera1Session;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->stopInternal()V

    return-void
.end method

.method static synthetic access$100(Lorg/webrtc/ali/Camera1Session;)Lorg/webrtc/ali/CameraSession$Events;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->events:Lorg/webrtc/ali/CameraSession$Events;

    return-object v0
.end method

.method static synthetic access$1000(Lorg/webrtc/ali/Camera1Session;)Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->captureFormat:Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;

    return-object v0
.end method

.method static synthetic access$1100(Lorg/webrtc/ali/Camera1Session;)Landroid/hardware/Camera;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->camera:Landroid/hardware/Camera;

    return-object v0
.end method

.method static synthetic access$200(Lorg/webrtc/ali/Camera1Session;)V
    .registers 1
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->checkIsOnCameraThread()V

    return-void
.end method

.method static synthetic access$300(Lorg/webrtc/ali/Camera1Session;)Lorg/webrtc/ali/Camera1Session$SessionState;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->state:Lorg/webrtc/ali/Camera1Session$SessionState;

    return-object v0
.end method

.method static synthetic access$400(Lorg/webrtc/ali/Camera1Session;)Lorg/webrtc/ali/SurfaceTextureHelper;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->surfaceTextureHelper:Lorg/webrtc/ali/SurfaceTextureHelper;

    return-object v0
.end method

.method static synthetic access$500(Lorg/webrtc/ali/Camera1Session;)Z
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-boolean v0, p0, Lorg/webrtc/ali/Camera1Session;->firstFrameReported:Z

    return v0
.end method

.method static synthetic access$502(Lorg/webrtc/ali/Camera1Session;Z)Z
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;
    .param p1, "x1"    # Z

    .line 26
    iput-boolean p1, p0, Lorg/webrtc/ali/Camera1Session;->firstFrameReported:Z

    return p1
.end method

.method static synthetic access$600(Lorg/webrtc/ali/Camera1Session;)J
    .registers 3
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-wide v0, p0, Lorg/webrtc/ali/Camera1Session;->constructionTimeNs:J

    return-wide v0
.end method

.method static synthetic access$700()Lorg/webrtc/ali/Histogram;
    .registers 1

    .line 26
    sget-object v0, Lorg/webrtc/ali/Camera1Session;->camera1StartTimeMsHistogram:Lorg/webrtc/ali/Histogram;

    return-object v0
.end method

.method static synthetic access$800(Lorg/webrtc/ali/Camera1Session;)I
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->getFrameOrientation()I

    move-result v0

    return v0
.end method

.method static synthetic access$900(Lorg/webrtc/ali/Camera1Session;)Landroid/hardware/Camera$CameraInfo;
    .registers 2
    .param p0, "x0"    # Lorg/webrtc/ali/Camera1Session;

    .line 26
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->info:Landroid/hardware/Camera$CameraInfo;

    return-object v0
.end method

.method private checkIsOnCameraThread()V
    .registers 3

    .line 339
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v0

    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->cameraThreadHandler:Landroid/os/Handler;

    invoke-virtual {v1}, Landroid/os/Handler;->getLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-virtual {v1}, Landroid/os/Looper;->getThread()Ljava/lang/Thread;

    move-result-object v1

    if-ne v0, v1, :cond_11

    .line 342
    return-void

    .line 340
    :cond_11
    new-instance v0, Ljava/lang/IllegalStateException;

    const-string v1, "Wrong thread"

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

    throw v0
.end method

.method public static create(Lorg/webrtc/ali/CameraSession$CreateSessionCallback;Lorg/webrtc/ali/CameraSession$Events;ZLandroid/content/Context;Lorg/webrtc/ali/SurfaceTextureHelper;Landroid/media/MediaRecorder;IIII)V
    .registers 32
    .param p0, "callback"    # Lorg/webrtc/ali/CameraSession$CreateSessionCallback;
    .param p1, "events"    # Lorg/webrtc/ali/CameraSession$Events;
    .param p2, "captureToTexture"    # Z
    .param p3, "applicationContext"    # Landroid/content/Context;
    .param p4, "surfaceTextureHelper"    # Lorg/webrtc/ali/SurfaceTextureHelper;
    .param p5, "mediaRecorder"    # Landroid/media/MediaRecorder;
    .param p6, "cameraId"    # I
    .param p7, "width"    # I
    .param p8, "height"    # I
    .param p9, "framerate"    # I

    .line 58
    move-object/from16 v1, p0

    move/from16 v14, p2

    move/from16 v15, p6

    move/from16 v12, p7

    move/from16 v13, p8

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v16

    .line 59
    .local v16, "constructionTimeNs":J
    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string v2, "Open camera "

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

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

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    const-string v2, "Camera1Session"

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

    .line 60
    invoke-interface/range {p1 .. p1}, Lorg/webrtc/ali/CameraSession$Events;->onCameraOpening()V

    .line 64
    :try_start_27
    invoke-static/range {p6 .. p6}, Landroid/hardware/Camera;->open(I)Landroid/hardware/Camera;

    move-result-object v0
    :try_end_2b
    .catch Ljava/lang/RuntimeException; {:try_start_27 .. :try_end_2b} :catch_a0

    move-object v11, v0

    .line 68
    .local v11, "camera":Landroid/hardware/Camera;
    nop

    .line 71
    :try_start_2d
    invoke-virtual/range {p4 .. p4}, Lorg/webrtc/ali/SurfaceTextureHelper;->getSurfaceTexture()Landroid/graphics/SurfaceTexture;

    move-result-object v0

    invoke-virtual {v11, v0}, Landroid/hardware/Camera;->setPreviewTexture(Landroid/graphics/SurfaceTexture;)V
    :try_end_34
    .catch Ljava/io/IOException; {:try_start_2d .. :try_end_34} :catch_90

    .line 76
    nop

    .line 78
    new-instance v0, Landroid/hardware/Camera$CameraInfo;

    invoke-direct {v0}, Landroid/hardware/Camera$CameraInfo;-><init>()V

    .line 79
    .local v0, "info":Landroid/hardware/Camera$CameraInfo;
    invoke-static {v15, v0}, Landroid/hardware/Camera;->getCameraInfo(ILandroid/hardware/Camera$CameraInfo;)V

    .line 81
    invoke-virtual {v11}, Landroid/hardware/Camera;->getParameters()Landroid/hardware/Camera$Parameters;

    move-result-object v10

    .line 82
    .local v10, "parameters":Landroid/hardware/Camera$Parameters;
    nop

    .line 83
    move/from16 v9, p9

    invoke-static {v10, v12, v13, v9}, Lorg/webrtc/ali/Camera1Session;->findClosestCaptureFormat(Landroid/hardware/Camera$Parameters;III)Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;

    move-result-object v8

    .line 84
    .local v8, "captureFormat":Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    invoke-static {v10, v12, v13}, Lorg/webrtc/ali/Camera1Session;->findClosestPictureSize(Landroid/hardware/Camera$Parameters;II)Lorg/webrtc/ali/Size;

    move-result-object v7

    .line 86
    .local v7, "pictureSize":Lorg/webrtc/ali/Size;
    invoke-static {v11, v10, v8, v7, v14}, Lorg/webrtc/ali/Camera1Session;->updateCameraParameters(Landroid/hardware/Camera;Landroid/hardware/Camera$Parameters;Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;Lorg/webrtc/ali/Size;Z)V

    .line 89
    if-nez v14, :cond_67

    .line 90
    invoke-virtual {v8}, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;->frameSize()I

    move-result v2

    .line 91
    .local v2, "frameSize":I
    const/4 v3, 0x0

    .local v3, "i":I
    :goto_56
    const/4 v4, 0x3

    if-ge v3, v4, :cond_67

    .line 92
    invoke-static {v2}, Ljava/nio/ByteBuffer;->allocateDirect(I)Ljava/nio/ByteBuffer;

    move-result-object v4

    .line 93
    .local v4, "buffer":Ljava/nio/ByteBuffer;
    invoke-virtual {v4}, Ljava/nio/ByteBuffer;->array()[B

    move-result-object v5

    invoke-virtual {v11, v5}, Landroid/hardware/Camera;->addCallbackBuffer([B)V

    .line 91
    .end local v4    # "buffer":Ljava/nio/ByteBuffer;
    add-int/lit8 v3, v3, 0x1

    goto :goto_56

    .line 98
    .end local v2    # "frameSize":I
    .end local v3    # "i":I
    :cond_67
    const/4 v2, 0x0

    invoke-virtual {v11, v2}, Landroid/hardware/Camera;->setDisplayOrientation(I)V

    .line 100
    new-instance v6, Lorg/webrtc/ali/Camera1Session;

    move-object v2, v6

    move-object/from16 v3, p1

    move/from16 v4, p2

    move-object/from16 v5, p3

    move-object v14, v6

    move-object/from16 v6, p4

    move-object/from16 v18, v7

    .end local v7    # "pictureSize":Lorg/webrtc/ali/Size;
    .local v18, "pictureSize":Lorg/webrtc/ali/Size;
    move-object/from16 v7, p5

    move-object/from16 v19, v8

    .end local v8    # "captureFormat":Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    .local v19, "captureFormat":Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    move/from16 v8, p6

    move-object v9, v11

    move-object/from16 v20, v10

    .end local v10    # "parameters":Landroid/hardware/Camera$Parameters;
    .local v20, "parameters":Landroid/hardware/Camera$Parameters;
    move-object v10, v0

    move-object/from16 v21, v11

    .end local v11    # "camera":Landroid/hardware/Camera;
    .local v21, "camera":Landroid/hardware/Camera;
    move-object/from16 v11, v19

    move-wide/from16 v12, v16

    invoke-direct/range {v2 .. v13}, Lorg/webrtc/ali/Camera1Session;-><init>(Lorg/webrtc/ali/CameraSession$Events;ZLandroid/content/Context;Lorg/webrtc/ali/SurfaceTextureHelper;Landroid/media/MediaRecorder;ILandroid/hardware/Camera;Landroid/hardware/Camera$CameraInfo;Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;J)V

    invoke-interface {v1, v14}, Lorg/webrtc/ali/CameraSession$CreateSessionCallback;->onDone(Lorg/webrtc/ali/CameraSession;)V

    .line 103
    return-void

    .line 72
    .end local v0    # "info":Landroid/hardware/Camera$CameraInfo;
    .end local v18    # "pictureSize":Lorg/webrtc/ali/Size;
    .end local v19    # "captureFormat":Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    .end local v20    # "parameters":Landroid/hardware/Camera$Parameters;
    .end local v21    # "camera":Landroid/hardware/Camera;
    .restart local v11    # "camera":Landroid/hardware/Camera;
    :catch_90
    move-exception v0

    move-object/from16 v21, v11

    .line 73
    .end local v11    # "camera":Landroid/hardware/Camera;
    .local v0, "e":Ljava/io/IOException;
    .restart local v21    # "camera":Landroid/hardware/Camera;
    invoke-virtual/range {v21 .. v21}, Landroid/hardware/Camera;->release()V

    .line 74
    sget-object v2, Lorg/webrtc/ali/CameraSession$FailureType;->ERROR:Lorg/webrtc/ali/CameraSession$FailureType;

    invoke-virtual {v0}, Ljava/io/IOException;->getMessage()Ljava/lang/String;

    move-result-object v3

    invoke-interface {v1, v2, v3}, Lorg/webrtc/ali/CameraSession$CreateSessionCallback;->onFailure(Lorg/webrtc/ali/CameraSession$FailureType;Ljava/lang/String;)V

    .line 75
    return-void

    .line 65
    .end local v0    # "e":Ljava/io/IOException;
    .end local v21    # "camera":Landroid/hardware/Camera;
    :catch_a0
    move-exception v0

    move-object v2, v0

    move-object v0, v2

    .line 66
    .local v0, "e":Ljava/lang/RuntimeException;
    sget-object v2, Lorg/webrtc/ali/CameraSession$FailureType;->ERROR:Lorg/webrtc/ali/CameraSession$FailureType;

    invoke-virtual {v0}, Ljava/lang/RuntimeException;->getMessage()Ljava/lang/String;

    move-result-object v3

    invoke-interface {v1, v2, v3}, Lorg/webrtc/ali/CameraSession$CreateSessionCallback;->onFailure(Lorg/webrtc/ali/CameraSession$FailureType;Ljava/lang/String;)V

    .line 67
    return-void
.end method

.method private static findClosestCaptureFormat(Landroid/hardware/Camera$Parameters;III)Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    .registers 10
    .param p0, "parameters"    # Landroid/hardware/Camera$Parameters;
    .param p1, "width"    # I
    .param p2, "height"    # I
    .param p3, "framerate"    # I

    .line 129
    nop

    .line 130
    invoke-virtual {p0}, Landroid/hardware/Camera$Parameters;->getSupportedPreviewFpsRange()Ljava/util/List;

    move-result-object v0

    invoke-static {v0}, Lorg/webrtc/ali/Camera1Enumerator;->convertFramerates(Ljava/util/List;)Ljava/util/List;

    move-result-object v0

    .line 131
    .local v0, "supportedFramerates":Ljava/util/List;, "Ljava/util/List<Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;>;"
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "Available fps ranges: "

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

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

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

    move-result-object v1

    const-string v2, "Camera1Session"

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

    .line 133
    nop

    .line 134
    invoke-static {v0, p3}, Lorg/webrtc/ali/CameraEnumerationAndroid;->getClosestSupportedFramerateRange(Ljava/util/List;I)Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;

    move-result-object v1

    .line 136
    .local v1, "fpsRange":Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;
    nop

    .line 137
    invoke-virtual {p0}, Landroid/hardware/Camera$Parameters;->getSupportedPreviewSizes()Ljava/util/List;

    move-result-object v2

    invoke-static {v2}, Lorg/webrtc/ali/Camera1Enumerator;->convertSizes(Ljava/util/List;)Ljava/util/List;

    move-result-object v2

    .line 136
    invoke-static {v2, p1, p2}, Lorg/webrtc/ali/CameraEnumerationAndroid;->getClosestSupportedSize(Ljava/util/List;II)Lorg/webrtc/ali/Size;

    move-result-object v2

    .line 138
    .local v2, "previewSize":Lorg/webrtc/ali/Size;
    sget-object v3, Lorg/webrtc/ali/Camera1Session;->camera1ResolutionHistogram:Lorg/webrtc/ali/Histogram;

    invoke-static {v3, v2}, Lorg/webrtc/ali/CameraEnumerationAndroid;->reportCameraResolution(Lorg/webrtc/ali/Histogram;Lorg/webrtc/ali/Size;)V

    .line 140
    new-instance v3, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;

    iget v4, v2, Lorg/webrtc/ali/Size;->width:I

    iget v5, v2, Lorg/webrtc/ali/Size;->height:I

    invoke-direct {v3, v4, v5, v1}, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;-><init>(IILorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;)V

    return-object v3
.end method

.method private static findClosestPictureSize(Landroid/hardware/Camera$Parameters;II)Lorg/webrtc/ali/Size;
    .registers 4
    .param p0, "parameters"    # Landroid/hardware/Camera$Parameters;
    .param p1, "width"    # I
    .param p2, "height"    # I

    .line 145
    nop

    .line 146
    invoke-virtual {p0}, Landroid/hardware/Camera$Parameters;->getSupportedPictureSizes()Ljava/util/List;

    move-result-object v0

    invoke-static {v0}, Lorg/webrtc/ali/Camera1Enumerator;->convertSizes(Ljava/util/List;)Ljava/util/List;

    move-result-object v0

    .line 145
    invoke-static {v0, p1, p2}, Lorg/webrtc/ali/CameraEnumerationAndroid;->getClosestSupportedSize(Ljava/util/List;II)Lorg/webrtc/ali/Size;

    move-result-object v0

    return-object v0
.end method

.method private getDeviceOrientation()I
    .registers 5

    .line 309
    const/4 v0, 0x0

    .line 311
    .local v0, "orientation":I
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->applicationContext:Landroid/content/Context;

    const-string v2, "window"

    invoke-virtual {v1, v2}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Landroid/view/WindowManager;

    .line 312
    .local v1, "wm":Landroid/view/WindowManager;
    invoke-interface {v1}, Landroid/view/WindowManager;->getDefaultDisplay()Landroid/view/Display;

    move-result-object v2

    invoke-virtual {v2}, Landroid/view/Display;->getRotation()I

    move-result v2

    const/4 v3, 0x1

    if-eq v2, v3, :cond_24

    const/4 v3, 0x2

    if-eq v2, v3, :cond_21

    const/4 v3, 0x3

    if-eq v2, v3, :cond_1e

    .line 324
    const/4 v0, 0x0

    goto :goto_27

    .line 320
    :cond_1e
    const/16 v0, 0x10e

    .line 321
    goto :goto_27

    .line 317
    :cond_21
    const/16 v0, 0xb4

    .line 318
    goto :goto_27

    .line 314
    :cond_24
    const/16 v0, 0x5a

    .line 315
    nop

    .line 327
    :goto_27
    return v0
.end method

.method private getFrameOrientation()I
    .registers 3

    .line 331
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->getDeviceOrientation()I

    move-result v0

    .line 332
    .local v0, "rotation":I
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->info:Landroid/hardware/Camera$CameraInfo;

    iget v1, v1, Landroid/hardware/Camera$CameraInfo;->facing:I

    if-nez v1, :cond_c

    .line 333
    rsub-int v0, v0, 0x168

    .line 335
    :cond_c
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->info:Landroid/hardware/Camera$CameraInfo;

    iget v1, v1, Landroid/hardware/Camera$CameraInfo;->orientation:I

    add-int/2addr v1, v0

    rem-int/lit16 v1, v1, 0x168

    return v1
.end method

.method private listenForBytebufferFrames()V
    .registers 3

    .line 277
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->camera:Landroid/hardware/Camera;

    new-instance v1, Lorg/webrtc/ali/Camera1Session$3;

    invoke-direct {v1, p0}, Lorg/webrtc/ali/Camera1Session$3;-><init>(Lorg/webrtc/ali/Camera1Session;)V

    invoke-virtual {v0, v1}, Landroid/hardware/Camera;->setPreviewCallbackWithBuffer(Landroid/hardware/Camera$PreviewCallback;)V

    .line 306
    return-void
.end method

.method private listenForTextureFrames()V
    .registers 3

    .line 244
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->surfaceTextureHelper:Lorg/webrtc/ali/SurfaceTextureHelper;

    new-instance v1, Lorg/webrtc/ali/Camera1Session$2;

    invoke-direct {v1, p0}, Lorg/webrtc/ali/Camera1Session$2;-><init>(Lorg/webrtc/ali/Camera1Session;)V

    invoke-virtual {v0, v1}, Lorg/webrtc/ali/SurfaceTextureHelper;->startListening(Lorg/webrtc/ali/SurfaceTextureHelper$OnTextureFrameAvailableListener;)V

    .line 274
    return-void
.end method

.method private startCapturing()V
    .registers 4

    .line 187
    const-string v0, "Camera1Session"

    const-string v1, "Start capturing"

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

    .line 188
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->checkIsOnCameraThread()V

    .line 190
    sget-object v0, Lorg/webrtc/ali/Camera1Session$SessionState;->RUNNING:Lorg/webrtc/ali/Camera1Session$SessionState;

    iput-object v0, p0, Lorg/webrtc/ali/Camera1Session;->state:Lorg/webrtc/ali/Camera1Session$SessionState;

    .line 192
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->camera:Landroid/hardware/Camera;

    new-instance v1, Lorg/webrtc/ali/Camera1Session$1;

    invoke-direct {v1, p0}, Lorg/webrtc/ali/Camera1Session$1;-><init>(Lorg/webrtc/ali/Camera1Session;)V

    invoke-virtual {v0, v1}, Landroid/hardware/Camera;->setErrorCallback(Landroid/hardware/Camera$ErrorCallback;)V

    .line 211
    iget-boolean v0, p0, Lorg/webrtc/ali/Camera1Session;->captureToTexture:Z

    if-eqz v0, :cond_20

    .line 212
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->listenForTextureFrames()V

    goto :goto_23

    .line 214
    :cond_20
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->listenForBytebufferFrames()V

    .line 217
    :goto_23
    :try_start_23
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->camera:Landroid/hardware/Camera;

    invoke-virtual {v0}, Landroid/hardware/Camera;->startPreview()V
    :try_end_28
    .catch Ljava/lang/RuntimeException; {:try_start_23 .. :try_end_28} :catch_29

    .line 221
    goto :goto_36

    .line 218
    :catch_29
    move-exception v0

    .line 219
    .local v0, "e":Ljava/lang/RuntimeException;
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->stopInternal()V

    .line 220
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->events:Lorg/webrtc/ali/CameraSession$Events;

    invoke-virtual {v0}, Ljava/lang/RuntimeException;->getMessage()Ljava/lang/String;

    move-result-object v2

    invoke-interface {v1, p0, v2}, Lorg/webrtc/ali/CameraSession$Events;->onCameraError(Lorg/webrtc/ali/CameraSession;Ljava/lang/String;)V

    .line 222
    .end local v0    # "e":Ljava/lang/RuntimeException;
    :goto_36
    return-void
.end method

.method private stopInternal()V
    .registers 4

    .line 225
    const-string v0, "Camera1Session"

    const-string v1, "Stop internal"

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

    .line 226
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->checkIsOnCameraThread()V

    .line 227
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->state:Lorg/webrtc/ali/Camera1Session$SessionState;

    sget-object v2, Lorg/webrtc/ali/Camera1Session$SessionState;->STOPPED:Lorg/webrtc/ali/Camera1Session$SessionState;

    if-ne v1, v2, :cond_16

    .line 228
    const-string v1, "Camera is already stopped"

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

    .line 229
    return-void

    .line 232
    :cond_16
    sget-object v1, Lorg/webrtc/ali/Camera1Session$SessionState;->STOPPED:Lorg/webrtc/ali/Camera1Session$SessionState;

    iput-object v1, p0, Lorg/webrtc/ali/Camera1Session;->state:Lorg/webrtc/ali/Camera1Session$SessionState;

    .line 233
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->surfaceTextureHelper:Lorg/webrtc/ali/SurfaceTextureHelper;

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

    .line 237
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->camera:Landroid/hardware/Camera;

    invoke-virtual {v1}, Landroid/hardware/Camera;->stopPreview()V

    .line 238
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->camera:Landroid/hardware/Camera;

    invoke-virtual {v1}, Landroid/hardware/Camera;->release()V

    .line 239
    iget-object v1, p0, Lorg/webrtc/ali/Camera1Session;->events:Lorg/webrtc/ali/CameraSession$Events;

    invoke-interface {v1, p0}, Lorg/webrtc/ali/CameraSession$Events;->onCameraClosed(Lorg/webrtc/ali/CameraSession;)V

    .line 240
    const-string v1, "Stop done"

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

    .line 241
    return-void
.end method

.method private static updateCameraParameters(Landroid/hardware/Camera;Landroid/hardware/Camera$Parameters;Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;Lorg/webrtc/ali/Size;Z)V
    .registers 8
    .param p0, "camera"    # Landroid/hardware/Camera;
    .param p1, "parameters"    # Landroid/hardware/Camera$Parameters;
    .param p2, "captureFormat"    # Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;
    .param p3, "pictureSize"    # Lorg/webrtc/ali/Size;
    .param p4, "captureToTexture"    # Z

    .line 108
    invoke-virtual {p1}, Landroid/hardware/Camera$Parameters;->getSupportedFocusModes()Ljava/util/List;

    move-result-object v0

    .line 110
    .local v0, "focusModes":Ljava/util/List;, "Ljava/util/List<Ljava/lang/String;>;"
    iget-object v1, p2, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;->framerate:Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;

    iget v1, v1, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;->min:I

    iget-object v2, p2, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;->framerate:Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;

    iget v2, v2, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat$FramerateRange;->max:I

    invoke-virtual {p1, v1, v2}, Landroid/hardware/Camera$Parameters;->setPreviewFpsRange(II)V

    .line 111
    iget v1, p2, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;->width:I

    iget v2, p2, Lorg/webrtc/ali/CameraEnumerationAndroid$CaptureFormat;->height:I

    invoke-virtual {p1, v1, v2}, Landroid/hardware/Camera$Parameters;->setPreviewSize(II)V

    .line 112
    iget v1, p3, Lorg/webrtc/ali/Size;->width:I

    iget v2, p3, Lorg/webrtc/ali/Size;->height:I

    invoke-virtual {p1, v1, v2}, Landroid/hardware/Camera$Parameters;->setPictureSize(II)V

    .line 113
    if-nez p4, :cond_27

    .line 114
    invoke-virtual {p2}, Ljava/lang/Object;->getClass()Ljava/lang/Class;

    const/16 v1, 0x11

    invoke-virtual {p1, v1}, Landroid/hardware/Camera$Parameters;->setPreviewFormat(I)V

    .line 117
    :cond_27
    invoke-virtual {p1}, Landroid/hardware/Camera$Parameters;->isVideoStabilizationSupported()Z

    move-result v1

    if-eqz v1, :cond_31

    .line 118
    const/4 v1, 0x1

    invoke-virtual {p1, v1}, Landroid/hardware/Camera$Parameters;->setVideoStabilization(Z)V

    .line 120
    :cond_31
    const-string v1, "continuous-video"

    invoke-interface {v0, v1}, Ljava/util/List;->contains(Ljava/lang/Object;)Z

    move-result v2

    if-eqz v2, :cond_3c

    .line 121
    invoke-virtual {p1, v1}, Landroid/hardware/Camera$Parameters;->setFocusMode(Ljava/lang/String;)V

    .line 123
    :cond_3c
    invoke-virtual {p0, p1}, Landroid/hardware/Camera;->setParameters(Landroid/hardware/Camera$Parameters;)V

    .line 124
    return-void
.end method


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

    .line 176
    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string v1, "Stop camera1 session on camera "

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

    iget v1, p0, Lorg/webrtc/ali/Camera1Session;->cameraId: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, "Camera1Session"

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

    .line 177
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->checkIsOnCameraThread()V

    .line 178
    iget-object v0, p0, Lorg/webrtc/ali/Camera1Session;->state:Lorg/webrtc/ali/Camera1Session$SessionState;

    sget-object v1, Lorg/webrtc/ali/Camera1Session$SessionState;->STOPPED:Lorg/webrtc/ali/Camera1Session$SessionState;

    if-eq v0, v1, :cond_39

    .line 179
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v0

    .line 180
    .local v0, "stopStartTime":J
    invoke-direct {p0}, Lorg/webrtc/ali/Camera1Session;->stopInternal()V

    .line 181
    sget-object v2, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v3

    sub-long/2addr v3, v0

    invoke-virtual {v2, v3, v4}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J

    move-result-wide v2

    long-to-int v3, v2

    .line 182
    .local v3, "stopTimeMs":I
    sget-object v2, Lorg/webrtc/ali/Camera1Session;->camera1StopTimeMsHistogram:Lorg/webrtc/ali/Histogram;

    invoke-virtual {v2, v3}, Lorg/webrtc/ali/Histogram;->addSample(I)V

    .line 184
    .end local v0    # "stopStartTime":J
    .end local v3    # "stopTimeMs":I
    :cond_39
    return-void
.end method