rely on GestureDetector at detecting focus clicks

This commit is contained in:
tibbi 2020-04-21 22:33:25 +02:00
parent fab62ee3b8
commit ca273da40e

View File

@ -19,10 +19,7 @@ import android.util.DisplayMetrics
import android.util.Range import android.util.Range
import android.util.Size import android.util.Size
import android.util.SparseIntArray import android.util.SparseIntArray
import android.view.MotionEvent import android.view.*
import android.view.Surface
import android.view.TextureView
import android.view.ViewGroup
import android.widget.Toast import android.widget.Toast
import com.simplemobiletools.camera.R import com.simplemobiletools.camera.R
import com.simplemobiletools.camera.activities.MainActivity import com.simplemobiletools.camera.activities.MainActivity
@ -49,8 +46,6 @@ class CameraPreview : ViewGroup, TextureView.SurfaceTextureListener, MyPreview {
private val MAX_PREVIEW_HEIGHT = 1080 private val MAX_PREVIEW_HEIGHT = 1080
private val MAX_VIDEO_WIDTH = 4096 private val MAX_VIDEO_WIDTH = 4096
private val MAX_VIDEO_HEIGHT = 2160 private val MAX_VIDEO_HEIGHT = 2160
private val CLICK_MS = 250
private val CLICK_DIST = 20
private val DEFAULT_ORIENTATIONS = SparseIntArray(4).apply { private val DEFAULT_ORIENTATIONS = SparseIntArray(4).apply {
append(Surface.ROTATION_0, 90) append(Surface.ROTATION_0, 90)
@ -73,9 +68,6 @@ class CameraPreview : ViewGroup, TextureView.SurfaceTextureListener, MyPreview {
private var mRotationAtCapture = 0 private var mRotationAtCapture = 0
private var mZoomLevel = 1 private var mZoomLevel = 1
private var mZoomFingerSpacing = 0f private var mZoomFingerSpacing = 0f
private var mDownEventAtMS = 0L
private var mDownEventAtX = 0f
private var mDownEventAtY = 0f
private var mLastFocusX = 0f private var mLastFocusX = 0f
private var mLastFocusY = 0f private var mLastFocusY = 0f
private var mIsFlashSupported = true private var mIsFlashSupported = true
@ -124,22 +116,17 @@ class CameraPreview : ViewGroup, TextureView.SurfaceTextureListener, MyPreview {
mIsInVideoMode = !initPhotoMode mIsInVideoMode = !initPhotoMode
loadSounds() loadSounds()
mTextureView.setOnTouchListener { view, event -> val gestureDetector = GestureDetector(context, object : GestureDetector.SimpleOnGestureListener() {
if (event.action == MotionEvent.ACTION_DOWN) { override fun onSingleTapConfirmed(e: MotionEvent?): Boolean {
mDownEventAtMS = System.currentTimeMillis() if (e != null && mIsFocusSupported && mCaptureSession != null) {
mDownEventAtX = event.x focusArea(e.rawX, e.rawY, true)
mDownEventAtY = event.y
} else if (event.action == MotionEvent.ACTION_UP) {
if (mIsFocusSupported && System.currentTimeMillis() - mDownEventAtMS < CLICK_MS &&
mCaptureSession != null &&
Math.abs(event.x - mDownEventAtX) < CLICK_DIST &&
Math.abs(event.y - mDownEventAtY) < CLICK_DIST) {
try {
focusArea(event.x, event.y, true)
} catch (e: Exception) {
}
} }
return true
} }
})
mTextureView.setOnTouchListener { view, event ->
gestureDetector.onTouchEvent(event)
if (mIsZoomSupported && event.pointerCount > 1 && mCaptureSession != null) { if (mIsZoomSupported && event.pointerCount > 1 && mCaptureSession != null) {
try { try {