第9讲 Android Camera性能分析 在Camera App或Java Framework添加trace

本讲是Android Camera性能分析专题的第9讲,我们介绍在Camera App或Java Framework添加trace,包括如下内容:

  1. Java Trace类说明
  2. 实战:在Camera App中添加Trace
  3. 实战:在Camera Java Framework中添加Trace

视频在线观看:

加入知识星球与更多Camera同学交流
– 星球名称:深入浅出Android Camera
– 星球ID: 17296815

Java Trace类说明

android.os.Trace类描述
beginSection(String sectionName)在一个函数中打印Trace开始标记,会显示在某个线程中
endSection()在一个函数中打印Trace结束标记,会显示在某个线程中
beginAsyncSection(String methodName, int cookie)打印异步Trace开始标记,cookie用来区分相同methodName不同的异步Trace,会独立成一行Trace显示
endAsyncSection(String methodName, int cookie)打印异步Trace结束标记,cookie用来区分相同methodName不同的异步Trace,会独立成一行Trace显示
setCounter(String counterName, long counterValue)以给定计数器的值打印Trace
isEnabled()判断是否Trace打开了,建议打印Trace前都判断下避免创建一些无用的临时对象

实战:在Camera App中添加Trace

public class GeekCamera2Trace {
    public static final String OPEN_CAMERA = "GC2_openCamera";
    public static final String CREATE_CAPTURE_SESSION = "GC2_createCaptureSession";
    public static final String FRAME_NUMBER = "GC2_FrameNumber";
    public static void beginAsyncSection(String methodName, int cookie) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q && Trace.isEnabled()) {
            Trace.beginAsyncSection(methodName, cookie);
        }
    }

    public static void endAsyncSection(String methodName, int cookie) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q && Trace.isEnabled()) {
            Trace.endAsyncSection(methodName, cookie);
        }
    }

    public static void beginSection(String sectionName) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q &&Trace.isEnabled()) {
            Trace.beginSection(sectionName);
        }
    }

    public static void endSection() {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q &&Trace.isEnabled()) {
            Trace.endSection();
        }
    }

    public static void setCounter(String counterName, long counterValue) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q &&Trace.isEnabled()) {
            Trace.setCounter(counterName, counterValue);
        }
    }
}

实战:在Camera Java Framework中添加Trace

public void openCameraForUid(@NonNull String cameraId,
        @NonNull final CameraDevice.StateCallback callback, @NonNull Executor executor,
        int clientUid, int oomScoreOffset) throws CameraAccessException {
    Log.i(TAG, "v.deepinout.com openCameraForUid cameraId:" + cameraId);
    Trace.beginSection("GC2_FWK_openCameraForUid");

    if (cameraId == null) {
        throw new IllegalArgumentException("cameraId was null");
    } else if (callback == null) {
        throw new IllegalArgumentException("callback was null");
    }
    if (CameraManagerGlobal.sCameraServiceDisabled) {
        throw new IllegalArgumentException("No cameras available on device");
    }

    openCameraDeviceUserAsync(cameraId, callback, executor, clientUid, oomScoreOffset);
    Trace.endSection();
}

Android模拟器替换image后无法开机怎么办

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

deepinout_camera

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值