微信QQ侧拉删除的条目SwipeLayout与SwipeListview介绍

最近项目用到了测拉菜单,类似于微信与QQ的形似,自己研究了一下,主要是自定义View与ViewDragHelper,实现起来非常容易,但是扩展性不好,这里介绍一个git上的SwipeLayout。附上git地址:https://github.com/daimajia/AndroidSwipeLayout/wiki/usage

public class MainActivity extends AppCompatActivity {
    private ArrayList<String> lists = new ArrayList<String>();
    private ListView lv;
    public SwipeLayout mSwipeLayout;
    public ArrayList<SwipeLayout> swipeLayoutArrayList;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.layout_lv);
        swipeLayoutArrayList = new ArrayList<SwipeLayout>();
        lv = (ListView) findViewById(R.id.lv);
        for (int i = 0; i < 50; i++) {
            lists.add("hello" + i);
        }
        lv.setAdapter(new GridViewAdapter());
        lv.setOnScrollListener(new AbsListView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {

            }

            @Override
            public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
                if (swipeLayoutArrayList.size() > 0) {
                    for (int i = 0; i < swipeLayoutArrayList.size(); i++) {
                        swipeLayoutArrayList.get(i).close();
                    }
                }
            }
        });
    }

    public class GridViewAdapter extends BaseAdapter {

        @Override
        public int getCount() {
            return lists.size();
        }

        @Override
        public Object getItem(int position) {
            return null;
        }

        @Override
        public long getItemId(int position) {
            return position;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
           View view = View.inflate(MainActivity.this, R.layout.activity_main, null);
            TextView tv = (TextView) view.findViewById(R.id.tv);
            tv.setText(lists.get(position));
            TextView delete = (TextView) view.findViewById(R.id.delete);
            TextView remark = (TextView) view.findViewById(R.id.remark);
            delete.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    System.out.println("delete");
                }
            });
            remark.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    System.out.println("remark");
                }
            });
            SwipeLayout swipeLayout = (SwipeLayout) view.findViewById(R.id.sample1);
            swipeLayout.setShowMode(SwipeLayout.ShowMode.LayDown);
            swipeLayout.setClickToClose(true);
            swipeLayout.addDrag(SwipeLayout.DragEdge.Right, view.findViewById(R.id.bottom_wrapper));
            swipeLayout.addSwipeListener(new SwipeLayout.SwipeListener() {
                @Override
                public void onClose(SwipeLayout layout) {
                    //when the SurfaceView totally cover the BottomView.
                    swipeLayoutArrayList.remove(layout);
                    System.out.println("onClose");
                }

                @Override
                public void onUpdate(SwipeLayout layout, int leftOffset, int topOffset) {
                    //you are swiping.
                    // System.out.println("onUpdate");
                }

                @Override
                public void onStartOpen(SwipeLayout layout) {
                    if (swipeLayoutArrayList.size() > 0) {
                        for (int i = 0; i < swipeLayoutArrayList.size(); i++) {
                            swipeLayoutArrayList.get(i).close();
                        }
                    }
                    System.out.println("onStartOpen");
                }

                @Override
                public void onOpen(SwipeLayout layout) {
                    //when the BottomView totally show.
                    swipeLayoutArrayList.add(layout);
                    System.out.println("onOpen");
                }

                @Override
                public void onStartClose(SwipeLayout layout) {
                    System.out.println("onStartClose");
                }

                @Override
                public void onHandRelease(SwipeLayout layout, float xvel, float yvel) {
                    //when user's hand released.
                    System.out.println("onHandRelease");
                }
            });
            return view;
        }
    }
}
<?xml version="1.0" encoding="utf-8"?>
<com.daimajia.swipe.SwipeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent" android:layout_height="80dp"
    android:id="@+id/sample1">
    <!-- Bottom View Start-->
    <LinearLayout
        android:background="#66ddff00"
        android:id="@+id/bottom_wrapper"
        android:layout_width="160dp"
        android:weightSum="2"
        android:orientation="horizontal"
        android:layout_height="match_parent">
        <TextView
            android:id="@+id/delete"
            android:layout_weight="1"
            android:textSize="22sp"
            android:text="删除"
            android:gravity="center"
            android:layout_width="wrap_content"
            android:layout_height="match_parent" />
        <TextView
            android:id="@+id/remark"
            android:layout_weight="1"
            android:textSize="22sp"
            android:text="备注"
            android:gravity="center"
            android:layout_width="wrap_content"
            android:layout_height="match_parent" />
        <!--What you want to show-->
    </LinearLayout>
    <!-- Bottom View End-->

    <!-- Surface View Start -->
    <LinearLayout
        android:padding="10dp"
        android:background="#ffffff"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="horizontal">
        <!--What you want to show in SurfaceView-->
    <TextView
        android:id="@+id/tv"
        android:textSize="22sp"
        android:gravity="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    </LinearLayout>
    <!-- Surface View End -->
</com.daimajia.swipe.SwipeLayout>
XML文件注意FrontView与BackView的位置。

package com.example.jiangwei18.myswipelayout;

import android.content.Context;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;

import com.daimajia.swipe.SimpleSwipeListener;
import com.daimajia.swipe.SwipeLayout;
import com.daimajia.swipe.adapters.BaseSwipeAdapter;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
    private ArrayList<String> lists = new ArrayList<String>();
    private ListView lv;
    public ArrayList<SwipeLayout> swipeLayoutArrayList;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.layout_lv);
        swipeLayoutArrayList = new ArrayList<SwipeLayout>();
        lv = (ListView) findViewById(R.id.lv);

        lv.setOnScrollListener(new AbsListView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {

            }

            @Override
            public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
                if(swipeLayoutArrayList.size()>0){
                    for(int i =0;i<swipeLayoutArrayList.size();i++){
                        swipeLayoutArrayList.get(i).close();
                    }
                    swipeLayoutArrayList.clear();
                }
            }
        });
        lv.setAdapter(new GridViewAdapter(MainActivity.this));
        for (int i = 0; i < 50; i++) {
            lists.add("hello" + i);
        }
    }
    public class GridViewAdapter extends BaseSwipeAdapter {

        private Context mContext;

        public GridViewAdapter(Context mContext) {
            this.mContext = mContext;
        }

        @Override
        public int getSwipeLayoutResourceId(int position) {
            return R.id.sample1;
        }

        //ATTENTION: Never bind listener or fill values in generateView.
        //           You have to do that in fillValues method.
        @Override
        public View generateView(int position, ViewGroup parent) {
            return LayoutInflater.from(mContext).inflate(R.layout.activity_main, null);
        }

        @Override
        public void fillValues(int position, View convertView) {
            TextView t = (TextView)convertView.findViewById(R.id.tv);
            t.setText(lists.get(position));
            SwipeLayout mSwipeLayout = (SwipeLayout) convertView.findViewById(getSwipeLayoutResourceId(position));
            mSwipeLayout.addDrag(SwipeLayout.DragEdge.Right, convertView.findViewById(R.id.bottom_wrapper));
            mSwipeLayout.setClickToClose(true);
            mSwipeLayout.setShowMode(SwipeLayout.ShowMode.LayDown);
            mSwipeLayout.addSwipeListener(new SimpleSwipeListener(){
                @Override
                public void onStartOpen(SwipeLayout layout) {
                    super.onStartOpen(layout);
                }

                @Override
                public void onHandRelease(SwipeLayout layout, float xvel, float yvel) {
                    super.onHandRelease(layout, xvel, yvel);
                }

                @Override
                public void onUpdate(SwipeLayout layout, int leftOffset, int topOffset) {
                    super.onUpdate(layout, leftOffset, topOffset);
                }

                @Override
                public void onClose(SwipeLayout layout) {
                    super.onClose(layout);
                }

                @Override
                public void onStartClose(SwipeLayout layout) {
                    super.onStartClose(layout);
                }

                @Override
                public void onOpen(SwipeLayout layout) {
                    swipeLayoutArrayList.add(layout);
                    super.onOpen(layout);
                }
            });
            TextView delete = (TextView) convertView.findViewById(R.id.delete);
            TextView remark = (TextView) convertView.findViewById(R.id.remark);
            delete.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    System.out.println("delete");
                }
            });
            remark.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    System.out.println("remark");
                }
            });
        }

        @Override
        public int getCount() {
            return lists.size();
        }

        @Override
        public Object getItem(int position) {
            return null;
        }

        @Override
        public long getItemId(int position) {
            return position;
        }
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值