微信QQ侧拉删除的条目SwipeLayout与SwipeListview介绍
2016-05-04 13:56
381 查看
最近项目用到了测拉菜单,类似于微信与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;
}
}
}
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.addSwipeL b72f istener(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; } } }
相关文章推荐
- 微信 JS SDK 的 chooseImage 接口在部分安卓机上容易造成页面刷新
- 模仿微信标签功能的多行LinearLayout效果
- C#微信开发之微信公众号标签管理功能
- C#.net 微信公众账号接口开发
- 微信公众平台DEMO(PHP)
- 关于微信登录和友盟第三方微信登录那些坑
- 微信支付哪些事儿
- C#开发微信门户及应用(37)--微信公众号标签管理功能
- C#.net 微信公众账号接口开发
- 微信公众平台DEMO(PHP)
- 微信开发中网页授权access_token与基础支持的access_token异同
- 零基础微信开发入门指南
- Android微信分享及AS生成APK
- iphone 微信下浏览器中数字去除下划线
- openerp7微信支付开发
- IOS微信分享功能简单实现
- IOS微信分享功能简单实现
- iPhone 反编译-微信多开分身版原理,一部iPhone登录多个微信号
- 零基础二十分钟搭建SAE微信个人号后台
- JAVA版的微信红包算法