这篇文章将会介绍我是如何学习item的左滑监听事件设置的,首先我们先添加依赖:
compile ‘com.baoyz.swipemenulistview:library:1.3.+’
可以看到,我们是借助大神所写的swipemenulistView这个空间来实现我们的左滑事件的。导入之后呢,我们就可以开始我们的项目了。
首先和往常写listView写好我们的布局文件,但是以前所有的listView控件就需要我们使用这一款新的控件代替了。
main_activity.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:swipe="http://schemas.android.com/apk/res-auto"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.administrator.learnlistviewmenu.MainActivity">
<com.baoyz.swipemenulistview.SwipeMenuListView
android:id="@+id/listView"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
</com.baoyz.swipemenulistview.SwipeMenuListView>
</RelativeLayout>
接下来是我们的item布局文件:
list_item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/nameTextView"
android:textSize="20sp"
android:layout_width="match_parent"
android:layout_height="40dp" />
<TextView
android:id="@+id/ageTextView"
android:textSize="15sp"
android:layout_width="match_parent"
android:layout_height="40dp" />
</LinearLayout>
然后代码部分,还是需要我们自己去建立适配器,以及写一个数据类来存放需要显示的数据。这和以前我们写listView的思想一样,接下来我们直接放代码吧。
数据类Person:
public class Person {
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
public Person(){
}
String name ;
String age;
}
item 的AppView类:
public class AppView extends LinearLayout {
private Context context;
private TextView nameTextView;
private TextView ageTextView;
public AppView(Context context) {
super(context);
this .context = context;
init(context);
}
public void init(Context context){
this.context = context;
View view = LayoutInflater.from(this.context).inflate(R.layout.listview_item,null);
nameTextView = (TextView) view .findViewById(R.id.nameTextView);
ageTextView = (TextView) view.findViewById(R.id.ageTextView);
addView(view);
}
public void updateView(Person person){
nameTextView.setText(person.getName());
ageTextView.setText(person.getAge());
}
}
Adapter:
public class ListViewAdapter extends BaseAdapter {
private Context context;
private List<Person> infos;
public ListViewAdapter(Context context, List<Person> infos){
this.context =context;
this.infos=infos;
}
public int getCount() {
return infos.size();
}
@Override
public Object getItem(int i) {
return infos.get(i);
}
@Override
public long getItemId(int i) {
return i;
}
@Override
public View getView(int i, View view, ViewGroup viewGroup) {
if(infos==null){
return null;
}
if(view==null){
AppView appView = new AppView(context);
appView.updateView(infos.get(i));
view = appView;
view.setTag(appView);
}else{
view = (View) view.getTag();
}
return view;
}
}
接下来就是比较重要,也是比较关键的MainActivity类了.
package com.example.administrator.learnlistviewmenu;
import android.content.Context;
import android.content.res.Resources;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.TypedValue;
import android.widget.Toast;
import com.baoyz.swipemenulistview.SwipeMenu;
import com.baoyz.swipemenulistview.SwipeMenuCreator;
import com.baoyz.swipemenulistview.SwipeMenuItem;
import com.baoyz.swipemenulistview.SwipeMenuListView;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
List<Person> infos = new ArrayList<Person>();
SwipeMenuCreator creator = new SwipeMenuCreator() {
@Override
public void create(SwipeMenu menu) {
//create open item
SwipeMenuItem openItem = new SwipeMenuItem(getApplicationContext());
//set backg
openItem.setBackground(new ColorDrawable(Color.rgb(0xC9, 0xC9,
0xCE)));
openItem.setWidth(dip2px(MainActivity.this,90));
openItem.setTitle("Open");
openItem.setTitleSize(18);
openItem.setTitleColor(Color.WHITE);
menu.addMenuItem(openItem);
SwipeMenuItem deleteItem = new SwipeMenuItem(
getApplicationContext());
// set item background
deleteItem.setBackground(new ColorDrawable(Color.rgb(0xF9,
0x3F, 0x25)));
// set item width
deleteItem.setWidth(dip2px(MainActivity.this,90));
// set a icon
deleteItem.setIcon(R.mipmap.ic_launcher);
// add to menu
menu.addMenuItem(deleteItem);
}
};
SwipeMenuListView listView;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
loadDada();
ListViewAdapter adapter = new ListViewAdapter(this,infos);
listView = (SwipeMenuListView) findViewById(R.id.listView);
listView.setMenuCreator(creator);
listView.setSwipeDirection(SwipeMenuListView.DIRECTION_LEFT);
listView.setAdapter(adapter);
listView.setOnMenuItemClickListener(new SwipeMenuListView.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(int position, SwipeMenu menu, int index) {
switch (index){
case 0:
Toast.makeText(MainActivity.this, "open", Toast.LENGTH_SHORT).show();
break;
case 1:
Toast.makeText(MainActivity.this, "delete", Toast.LENGTH_SHORT).show();
break;
}
return false;
}
});
}
public void loadDada(){
for(int i = 0 ;i<=20;i++){
Person x = new Person();
x.setName("my name is "+i);
x.setAge("my age is "+i);
infos.add(x);
}
}
public static int dip2px(Context context, float dpValue) {
final float scale = context.getResources().getDisplayMetrics().density;
return (int) (dpValue * scale + 0.5f);
}
/**
* px2dp
*/
public static int px2dip(Context context, float pxValue) {
final float scale = context.getResources().getDisplayMetrics().density;
return (int) (pxValue / scale + 0.5f);
}
/**
*根据设备信息获取当前分辨率下指定单位对应的像素大小;
* px,dip,sp -> px
*/
public float getRawSize(Context c, int unit, float size) {
Resources r;
if (c == null){
r = Resources.getSystem();
}else{
r = c.getResources();
}
return TypedValue.applyDimension(unit, size, r.getDisplayMetrics());
}
}
这里面可以看到,我们的控件设置属性:
SwipeMenuCreator creator = new SwipeMenuCreator() {
@Override
public void create(SwipeMenu menu) {
//create open item
SwipeMenuItem openItem = new SwipeMenuItem(getApplicationContext());
//set backg
openItem.setBackground(new ColorDrawable(Color.rgb(0xC9, 0xC9,
0xCE)));
openItem.setWidth(dip2px(MainActivity.this,90));
openItem.setTitle("Open");
openItem.setTitleSize(18);
openItem.setTitleColor(Color.WHITE);
menu.addMenuItem(openItem);
SwipeMenuItem deleteItem = new SwipeMenuItem(
getApplicationContext());
// set item background
deleteItem.setBackground(new ColorDrawable(Color.rgb(0xF9,
0x3F, 0x25)));
// set item width
deleteItem.setWidth(dip2px(MainActivity.this,90));
// set a icon
deleteItem.setIcon(R.mipmap.ic_launcher);
// add to menu
menu.addMenuItem(deleteItem);
}
};
这一款代码就是我们设置的属性,说白了就是设置的左滑后显示的item的属性,这里我们可以自己去设置他的图片背景,大小以及title,这里设置好之后,在后面添加监听后的方法中就可以去写相应的触发事件了.
listView.setMenuCreator(creator);
listView.setSwipeDirection(SwipeMenuListView.DIRECTION_LEFT);
listView.setAdapter(adapter);
listView.setOnMenuItemClickListener(new SwipeMenuListView.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(int position, SwipeMenu menu, int index) {
switch (index){
case 0:
Toast.makeText(MainActivity.this, "open", Toast.LENGTH_SHORT).show();
break;
case 1:
Toast.makeText(MainActivity.this, "delete", Toast.LENGTH_SHORT).show();
break;
}
return false;
}
});
}
在使用的时候,我们必须传入最开始设置好的creator然后选择Direction,然后添加监听之后,我们就是通过switch判断index来,判断点击的具体的左滑item功能按钮.完成相应的方法。
这大概就是swipemenulistview的初使用了,本片文章只是记录学习过程,有很多不规范和有问题的写法的话。请大神勿喷啊