AndroidR上展讯CameraAPP点击预览聚焦的流程

现象:点击预览会显示聚焦框,然后一段时间后聚焦框消失。

一,点击预览触发聚焦的流程

从下面的trace中看到点击touch事件是如何转到AndroidCamera2AgentImpl中去触发聚焦的
关键流程是:
1,PhotoModule.onSingleTapUp ==》
2,FocusOverlayManager.onSingleTapUp ==》
3,FocusOverlayManager.autoFocus ==》
4, PhotoModule.autoFocus ==》
5,AndroidCamera2AgentImpl$AndroidCamera2ProxyImpl.autoFocus

04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): autofocus:java.lang.Throwable
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.ex.camera2.portability.AndroidCamera2AgentImpl$AndroidCamera2ProxyImpl.autoFocus(AndroidCamera2AgentImpl.java:1599)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.PhotoModule.autoFocus(PhotoModule.java:4059)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.FocusOverlayManager.autoFocus(FocusOverlayManager.java:927)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.FocusOverlayManager.autoFocus(FocusOverlayManager.java:959)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.FocusOverlayManager.onSingleTapUp(FocusOverlayManager.java:837)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.PhotoModule.onSingleTapUp(PhotoModule.java:4156)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.PhotoUI$1.onSingleTapUp(PhotoUI.java:146)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.GestureDetector.onTouchEvent(GestureDetector.java:758)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.ui.PreviewOverlay.onTouchEvent(PreviewOverlay.java:260)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.View.dispatchTouchEvent(View.java:14392)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3128)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2808)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3128)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2808)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3128)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2808)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3128)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2808)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3128)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2808)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.internal.policy.DecorView.superDispatchTouchEvent(DecorView.java:491)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.internal.policy.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1871)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.app.Activity.dispatchTouchEvent(Activity.java:4188)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.camera.CameraActivity.dispatchTouchEvent(CameraActivity.java:1965)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.internal.policy.DecorView.dispatchTouchEvent(DecorView.java:449)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.View.dispatchPointerEvent(View.java:14655)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:6109)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:5905)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5395)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:5453)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:5418)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:5571)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:5426)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:5628)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5399)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:5453)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:5418)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:5426)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5399)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:8228)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:8179)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:8140)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:8357)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:220)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.os.MessageQueue.nativePollOnce(Native Method)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.os.MessageQueue.next(MessageQueue.java:335)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.os.Looper.loop(Looper.java:183)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at android.app.ActivityThread.main(ActivityThread.java:7945)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at java.lang.reflect.Method.invoke(Native Method)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:603)
04-12 17:20:48.540: E/CAM2PORT_AndCam2AgntImp(20509): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)

1,PhotoModule.onSingleTapUp ==》
2,FocusOverlayManager.onSingleTapUp ==》
3,FocusOverlayManager.autoFocus ==》
4, PhotoModule.autoFocus ==》
5,AndroidCamera2AgentImpl$AndroidCamera2ProxyImpl.autoFocus
下面贴一些代码来具体说明上述调用逻辑
1,PhotoModule.onSingleTapUp

 @Override
    public void onSingleTapUp(View view, int x, int y) {
    	// --- 省略与本流程无关的逻辑
    	mFocusManager.onSingleTapUp(x, y, isSupportTouchEV());
    }

2,FocusOverlayManager.onSingleTapUp

public void onSingleTapUp(int x, int y, boolean supportTEV) {
	// --- 省略与本流程无关的逻辑
	autoFocus();
}

3,FocusOverlayManager.autoFocus

public void autoFocus() {
	autoFocus(STATE_FOCUSING);//调用有参的autoFocus方法
}

private void autoFocus(int focusingState) {
    Log.i(TAG, "autoFocus focusingState:" + focusingState);
	if(isSingletapFocus)
        isAFLock = true;
    mListener.autoFocus();//此处Listener对象是PhotoModule
    mState = focusingState;
    if (!mIsSupportTEV && !mFocusRing.isAEAFDraging()) {
        updateFocusUI();//SPRD:fix bug 594887
    }
    mHandler.removeMessages(RESET_TOUCH_FOCUS);

    initializeCameraSound();
}

4, PhotoModule.autoFocus

@Override
    public void autoFocus() {
        if (mCameraDevice == null) {
            return;
        }
        Log.i(TAG, "Starting auto focus");
        mNeedCancelAutoFocus = true;
        mFocusStartTime = System.currentTimeMillis();
        mCameraDevice.autoFocus(mHandler, mAutoFocusCallback);// ** 调用mCameraDevice的autoFocus方法,mCameraDevice对象是连接app与底层通信的实例
        setCameraState(FOCUSING);
        Log.i(TAG, "autoFocus end!");
    }

5,AndroidCamera2AgentImpl$AndroidCamera2ProxyImpl.autoFocus
关键是发送了CameraActions.AUTO_FOCUS 的message去继续向底层请求聚焦,我们不往下继续跟了,这里关注CameraAFCallback,即聚焦成功之后会回调 CameraAFCallback 的 onAutoFocus方法

@Override
public void autoFocus(final Handler handler, final CameraAFCallback cb) {
    Log.e(TAG,"autofocus:"+android.util.Log.getStackTraceString(new Throwable()));
    try {
        if (mAutofocusRunnable == null) {
            mAutofocusRunnable = new Runnable() {
                @Override
                public void run() {
                    CameraAFCallback cbForward = null;
                    if (cb != null) {
                        cbForward = new CameraAFCallback() {
                            @Override
                            public void onAutoFocus(final boolean focused,
                                                    final CameraProxy camera) {
                                handler.post(new Runnable() {
                                    @Override
                                    public void run() {
                                        cb.onAutoFocus(focused, camera);
                                    }
                                });
                            }
                        };
                    }
                    mCameraHandler.obtainMessage(CameraActions.AUTO_FOCUS, cbForward)
                            .sendToTarget();
                }
            };
        }
        mDispatchThread.runJob(mAutofocusRunnable);
    } catch (RuntimeException ex) {
        mAutofocusRunnable = null;
        mCameraAgent.getCameraExceptionHandler().onDispatchThreadException(ex);
    }
}

二,Focus流程回调

1,PhoptoModule.AutoFocusCallback.onAutoFocus ==>
2,FocusManager.onAutoFocus ==>
3,AELockPanel.showTipText

老规矩,贴部分代码来说明上述的调用逻辑:

1,回调到PhotoModule的onAutoFocus方法中

private final class AutoFocusCallback implements CameraAFCallback {
    @Override
    public void onAutoFocus(boolean focused, CameraProxy camera) {
        if (mPaused) {
            return;
        }

        mAutoFocusTime = System.currentTimeMillis() - mFocusStartTime;
        Log.i(TAG, "mAutoFocusTime = " + mAutoFocusTime + "ms   focused = "
                + focused);
        setCameraState(IDLE);
        mFocusManager.onAutoFocus(focused, false);// *** FocusManager.onAutoFocus
    }
}

2,mFocusManager.onAutoFocus

public void onAutoFocus(boolean focused, boolean shutterButtonPressed) {
        Log.i(TAG, "onAutoFocus focused:" + focused + ",mState:" + mState+"  isAFLock:"+isAFLock);
        /**SPRD:Bug1005594 set isAELock in advance @{*/

        if(isAFLock) {
            mListener.setAELock(true);//*** 设置AELock的状态:true
            mFocusRing.setTipTextVisible(true);// *** 跟下去
            mFocusRing.setSeekBarVisibility(true);
        }
    }

3,流程转到 AELockPanel中

public void showtipText(boolean visible){
        if(tipText == null){
            tipText = (TextView)getRootView().findViewById(R.id.lock_ae_tip);
        }
        Log.d(TAG,"show tip text :" + visible+"  "+android.util.Log.getStackTraceString(new Throwable()));
        if(visible){
            tipText.setText(R.string.lock_ae_and_af);
            if(!isSingletap)
                tipText.setVisibility(View.VISIBLE);
			if(adjustCircle != null)
				adjustCircle.setVisibility(View.VISIBLE);
            if(verticalSeekBar != null){
                verticalSeekBar.setVisibility(View.VISIBLE);//SPRD:fix bug946451
            }
            startTime = System.currentTimeMillis();
            hidePanelAWhile();// *** 延时设置 setAELock 的状态
        } else {
            tipText.setVisibility(View.GONE);
        }
    }

    /**
    * add by zy for nokia.
    * hide the panel if no operation within 3s.
    */
    public void hidePanelAWhile(){
        CameraActivity.THREAD_POOL_EXECUTOR.execute(new Runnable(){
            @Override
            public void run() {
                while(true){
                    //android.util.Log.d("zhaoyu","thread:Time"+(System.currentTimeMillis()-getStartTime()));  
                    if((System.currentTimeMillis()-getStartTime())>3000){
                        ((CameraActivity)getContext()).runOnUiThread(new Runnable() {
                            @Override
                            public void run() {
                                if(isSingletap){
                                    //hide
                                    CameraModule mCurrentModule = ((CameraActivity) mContext).getCurrentModule();
                                    if(mCurrentModule instanceof PhotoModule){
                                        ((PhotoModule) mCurrentModule).setAELock(false);//3s延时之后,将AELock置为false,与第7步中的setAELock(true)相对
                                    }
                                }
                            }
                        });
                        break;
                    }
                }
            }
        });
    }

好了,手动点击预览触发聚焦 及 聚焦成功之后回调流程 的逻辑就是这些了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值