ListView实现条目横向侧滑删除

1.原理

(1)定义条目时,使用HorizontalScrollView实现横向滑动;
(2)由于ScrollView相当于横向无限延伸,所以需要控制第一个元素的宽度为屏幕宽度;
本例使用TextView作为条目第一个元素,这个元素也可以是一个容器布局元素,“删除”按钮为第二个元素,需要侧滑才能看到“删除”按钮
(3)因为“删除”按钮是隐藏的,需要将第一个元素设置屏幕宽度。

2.上代码

2.1项目结构

image.png

2.2activity_main.xml




    

image.png

2.3item.xml




    

        

            

            
        
    

image.png

2.4MainActivity.java

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Context;
import android.os.Bundle;
import android.util.DisplayMetrics;
import android.view.Display;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {
    ListView lv;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        lv = findViewById(R.id.lv);
        List list = new ArrayList<>();
        for (int i = 0; i < 100; i++) {
            list.add("i" + i);
        }
        MyAdapter adapter=new MyAdapter(list,MainActivity.this);
        lv.setAdapter(adapter);
    }

    public class MyAdapter extends BaseAdapter{
        private List list;
        private Context context;
        int width;

        public MyAdapter(List list, Context context) {
            this.list = list;
            this.context = context;
            Display defaultDisplay = getWindowManager().getDefaultDisplay();
            DisplayMetrics metrics=new DisplayMetrics();
            defaultDisplay.getMetrics(metrics);
            width= metrics.widthPixels;//获取屏幕宽度
        }

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

        @Override
        public Object getItem(int i) {
            return list.get(i);
        }

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

        @Override
        public View getView(int i, View view, ViewGroup viewGroup) {
            View myView = LayoutInflater.from(context).inflate(R.layout.item, null);
            TextView tv=myView.findViewById(R.id.tv);
            tv.setWidth(width);
            tv.setText(list.get(i));
            return myView;
        }
    }
}

效果:


动画.gif
动画2.gif

你可能感兴趣的:(ListView实现条目横向侧滑删除)