Java Code Examples for android.hardware.camera2.CaptureResult#CONTROL_AF_STATE_PASSIVE_FOCUSED
The following examples show how to use
android.hardware.camera2.CaptureResult#CONTROL_AF_STATE_PASSIVE_FOCUSED .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: AcceptableZslImageFilter.java From Camera2 with Apache License 2.0 | 6 votes |
private boolean isAFAcceptable(TotalCaptureResultProxy metadata) { Integer afState = metadata.get(CaptureResult.CONTROL_AF_STATE); if (afState == null) { return true; } else { switch (afState) { case CaptureResult.CONTROL_AF_STATE_INACTIVE: case CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED: case CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: case CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED: case CaptureResult.CONTROL_AF_STATE_PASSIVE_UNFOCUSED: return true; default: return false; } } }
Example 2
Source File: AutoFocusHelper.java From Camera2 with Apache License 2.0 | 6 votes |
/** * Convert reported camera2 AF state to OneCamera AutoFocusState. */ public static OneCamera.AutoFocusState stateFromCamera2State(int state) { switch (state) { case CaptureResult.CONTROL_AF_STATE_ACTIVE_SCAN: return OneCamera.AutoFocusState.ACTIVE_SCAN; case CaptureResult.CONTROL_AF_STATE_PASSIVE_SCAN: return OneCamera.AutoFocusState.PASSIVE_SCAN; case CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED: return OneCamera.AutoFocusState.PASSIVE_FOCUSED; case CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED: return OneCamera.AutoFocusState.ACTIVE_FOCUSED; case CaptureResult.CONTROL_AF_STATE_PASSIVE_UNFOCUSED: return OneCamera.AutoFocusState.PASSIVE_UNFOCUSED; case CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: return OneCamera.AutoFocusState.ACTIVE_UNFOCUSED; default: return OneCamera.AutoFocusState.INACTIVE; } }
Example 3
Source File: AutoFocusHelper.java From Camera2 with Apache License 2.0 | 6 votes |
/** * Utility function: converts CaptureResult.CONTROL_AF_STATE to String. */ private static String controlAFStateToString(int controlAFState) { switch (controlAFState) { case CaptureResult.CONTROL_AF_STATE_INACTIVE: return "inactive"; case CaptureResult.CONTROL_AF_STATE_PASSIVE_SCAN: return "passive_scan"; case CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED: return "passive_focused"; case CaptureResult.CONTROL_AF_STATE_ACTIVE_SCAN: return "active_scan"; case CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED: return "focus_locked"; case CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: return "not_focus_locked"; case CaptureResult.CONTROL_AF_STATE_PASSIVE_UNFOCUSED: return "passive_unfocused"; default: return "unknown"; } }
Example 4
Source File: Camera2Helper.java From DeviceConnect-Android with MIT License | 6 votes |
/** * Auto-Focus の状態を文字列に変換します。 * * @param afState Auto Focus の状態 * @return 文字列 */ static String debugAFState(Integer afState) { if (afState == null) { return "NULL"; } switch (afState) { default: return "UNKNOWN"; case CaptureResult.CONTROL_AF_STATE_ACTIVE_SCAN: return "CaptureResult.CONTROL_AF_STATE_ACTIVE_SCAN"; case CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED: return "CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED"; case CaptureResult.CONTROL_AF_STATE_INACTIVE: return "CaptureResult.CONTROL_AF_STATE_INACTIVE"; case CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: return "CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED"; case CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED: return "CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED"; case CaptureResult.CONTROL_AF_STATE_PASSIVE_SCAN: return "CaptureResult.CONTROL_AF_STATE_PASSIVE_SCAN"; case CaptureResult.CONTROL_AF_STATE_PASSIVE_UNFOCUSED: return "CaptureResult.CONTROL_AF_STATE_PASSIVE_UNFOCUSED"; } }
Example 5
Source File: Camera2Wrapper.java From DeviceConnect-Android with MIT License | 5 votes |
@Override public void onCaptureResult(CaptureResult result, boolean isCompleted) { Integer afState = result.get(CaptureResult.CONTROL_AF_STATE); if (DEBUG) { Log.d(TAG, "afState: " + Camera2Helper.debugAFState(afState) + " isCompleted: " + isCompleted); } boolean isAfReady = afState == null || afState == CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED || afState == CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED || afState == CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED; boolean timeout = (System.currentTimeMillis() - mStartTime) > 5000; if (isAfReady || timeout) { nextState(mAutoExposureState); } }
Example 6
Source File: AndroidCamera2AgentImpl.java From Camera2 with Apache License 2.0 | 4 votes |
@Override public void monitorControlStates(CaptureResult result) { Integer afStateMaybe = result.get(CaptureResult.CONTROL_AF_STATE); if (afStateMaybe != null) { int afState = afStateMaybe; // Since we handle both partial and total results for multiple frames here, we // might get the final callbacks for an earlier frame after receiving one or // more that correspond to the next one. To prevent our data from oscillating, // we never consider AF states that are older than the last one we've seen. if (result.getFrameNumber() > mLastAfFrameNumber) { boolean afStateChanged = afState != mLastAfState; mLastAfState = afState; mLastAfFrameNumber = result.getFrameNumber(); switch (afState) { case CaptureResult.CONTROL_AF_STATE_PASSIVE_SCAN: case CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED: case CaptureResult.CONTROL_AF_STATE_PASSIVE_UNFOCUSED: { if (afStateChanged && mPassiveAfCallback != null) { // A CameraAFMoveCallback is attached. If we just started to // scan, the motor is moving; otherwise, it has settled. mPassiveAfCallback.onAutoFocusMoving( afState == CaptureResult.CONTROL_AF_STATE_PASSIVE_SCAN, mCameraProxy); } break; } case CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED: case CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: { // This check must be made regardless of whether the focus state has // changed recently to avoid infinite waiting during autoFocus() // when the algorithm has already either converged or failed to. if (mOneshotAfCallback != null) { // A call to autoFocus() was just made to request a focus lock. // Notify the caller that the lens is now indefinitely fixed, // and report whether the image we're stuck with is in focus. mOneshotAfCallback.onAutoFocus( afState == CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED, mCameraProxy); mOneshotAfCallback = null; } break; } } } } Integer aeStateMaybe = result.get(CaptureResult.CONTROL_AE_STATE); if (aeStateMaybe != null) { int aeState = aeStateMaybe; // Since we handle both partial and total results for multiple frames here, we // might get the final callbacks for an earlier frame after receiving one or // more that correspond to the next one. To prevent our data from oscillating, // we never consider AE states that are older than the last one we've seen. if (result.getFrameNumber() > mLastAeFrameNumber) { mCurrentAeState = aeStateMaybe; mLastAeFrameNumber = result.getFrameNumber(); switch (aeState) { case CaptureResult.CONTROL_AE_STATE_CONVERGED: case CaptureResult.CONTROL_AE_STATE_FLASH_REQUIRED: case CaptureResult.CONTROL_AE_STATE_LOCKED: { // This check must be made regardless of whether the exposure state // has changed recently to avoid infinite waiting during // takePicture() when the algorithm has already converged. if (mOneshotCaptureCallback != null) { // A call to takePicture() was just made, and autoexposure // converged so it's time to initiate the capture! mCaptureReader.setOnImageAvailableListener( /*listener*/mOneshotCaptureCallback, /*handler*/Camera2Handler.this); try { mSession.capture( mPersistentSettings.createRequest(mCamera, CameraDevice.TEMPLATE_STILL_CAPTURE, mCaptureReader.getSurface()), /*callback*/mOneshotCaptureCallback, /*handler*/Camera2Handler.this); } catch (CameraAccessException ex) { Log.e(TAG, "Unable to initiate capture", ex); } finally { mOneshotCaptureCallback = null; } } break; } } } } }
Example 7
Source File: AutoFocusStateMachine.java From Camera2 with Apache License 2.0 | 4 votes |
/** * Invoke every time we get a new CaptureResult via * {@link CameraDevice.CaptureCallback#onCaptureCompleted}. * * <p>This function is responsible for dispatching updates via the * {@link AutoFocusStateListener} so without calling this on a regular basis, no * AF changes will be observed.</p> * * @param result CaptureResult */ public synchronized void onCaptureCompleted(CaptureResult result) { /** * Work-around for b/11269834 * Although these should never-ever happen, harden for ship */ if (result == null) { Log.w(TAG, "onCaptureCompleted - missing result, skipping AF update"); return; } Key<Integer> keyAfState = CaptureResult.CONTROL_AF_STATE; if (keyAfState == null) { Log.e(TAG, "onCaptureCompleted - missing android.control.afState key, " + "skipping AF update"); return; } Key<Integer> keyAfMode = CaptureResult.CONTROL_AF_MODE; if (keyAfMode == null) { Log.e(TAG, "onCaptureCompleted - missing android.control.afMode key, " + "skipping AF update"); return; } Integer afState = result.get(CaptureResult.CONTROL_AF_STATE); Integer afMode = result.get(CaptureResult.CONTROL_AF_MODE); /** * Work-around for b/11238865 * This is a HAL bug as these fields should be there always. */ if (afState == null) { Log.w(TAG, "onCaptureCompleted - missing android.control.afState !"); return; } else if (afMode == null) { Log.w(TAG, "onCaptureCompleted - missing android.control.afMode !"); return; } if (DEBUG_LOGGING) Log.d(TAG, "onCaptureCompleted - new AF mode = " + afMode + " new AF state = " + afState); if (mLastAfState == afState && afMode == mLastAfMode) { // Same AF state as last time, nothing else needs to be done. return; } if (VERBOSE_LOGGING) Log.v(TAG, "onCaptureCompleted - new AF mode = " + afMode + " new AF state = " + afState); mLastAfState = afState; mLastAfMode = afMode; switch (afState) { case CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED: mListener.onAutoFocusSuccess(result, /*locked*/true); endTraceAsync(); break; case CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: mListener.onAutoFocusFail(result, /*locked*/true); endTraceAsync(); break; case CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED: mListener.onAutoFocusSuccess(result, /*locked*/false); break; case CaptureResult.CONTROL_AF_STATE_PASSIVE_UNFOCUSED: mListener.onAutoFocusFail(result, /*locked*/false); break; case CaptureResult.CONTROL_AF_STATE_ACTIVE_SCAN: mListener.onAutoFocusScan(result); break; case CaptureResult.CONTROL_AF_STATE_PASSIVE_SCAN: mListener.onAutoFocusScan(result); break; case CaptureResult.CONTROL_AF_STATE_INACTIVE: mListener.onAutoFocusInactive(result); break; } }
Example 8
Source File: Camera2BasicFragment.java From opencv-documentscanner-android with Apache License 2.0 | 4 votes |
private void process(CaptureResult result) { int afState = result.get(CaptureResult.CONTROL_AF_STATE); if (CaptureResult.CONTROL_AF_STATE_PASSIVE_FOCUSED == afState) { areWeFocused = true; getActivity().runOnUiThread(new Runnable() { @Override public void run() { button.setBackgroundColor(getActivity().getResources().getColor(R.color.blue)); button.setText("Focused"); } }); } else { areWeFocused = false; getActivity().runOnUiThread(new Runnable() { @Override public void run() { button.setBackgroundColor(getActivity().getResources().getColor(R.color.colorAccent)); button.setText("Not focused"); } }); } if (shouldCapture) { if (areWeFocused) { shouldCapture = false; captureStillPicture(); } } // switch (mState) { // case STATE_PREVIEW: { // Log.d(TAG, "STATE_PREVIEW"); // // We have nothing to do when the camera preview is working normally. // break; // } // case STATE_WAITING_LOCK: { // Log.d(TAG, "STATE_WAITING_LOCK"); // Integer afState = result.get(CaptureResult.CONTROL_AF_STATE); // if (afState == null) { // captureStillPicture(); // } else if (CaptureResult.CONTROL_AF_STATE_FOCUSED_LOCKED == afState || // CaptureResult.CONTROL_AF_STATE_NOT_FOCUSED_LOCKED == afState || // CaptureResult.CONTROL_AF_STATE_INACTIVE == afState /*add this*/) { // Log.d(TAG, "STATE_WAITING_LOCK222"); // // CONTROL_AE_STATE can be null on some devices // Integer aeState = result.get(CaptureResult.CONTROL_AE_STATE); // if (aeState == null || aeState == CaptureResult.CONTROL_AE_STATE_CONVERGED) { // mState = STATE_PICTURE_TAKEN; // captureStillPicture(); // } else { // runPrecaptureSequence(); // } // } // break; // } // case STATE_WAITING_PRECAPTURE: { // Log.d(TAG, "STATE_WAITING_PRECAPTURE"); // // CONTROL_AE_STATE can be null on some devices // Integer aeState = result.get(CaptureResult.CONTROL_AE_STATE); // if (aeState == null || // aeState == CaptureResult.CONTROL_AE_STATE_PRECAPTURE || // aeState == CaptureRequest.CONTROL_AE_STATE_FLASH_REQUIRED) { // mState = STATE_WAITING_NON_PRECAPTURE; // } // break; // } // case STATE_WAITING_NON_PRECAPTURE: { // Log.d(TAG, "STATE_WAITING_NON_PRECAPTURE"); // // CONTROL_AE_STATE can be null on some devices // Integer aeState = result.get(CaptureResult.CONTROL_AE_STATE); // if (aeState == null || aeState != CaptureResult.CONTROL_AE_STATE_PRECAPTURE) { // mState = STATE_PICTURE_TAKEN; // captureStillPicture(); // } // break; // } // } }