Android 实现ListView item的左滑(右滑)监听事件 swipemenulistview

本文介绍了在Android中利用SwipeMenuListView库实现ListView项的左滑监听事件。首先引入库,然后替换原有ListView控件,创建布局文件和数据类。接着在MainActivity中设置控件属性并添加监听,通过Direction判断滑动方向,执行对应功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这篇文章将会介绍我是如何学习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的初使用了,本片文章只是记录学习过程,有很多不规范和有问题的写法的话。请大神勿喷啊

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值