首先我们看下面视图:





  ![](http://img1.tuicool.com/yyqeQv.png)      ![](http://img0.tuicool.com/mYVFFr.png)





  这种效果大家都不陌生,网上好多都说是仿人人网的,估计人家牛逼出来的早吧,我也参考了一一些例子,实现起来有三种方法,我下面简单介绍下:





  方法一: 其实就是对GestureDetector手势的应用及布局文件的设计 .





  布局文件main.xml    采用RelativeLayout布局.



```

<?xml version=“1.0” encoding=“utf-8”?> <RelativeLayout xmlns:android=http://schemas.android.com/apk/res/android" android:layout_width=“fill_parent” android:layout_height=“fill_parent” android:orientation=“vertical” >

<span class="tag">&lt;<span class="title">LinearLayout

android:id=”@+id/layout_right" android:layout_width=“fill_parent” android:layout_height=“fill_parent” android:layout_marginLeft=“50dp” android:orientation=“vertical” >

    <span class="tag">&lt;<span class="title">AbsoluteLayout

android:layout_width=“fill_parent” android:layout_height=“wrap_content” android:background="@color/grey21" android:padding=“10dp” >

        <span class="tag">&lt;<span class="title">TextView

android:layout_width=“wrap_content” android:layout_height=“wrap_content” android:text=“设置” android:textColor="@android:color/background_light" android:textSize=“20sp” /> </AbsoluteLayout>

    <span class="tag">&lt;<span class="title">ListView

android:id="@+id/lv_set" android:layout_width=“fill_parent” android:layout_height=“fill_parent” android:layout_weight=“1” > </ListView> </LinearLayout>

<span class="tag">&lt;<span class="title">LinearLayout

android:id="@+id/layout_left" android:layout_width=“fill_parent” android:layout_height=“fill_parent” android:background="@color/white" android:orientation=“vertical” >

    <span class="tag">&lt;<span class="title">RelativeLayout

android:layout_width=“fill_parent” android:layout_height=“wrap_content” android:background="@drawable/nav_bg" >

        <span class="tag">&lt;<span class="title">ImageView

android:id="@+id/iv_set" android:layout_width=“wrap_content” android:layout_height=“wrap_content” android:layout_alignParentRight=“true” android:layout_alignParentTop=“true” android:src="@drawable/nav_setting" />

        <span class="tag">&lt;<span class="title">TextView

android:layout_width=“wrap_content” android:layout_height=“wrap_content” android:layout_centerInParent=“true” android:text=“我” android:textColor="@android:color/background_light" android:textSize=“20sp” /> </RelativeLayout>

    <span class="tag">&lt;<span class="title">ImageView

android:id="@+id/iv_set" android:layout_width=“fill_parent” android:layout_height=“fill_parent” android:scaleType=“fitXY” android:src="@drawable/bg_guide_5" /> </LinearLayout>

</RelativeLayout>

    
    

      ![](http://img0.tuicool.com/QfYjYf.png)layout_right :这个大布局文件, layout_left:距离左边50dp像素.(我们要移动的是 layout_left ).
    

    
    

      看到这个图我想大家都很清晰了吧,其实: 我们就是把layout_left这个布局控件整理向左移动,至于移动多少,就要看layout_right有多宽了。layout_left移动到距离左边的边距就是layout_right的宽及-MAX_WIDTH.相信大家都理解.
    

    
    

      布局文件就介绍到这里,下面看代码.
    

    
    ```
<span class="javadoc">/***
   * 初始化view
   */</span>
  <span class="keyword">void</span> InitView() {
    layout_left = (LinearLayout) findViewById(R.id.layout_left);
    layout_right = (LinearLayout) findViewById(R.id.layout_right);
    iv_set = (ImageView) findViewById(R.id.iv_set);
    lv_set = (ListView) findViewById(R.id.lv_set);
    lv_set.setAdapter(<span class="keyword">new</span> ArrayAdapter&lt;String&gt;(<span class="keyword">this</span>, R.layout.item,
        R.id.tv_item, title));
    lv_set.setOnItemClickListener(<span class="keyword">new</span> OnItemClickListener() {

      <span class="annotation">@Override</span>
      <span class="keyword">public</span> <span class="keyword">void</span> onItemClick(AdapterView&lt;?&gt; parent, View view,
          <span class="keyword">int</span> position, <span class="keyword">long</span> id) {
        Toast.makeText(MainActivity.<span class="keyword">this</span>, title[position], <span class="number">1</span>).show();
      }
    });
    layout_left.setOnTouchListener(<span class="keyword">this</span>);
    iv_set.setOnTouchListener(<span class="keyword">this</span>);
    mGestureDetector = <span class="keyword">new</span> GestureDetector(<span class="keyword">this</span>);
    <span class="comment">// 禁用长按监听</span>
    mGestureDetector.setIsLongpressEnabled(<span class="keyword">false</span>);
    getMAX_WIDTH();
  }
  这里要对手势进行监听,我想大家都知道怎么做,在这里我要说明一个方法:



```

/***

  • 获取移动距离 移动的距离其实就是layout_left的宽度 */ void getMAX_WIDTH() { ViewTreeObserver viewTreeObserver = layout_left.getViewTreeObserver(); // 获取控件宽度 viewTreeObserver.addOnPreDrawListener(new OnPreDrawListener() { @Override public boolean onPreDraw() { if (!hasMeasured) { window_width = getWindowManager().getDefaultDisplay() .getWidth(); RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout_left .getLayoutParams(); layoutParams.width = window_width; layout_left.setLayoutParams(layoutParams); MAX_WIDTH = layout_right.getWidth(); Log.v(TAG, “MAX_WIDTH=" + MAX_WIDTH + “width=" + window_width); hasMeasured = true; } return true; } });

}

    
    

      在这里我们要获取屏幕的宽度,并将屏幕宽度设置给layout_left这个控件,为什么要这么做呢 , 因为如果不把该控件宽度写死的话,那么系统将认为layout_left会根据不同环境宽度自动适应,也就是说我们通过layout_left.getLayoutParams动态移动该控件的时候,该控件会伸缩而不是移动。 描述的有点模糊,大家请看下面示意图就明白了.
    

    
    

      我们不为 layout_left定义死宽度效果:
    

    
    

      ![](http://img1.tuicool.com/ziAjIr.png)      ![](http://img0.tuicool.com/VrqI32.png)
    

    
    

      getLayoutParams可以很清楚看到, layout_left被向左拉伸了,并不是我们要的效果.
    

    
    

      还有一种解决办法就是我们在配置文件中直接把 layout_left宽度写死,不过这样不利于开发,因为分辨率的问题.因此就用 ViewTreeObserver进行对 layout_left设置宽度.
    

    
    

      ViewTreeObserver,这个类主要用于对布局文件的监听.强烈建议同学们参考这篇文章  [android ViewTreeObserver详细讲解](http://blog.csdn.net/jj120522/article/details/8097133),相信让你对ViewTreeObserver有更一步的了解.其他的就是对 GestureDetector手势的应用,下面我把代码贴出来:
    

    
    ```
<span class="keyword">package</span> com.jj.slidingmenu;

<span class="keyword">import</span> android.app.Activity;
<span class="keyword">import</span> android.os.AsyncTask;
<span class="keyword">import</span> android.os.Bundle;
<span class="keyword">import</span> android.util.Log;
<span class="keyword">import</span> android.view.GestureDetector;
<span class="keyword">import</span> android.view.KeyEvent;
<span class="keyword">import</span> android.view.MotionEvent;
<span class="keyword">import</span> android.view.View;
<span class="keyword">import</span> android.view.ViewTreeObserver;
<span class="keyword">import</span> android.view.ViewTreeObserver.OnPreDrawListener;
<span class="keyword">import</span> android.view.Window;
<span class="keyword">import</span> android.view.View.OnTouchListener;
<span class="keyword">import</span> android.widget.AdapterView;
<span class="keyword">import</span> android.widget.AdapterView.OnItemClickListener;
<span class="keyword">import</span> android.widget.ArrayAdapter;
<span class="keyword">import</span> android.widget.ImageView;
<span class="keyword">import</span> android.widget.LinearLayout;
<span class="keyword">import</span> android.widget.ListView;
<span class="keyword">import</span> android.widget.RelativeLayout;
<span class="keyword">import</span> android.widget.Toast;
<span class="keyword">import</span> android.widget.LinearLayout.LayoutParams;

<span class="javadoc">/***
 * 滑动菜单
 * 
 * <span class="javadoctag">@author</span> jjhappyforever...
 * 
 */</span>
<span class="keyword">public</span> <span class="class"><span class="keyword">class</span> <span class="title">MainActivity</span> <span class="keyword">extends</span> <span class="title">Activity</span> <span class="keyword">implements</span> <span class="title">OnTouchListener</span>,
    <span class="title">GestureDetector</span>.<span class="title">OnGestureListener</span> {</span>
  <span class="keyword">private</span> <span class="keyword">boolean</span> hasMeasured = <span class="keyword">false</span>;<span class="comment">// 是否Measured.</span>
  <span class="keyword">private</span> LinearLayout layout_left;
  <span class="keyword">private</span> LinearLayout layout_right;
  <span class="keyword">private</span> ImageView iv_set;
  <span class="keyword">private</span> ListView lv_set;

  <span class="javadoc">/** 每次自动展开/收缩的范围 */</span>
  <span class="keyword">private</span> <span class="keyword">int</span> MAX_WIDTH = <span class="number"></span>;
  <span class="javadoc">/** 每次自动展开/收缩的速度 */</span>
  <span class="keyword">private</span> <span class="keyword">final</span> <span class="keyword">static</span> <span class="keyword">int</span> SPEED = <span class="number">30</span>;

  <span class="keyword">private</span> GestureDetector mGestureDetector;<span class="comment">// 手势</span>
  <span class="keyword">private</span> <span class="keyword">boolean</span> isScrolling = <span class="keyword">false</span>;
  <span class="keyword">private</span> <span class="keyword">float</span> mScrollX; <span class="comment">// 滑块滑动距离</span>
  <span class="keyword">private</span> <span class="keyword">int</span> window_width;<span class="comment">// 屏幕的宽度</span>

  <span class="keyword">private</span> String TAG = <span class="string">"jj"</span>;

  <span class="keyword">private</span> String title[] = { <span class="string">"待发送队列"</span>, <span class="string">"同步分享设置"</span>, <span class="string">"编辑我的资料"</span>, <span class="string">"找朋友"</span>, <span class="string">"告诉朋友"</span>,
      <span class="string">"节省流量"</span>, <span class="string">"推送设置"</span>, <span class="string">"版本更新"</span>, <span class="string">"意见反馈"</span>, <span class="string">"积分兑换"</span>, <span class="string">"精品应用"</span>, <span class="string">"常见问题"</span>, <span class="string">"退出当前帐号"</span> };

  <span class="javadoc">/***
   * 初始化view
   */</span>
  <span class="keyword">void</span> InitView() {
    layout_left = (LinearLayout) findViewById(R.id.layout_left);
    layout_right = (LinearLayout) findViewById(R.id.layout_right);
    iv_set = (ImageView) findViewById(R.id.iv_set);
    lv_set = (ListView) findViewById(R.id.lv_set);
    lv_set.setAdapter(<span class="keyword">new</span> ArrayAdapter&lt;String&gt;(<span class="keyword">this</span>, R.layout.item,
        R.id.tv_item, title));
    lv_set.setOnItemClickListener(<span class="keyword">new</span> OnItemClickListener() {

      <span class="annotation">@Override</span>
      <span class="keyword">public</span> <span class="keyword">void</span> onItemClick(AdapterView&lt;?&gt; parent, View view,
          <span class="keyword">int</span> position, <span class="keyword">long</span> id) {
        Toast.makeText(MainActivity.<span class="keyword">this</span>, title[position], <span class="number">1</span>).show();
      }
    });
    layout_left.setOnTouchListener(<span class="keyword">this</span>);
    iv_set.setOnTouchListener(<span class="keyword">this</span>);
    mGestureDetector = <span class="keyword">new</span> GestureDetector(<span class="keyword">this</span>);
    <span class="comment">// 禁用长按监听</span>
    mGestureDetector.setIsLongpressEnabled(<span class="keyword">false</span>);
    getMAX_WIDTH();
  }

  <span class="javadoc">/***
   * 获取移动距离 移动的距离其实就是layout_left的宽度
   */</span>
  <span class="keyword">void</span> getMAX_WIDTH() {
    ViewTreeObserver viewTreeObserver = layout_left.getViewTreeObserver();
    <span class="comment">// 获取控件宽度</span>
    viewTreeObserver.addOnPreDrawListener(<span class="keyword">new</span> OnPreDrawListener() {
      <span class="annotation">@Override</span>
      <span class="keyword">public</span> <span class="keyword">boolean</span> onPreDraw() {
        <span class="keyword">if</span> (!hasMeasured) {
          window_width = getWindowManager().getDefaultDisplay()
              .getWidth();
          RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout_left
              .getLayoutParams();
          <span class="comment">// layoutParams.width = window_width;</span>
          layout_left.setLayoutParams(layoutParams);
          MAX_WIDTH = layout_right.getWidth();
          Log.v(TAG, <span class="string">"MAX_WIDTH="</span> + MAX_WIDTH + <span class="string">"width="</span>
              + window_width);
          hasMeasured = <span class="keyword">true</span>;
        }
        <span class="keyword">return</span> <span class="keyword">true</span>;
      }
    });

  }

  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">void</span> onCreate(Bundle savedInstanceState) {
    <span class="keyword">super</span>.onCreate(savedInstanceState);
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    setContentView(R.layout.main);
    InitView();

  }

  <span class="comment">// 返回键</span>
  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">boolean</span> onKeyDown(<span class="keyword">int</span> keyCode, KeyEvent event) {
    <span class="keyword">if</span> (KeyEvent.KEYCODE_BACK == keyCode && event.getRepeatCount() == <span class="number"></span>) {
      RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout_left
          .getLayoutParams();
      <span class="keyword">if</span> (layoutParams.leftMargin &lt; <span class="number"></span>) {
        <span class="keyword">new</span> AsynMove().execute(SPEED);
        <span class="keyword">return</span> <span class="keyword">false</span>;
      }
    }

    <span class="keyword">return</span> <span class="keyword">super</span>.onKeyDown(keyCode, event);
  }

  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">boolean</span> onTouch(View v, MotionEvent event) {
    <span class="comment">// 松开的时候要判断,如果不到半屏幕位子则缩回去,</span>
    <span class="keyword">if</span> (MotionEvent.ACTION_UP == event.getAction() && isScrolling == <span class="keyword">true</span>) {
      RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout_left
          .getLayoutParams();
      <span class="comment">// 缩回去</span>
      <span class="keyword">if</span> (layoutParams.leftMargin &lt; -window_width / <span class="number">2</span>) {
        <span class="keyword">new</span> AsynMove().execute(-SPEED);
      } <span class="keyword">else</span> {
        <span class="keyword">new</span> AsynMove().execute(SPEED);
      }
    }

    <span class="keyword">return</span> mGestureDetector.onTouchEvent(event);
  }

  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">boolean</span> onDown(MotionEvent e) {
    mScrollX = <span class="number"></span>;
    isScrolling = <span class="keyword">false</span>;
    <span class="comment">// 将之改为true,不然事件不会向下传递.</span>
    <span class="keyword">return</span> <span class="keyword">true</span>;
  }

  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">void</span> onShowPress(MotionEvent e) {

  }

  <span class="javadoc">/***
   * 点击松开执行
   */</span>
  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">boolean</span> onSingleTapUp(MotionEvent e) {
    RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout_left
        .getLayoutParams();
    <span class="comment">// 左移动</span>
    <span class="keyword">if</span> (layoutParams.leftMargin &gt;= <span class="number"></span>) {
      <span class="keyword">new</span> AsynMove().execute(-SPEED);
    } <span class="keyword">else</span> {
      <span class="comment">// 右移动</span>
      <span class="keyword">new</span> AsynMove().execute(SPEED);
    }

    <span class="keyword">return</span> <span class="keyword">true</span>;
  }

  <span class="javadoc">/***
   * e1 是起点,e2是终点,如果distanceX=e1.x-e2.x&gt;0说明向左滑动。反之亦如此.
   */</span>
  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">boolean</span> onScroll(MotionEvent e1, MotionEvent e2, <span class="keyword">float</span> distanceX,
      <span class="keyword">float</span> distanceY) {
    isScrolling = <span class="keyword">true</span>;
    mScrollX += distanceX;<span class="comment">// distanceX:向左为正,右为负</span>
    RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout_left
        .getLayoutParams();
    layoutParams.leftMargin -= mScrollX;
    <span class="keyword">if</span> (layoutParams.leftMargin &gt;= <span class="number"></span>) {
      isScrolling = <span class="keyword">false</span>;<span class="comment">// 拖过头了不需要再执行AsynMove了</span>
      layoutParams.leftMargin = <span class="number"></span>;

    } <span class="keyword">else</span> <span class="keyword">if</span> (layoutParams.leftMargin &lt;= -MAX_WIDTH) {
      <span class="comment">// 拖过头了不需要再执行AsynMove了</span>
      isScrolling = <span class="keyword">false</span>;
      layoutParams.leftMargin = -MAX_WIDTH;
    }
    layout_left.setLayoutParams(layoutParams);
    <span class="keyword">return</span> <span class="keyword">false</span>;
  }

  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">void</span> onLongPress(MotionEvent e) {

  }

  <span class="annotation">@Override</span>
  <span class="keyword">public</span> <span class="keyword">boolean</span> onFling(MotionEvent e1, MotionEvent e2, <span class="keyword">float</span> velocityX,
      <span class="keyword">float</span> velocityY) {
    <span class="keyword">return</span> <span class="keyword">false</span>;
  }

  <span class="class"><span class="keyword">class</span> <span class="title">AsynMove</span> <span class="keyword">extends</span> <span class="title">AsyncTask</span>&lt;<span class="title">Integer</span>, <span class="title">Integer</span>, <span class="title">Void</span>&gt; {</span>

    <span class="annotation">@Override</span>
    <span class="keyword">protected</span> Void doInBackground(Integer... params) {
      <span class="keyword">int</span> times = <span class="number"></span>;
      <span class="keyword">if</span> (MAX_WIDTH % Math.abs(params[<span class="number"></span>]) == <span class="number"></span>)<span class="comment">// 整除</span>
        times = MAX_WIDTH / Math.abs(params[<span class="number"></span>]);
      <span class="keyword">else</span>
        times = MAX_WIDTH / Math.abs(params[<span class="number"></span>]) + <span class="number">1</span>;<span class="comment">// 有余数</span>

      <span class="keyword">for</span> (<span class="keyword">int</span> i = <span class="number"></span>; i &lt; times; i++) {
        publishProgress(params[<span class="number"></span>]);
        <span class="keyword">try</span> {
          Thread.sleep(Math.abs(params[<span class="number"></span>]));
        } <span class="keyword">catch</span> (InterruptedException e) {
          e.printStackTrace();
        }
      }

      <span class="keyword">return</span> <span class="keyword">null</span>;
    }

    <span class="javadoc">/**
     * update UI
     */</span>
    <span class="annotation">@Override</span>
    <span class="keyword">protected</span> <span class="keyword">void</span> onProgressUpdate(Integer... values) {
      RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) layout_left
          .getLayoutParams();
      <span class="comment">// 右移动</span>
      <span class="keyword">if</span> (values[<span class="number"></span>] &gt; <span class="number"></span>) {
        layoutParams.leftMargin = Math.min(layoutParams.leftMargin
            + values[<span class="number"></span>], <span class="number"></span>);
        Log.v(TAG, <span class="string">"移动右"</span> + layoutParams.rightMargin);
      } <span class="keyword">else</span> {
        <span class="comment">// 左移动</span>
        layoutParams.leftMargin = Math.max(layoutParams.leftMargin
            + values[<span class="number"></span>], -MAX_WIDTH);
        Log.v(TAG, <span class="string">"移动左"</span> + layoutParams.rightMargin);
      }
      layout_left.setLayoutParams(layoutParams);

    }

  }

}
  上面代码注释已经很明确,相信大家都看的明白,我就不过多解释了。效果图: 截屏出来有点卡,不过在手机虚拟机上是不卡的.





  ![](http://img0.tuicool.com/ziuuUn.gif)





  [源码下载](http://download.csdn.net/detail/jj120522/4670568)





  怎么样,看着还行吧,我们在看下面一个示例:





  ![](http://img1.tuicool.com/vaYRbe.png)





  简单说明一下,当你滑动的时候左边会跟着右边一起滑动,这个效果比上面那个酷吧,上面那个有点死板,其实实现起来也比较容易,只需要把我们上面那个稍微修改下,对layout_right也进行时时更新,这样就实现了这个效果了,如果上面那个理解了,这个很轻松就解决了,在这里我又遇到一个问题: 此时的listview的item监听不到手势,意思就是我左右滑动listview他没有进行滑动。





  本人对touch众多事件监听拦截等熟悉度不够,因此这里我用到自己写的方法,也许比较麻烦,如果有更好的解决办法,请大家一定要分享哦,再次 thanks for you 了.





  具体解决办法:我们重写listview,对此listview进行手势监听, 我们自定义一个接口来实现 ,具体代码如下:



```

package com.jj.slidingmenu;

import android.content.Context; import android.util.AttributeSet; import android.util.Log; import android.view.GestureDetector; import android.view.MotionEvent; import android.view.GestureDetector.OnGestureListener; import android.view.View; import android.widget.ListView; import android.widget.Toast;

public class MyListView extends ListView implements OnGestureListener {

private GestureDetector gd; // 事件状态 public static final char FLING_CLICK = ; public static final char FLING_LEFT = 1; public static final char FLING_RIGHT = 2; public static char flingState = FLING_CLICK;

private float distanceX;// 水平滑动的距离

private MyListViewFling myListViewFling;

public static boolean isClick = false;// 是否可以点击

public void setMyListViewFling(MyListViewFling myListViewFling) { this.myListViewFling = myListViewFling; }

public float getDistanceX() { return distanceX; }

public char getFlingState() { return flingState; }

private Context context;

public MyListView(Context context) { super(context);

}

public MyListView(Context context, AttributeSet attrs) { super(context, attrs); this.context = context; gd = new GestureDetector(this); }

/**

  • 覆写此方法,以解决ListView滑动被屏蔽问题 */ @Override public boolean dispatchTouchEvent(MotionEvent event) { myListViewFling.doFlingOver(event);// 回调执行完毕. this.gd.onTouchEvent(event);
<span class="keyword">return</span> <span class="keyword">super</span>.dispatchTouchEvent(event);

}

@Override public boolean onTouchEvent(MotionEvent ev) { /*** * 当移动的时候 */ if (ev.getAction() == MotionEvent.ACTION_DOWN) isClick = true; if (ev.getAction() == MotionEvent.ACTION_MOVE) isClick = false; return super.onTouchEvent(ev); }

@Override public boolean onDown(MotionEvent e) { int position = pointToPosition((int) e.getX(), (int) e.getY()); if (position != ListView.INVALID_POSITION) { View child = getChildAt(position - getFirstVisiblePosition()); } return true; }

@Override public void onShowPress(MotionEvent e) {

}

@Override public boolean onSingleTapUp(MotionEvent e) {

<span class="keyword">return</span> <span class="keyword">false</span>;

}

@Override public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { // 左滑动 if (distanceX > ) { flingState = FLING_RIGHT; Log.v(“jj”, “左distanceX=" + distanceX); myListViewFling.doFlingLeft(distanceX);// 回调 // 右滑动. } else if (distanceX < ) { flingState = FLING_LEFT; Log.v(“jj”, “右distanceX=" + distanceX); myListViewFling.doFlingRight(distanceX);// 回调 }

<span class="keyword">return</span> <span class="keyword">false</span>;

}

/***

  • 上下文菜单 */ @Override public void onLongPress(MotionEvent e) { // System.out.println(“Listview long press”); // int position = pointToPosition((int) e.getX(), (int) e.getY()); // if (position != ListView.INVALID_POSITION) { // View child = getChildAt(position - getFirstVisiblePosition()); // if (child != null) { // showContextMenuForChild(child); // this.requestFocusFromTouch(); // } // // } }

@Override public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {

<span class="keyword">return</span> <span class="keyword">false</span>;

}

/***

  • 回调接口
  • @author jjhappyforever…

*/ interface MyListViewFling { void doFlingLeft(float distanceX);// 左滑动执行

<span class="keyword">void</span> doFlingRight(<span class="keyword">float</span> distanceX);<span class="comment">// 右滑动执行</span>

<span class="keyword">void</span> doFlingOver(MotionEvent event);<span class="comment">// 拖拽松开时执行</span>

}

}

    
    

      而在MainActivity.java里面实现该接口,我这么一说,我想有的同学们都明白了,具体实现起来代码有点多,我把代码上传到网上,大家可以下载后 用心看 ,我想大家都能够明白的.(在这里我鄙视一下自己,肯定通过对手势监听拦截实现对listview的左右滑动,但是自己学业不经,再次再说一下,如有好的解决方案,请一定要分享我一下哦.    

    
    

      另外有一个问题:当listivew超出一屏的时候, 此时的listview滑动的时候可以上下左右一起滑动,在此没有解决这个问题,如有解决请分享我哦.
    

    
    

      效果图:
    

    
    

      ![](http://img1.tuicool.com/A3iARj.gif)
    

    
    

      [源码下载](http://download.csdn.net/detail/jj120522/4671132)
    

    
    

      由于篇符较长,先说到这里,其实android 自定义ViewGroup和对view进行切图动画实现滑动菜单SlidingMenu也可以实现.具体参考下一篇文章:
    

    
    

      先写到这里,有不足的地方请指出,
    

    
    

      如果对您有帮助的话请记得赞一个哦. thanks for you。
    

  </div>
</div>

💬 评论