实现打开抽屉 主界面侧移动画

使用DrawerLayout,当手指侧滑时,左侧抽屉菜单会覆盖中间布局,中间布局不会随手指拖动而移动。

要实现主界面跟随移动就需要监听drawer滑动事件。

DrawerLayout(this).addDrawerListener(object :DrawerLayout.DrawerListener{
            override fun onDrawerSlide(drawerView: View, slideOffset: Float) {
            }
            override fun onDrawerStateChanged(newState: Int) = Unit

            override fun onDrawerClosed(drawerView: View) = Unit

            override fun onDrawerOpened(drawerView: View) = Unit
        })
复制代码

在DrawerLayout的监听事件onDrawerSlide回调中对其进行操作,slideOffset是滑动的偏移值:会在0~1之间变化

override fun onDrawerSlide(drawerView: View, slideOffset: Float) {
                //设置主布局随菜单滑动
                val width = drawerView.width
                main_root.translationX = width * slideOffset

                //设置控件最先出现的位置
                val paddingLeft = width * (1-0.618) * (1- slideOffset)
                drawerView.setPadding(paddingLeft.toInt(),0,0,0)
            }
复制代码

如果使用materialdrawer库的话也是一样的

DrawerBuilder()
                .withActivity(this)
                .withDrawerWidthDp(270)
                .withOnDrawerListener(object :Drawer.OnDrawerListener{
                    override fun onDrawerClosed(drawerView: View?) = Unit

                    override fun onDrawerSlide(drawerView: View, slideOffset: Float) {
                        //设置主布局随菜单滑动
                        val width = drawerView.width
                        main_root.translationX = width * slideOffset

                        //设置控件最先出现的位置
                        val paddingLeft = width * (1-0.618) * (1- slideOffset)
                        drawerView.setPadding(paddingLeft.toInt(),0,0,0)

                    }

                    override fun onDrawerOpened(drawerView: View?) = Unit
                })
复制代码

转载于:https://juejin.im/post/5cc6c10ee51d456e7c0cdb9e

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值