关于侧滑栏的步骤SlideMenu

时间:2021-03-15 15:32:51
关于侧滑栏的步骤SlideMenu=====================侧滑菜单============================
1.自定义SlideMenu,继承自ViewGroup


2.编写menu和main界面的布局,然后include到SlideMenu中,作为它的子view


3.在onFinishInflate方法中通过getChildAt(0)来初始化menuView和mainView对象


4.在onSizeChanged方法中获取menuView和mainView的宽高


5.自己实现onMeasure方法,主要了解测量规则MeasureSpec如果创建,以及三种测量mode的含义


6.由于自己实现onMeasure方法太麻烦和繁琐,最后将SlideMenu继承自FrameLayout,原因如下:
  a.因为FrameLayout帮我们实现了onMeasure方法,不需要我们自己实现
  b.因为FrameLayout代码最少,在四大布局中属于轻量级
  
7.由于FrameLayout是按照自己的方式实现onLayout方法,而我们的需求是将menuView放在屏幕左边,
  所以需要自己重写onLayout方法:
  menuView.layout(-menuWidth, 0, 0, menuHeight);
  mainView.layout(0, 0, mainWidth, menuHeight);
  
8.当TouchMove的时候让SlideMenu跟随手指滑动
  tip1:在ViewGorup中让子view移动的方法:
     layout(l,t,r,b);
offsetTopAndBottom(offset)和offsetLeftAndRight(offset);
scrollTo和scrollBy;
 
  tip2:scrollTo和scrollBy表示的不是view本身的移动,而是指屏幕的移动
  a.在onTouchEvent方法中计算出手指移动的距离
  b.根据手指移动的距离和当前屏幕已经滚动的scrollX的坐标算出新的scrollX:
    int newScrollX = (int) (getScrollX()-deltaX);
  c.对SlideMenu进行左边和右边的限定
    if(newScrollX<-menuWidth){
newScrollX = -menuWidth;//限制左边
}
if(newScrollX>0){
newScrollX = 0;//限制右边
}
  
9.当TouchUp的时候缓慢滑动SlideMenu到指定位置
   tip3:Scroller: 是用来模拟滚动的,模拟了一个滚动的流程,然后在滚动过程中也计算好了当前应该
               滚动的scrollX和scrollY。
  我们需要在它的执行过程中获得当前的scrollX和scrollY,然后自己去scrollTo(scrollX,scrollY);
   a.使用Scroller处理缓慢滚动:
     scroller.startScroll(getScrollX(), 0, 0-getScrollX(), 0,400);
// Invalidate to request a redraw
invalidate();
   b.在computeScroll方法中不断获取当前的currX和currY,然后自己去scrollTo
    if(scroller.computeScrollOffset()){//如果返回true,表示动画没有结束,反之就结束
scrollTo(scroller.getCurrX(), scroller.getCurrY());
invalidate();
}

10.此时出现滑动bug,当在menu中的ScrollView中水平滑动时无法滑动SlideMenu,
  a.根据触摸事件的传递机制分析原因,传递机制详情见图
  b.只要我们拦截触摸事件,就会将Event传给onTouchEvent,从而可以滑动
  c.但是我们要在一定条件下才能拦截,在move的方向偏于水平方向的时候拦截
  d.在onInterceptTouchEvent方法中计算x和y方向的移动距离,并比较是偏于水平还是垂直