在 Kotlin 中实现滑动手势

13

我正在尝试在Kotlin编写的应用程序中实现手势检测器。 我正在遵循这个问题中的评论:链接

因此,我创建了OnSwipeTouchListener类,并在我的类中实现了该监听器:

class DetailActivity : AppCompatActivity() {

override fun onBackPressed() {
    super.onBackPressed()
}

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.detail_activity)
    window.decorView.setOnTouchListener(object: OnSwipeTouchListener(this@DetailActivity) {
        override fun onSwipeLeft() {
            onBackPressed()
        }
        override fun onSwipeRight() {
            onBackPressed()
        }
    })
}

问题在于它无法被识别,也没有任何错误提示。我尝试使用Log.i检查程序是否进入了这两个覆盖方法,但没有打印任何内容。这可能是一个View问题吗?

编辑:这是监听器代码:

    open class OnSwipeTouchListener(ctx: Context) : OnTouchListener {

    private val gestureDetector: GestureDetector

    companion object {

        private val SWIPE_THRESHOLD = 100
        private val SWIPE_VELOCITY_THRESHOLD = 100
    }

    init {
        gestureDetector = GestureDetector(ctx, GestureListener())
    }

    override fun onTouch(v: View, event: MotionEvent): Boolean {
        return gestureDetector.onTouchEvent(event)
    }

    private inner class GestureListener : SimpleOnGestureListener() {


        override fun onDown(e: MotionEvent): Boolean {
            return true
        }

        override fun onFling(e1: MotionEvent, e2: MotionEvent, velocityX: Float, velocityY: Float): Boolean {
            var result = false
            try {
                val diffY = e2.y - e1.y
                val diffX = e2.x - e1.x
                if (Math.abs(diffX) > Math.abs(diffY)) {
                    if (Math.abs(diffX) > SWIPE_THRESHOLD && Math.abs(velocityX) > SWIPE_VELOCITY_THRESHOLD) {
                        if (diffX > 0) {
                            onSwipeRight()
                        } else {
                            onSwipeLeft()
                        }
                        result = true
                    }
                } else if (Math.abs(diffY) > SWIPE_THRESHOLD && Math.abs(velocityY) > SWIPE_VELOCITY_THRESHOLD) {
                    if (diffY > 0) {
                        onSwipeBottom()
                    } else {
                        onSwipeTop()
                    }
                    result = true
                }
            } catch (exception: Exception) {
                exception.printStackTrace()
            }

            return result
        }


    }

    open fun onSwipeRight() {}

    open fun onSwipeLeft() {}

    open fun onSwipeTop() {}

    open fun onSwipeBottom() {}
}

似乎将onTouchListener设置到装饰视图可能会有问题。你尝试在活动根视图或其他视图上设置OnSwipeTouchListener了吗? - Demigod
是的,我在另外两个主要活动上尝试了一下,但是问题依旧存在。我也尝试在我的四个片段中实现它,但是当我将上下文作为参数传递时,出现了错误。 - Babbara
你能发布滑动监听器代码吗? - Jayanth
@Jayanth,我已经更新了问题并附上了代码。 - Babbara
1个回答

10

我按照以下方法尝试了你的代码:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/main">

</androidx.constraintlayout.widget.ConstraintLayout>

main.setOnTouchListener(object: OnSwipeTouchListener(this@Main3Activity) {
        override fun onSwipeLeft() {
            onBackPressed()
        }
        override fun onSwipeRight() {
            onBackPressed()
        }
    })

它有效。可能问题在于decorview。


这里的 main 变量是什么? - Matt Ellis

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接