仿写Android控件SlidingMenu 简单仿写Android控件SlidingMenu的实例代码

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

仿写Android控件SlidingMenu 简单仿写Android控件SlidingMenu的实例代码

MG_ZXC   2021-03-28 我要评论
想了解简单仿写Android控件SlidingMenu的实例代码的相关内容吗,MG_ZXC在本文为您仔细讲解仿写Android控件SlidingMenu的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Android,控件,SlidingMenu,下面大家一起来学习吧。

SlidingMenu (侧滑菜单形式)在android开发过程中,经常用到,这次我们通过一个简单案例来仿写SlidingMenu 的大体功能,下面 是主要实现的代码:

java代码:(重写onTouchEvent方法 处理侧滑菜单处的事件分发机制)

public class SlidingMenu extends ViewGroup implements OnClickListener {
 private View menu;
 private View main;
 private int menuWidth;
 private int downX;
 private Scroller mScroller;
 private ImageView iv_back;
 // 加载阶段,先加载自身,然后再加载孩子
 public SlidingMenu(Context context, AttributeSet attrs) {
  super(context, attrs);
  mScroller=new Scroller(context);//声明Scroller进行滚动
 }
 // 结束加载的回调
 @Override
 protected void onFinishInflate() {
  super.onFinishInflate();
  menu = getChildAt(0);
  main = getChildAt(1);
  menuWidth = menu.getLayoutParams().width;
  Log.i("test", "menuWidth:" + menuWidth);
  iv_back = (ImageView) findViewById(R.id.iv_back);
  iv_back.setOnClickListener(this);
 }
 // 默认ViewGroup只测量自身,并不测量自身的孩子
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  super.onMeasure(widthMeasureSpec, heightMeasureSpec);
  // 将onMeasure中的两个参数直接传给两个孩子
  menu.measure(widthMeasureSpec, heightMeasureSpec);
  main.measure(widthMeasureSpec, heightMeasureSpec);
 }
 // 布局
 // 参数1,2,3,4:左上右下
 @Override
 protected void onLayout(boolean changed, int l, int t, int r, int b) {
  menu.layout(-menuWidth, t, 0, b);
  main.layout(l, t, r, b);
 }
 @Override
 public boolean onTouchEvent(MotionEvent event) {
  switch (event.getAction()) {
  case MotionEvent.ACTION_DOWN:
   downX = (int) event.getX();
   break;
  case MotionEvent.ACTION_MOVE:
   int moveX = (int) event.getX();
   int dX = moveX - downX;
   // scrollTo(x, y);//绝对移动
   // scrollBy(x, y);//相对移动
   // 获取滚动的坐标
   int scrollX = getScrollX();
   Log.i("test", "scrollX:" + scrollX);
   if (scrollX - dX >= -200 && scrollX - dX <= 0) {
    scrollBy(-dX, 0);
   }
   downX = moveX;
   break;
  case MotionEvent.ACTION_UP:
   int upScrollX = getScrollX();
   Log.i("test", "upScrollX:"+upScrollX);
   int dScrollX;
   if(upScrollX>-menuWidth/2){
    //收回去
    dScrollX=-upScrollX;
    isOpen=false;
   }else{
    //展开
    dScrollX=-menuWidth-upScrollX;
    isOpen=true;
   }
   Log.i("test", "dScrollX:"+dScrollX);
   mScroller.startScroll(upScrollX, 0, dScrollX, 0,20*dScrollX);
   //滚动后,要让界面重绘
   invalidate();
   break;
  default:
   break;
  }
  return true;
 }
 @Override
 public void computeScroll() {
  super.computeScroll();
  //调用这个方法来获取期望的滚动点,如果返回true,表示动画还没有执行完成
  if(mScroller.computeScrollOffset()){
   //用Scroller滚动,获取下一个期望的滚动点,滚动过去
   //获取期望点的滚动坐标
   int currX = mScroller.getCurrX();
   scrollTo(currX, 0);
   invalidate();
  }
 }
 private boolean isOpen;
 @Override
 public void onClick(View v) {
  switch (v.getId()) {
  case R.id.iv_back:
   int startX;
   int dx;
   if(!isOpen){
    startX=0;
    dx=-menuWidth;
   }else{
    startX=-menuWidth;
    dx=menuWidth;
   }
   isOpen=!isOpen;
   mScroller.startScroll(startX, 0, dx, 0, 2000);
   invalidate();
   break;
  default:
   break;
  }
 }
}

activity布局文件:

<mgzxc.myslidmenu.MySlidMenu
  android:layout_width="match_parent"
  android:layout_height="match_parent">
  <include layout="@layout/menu_layout" />
  <include layout="@layout/main_layout" />
 </mgzxc.myslidmenu.MySlidMenu>

主界面的布局文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:gravity="center"
 android:background="@android:color/holo_blue_bright"
 android:layout_width="match_parent" android:layout_height="match_parent">
  <Button
   android:id="@+id/open"
   android:text="打开"
   android:textSize="30sp"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content" />
</RelativeLayout>

最终效果如下:

以上这篇简单仿写Android控件SlidingMenu的实例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

猜您喜欢

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们