ListView实现条目横向侧滑删除

1.原理

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

2.上代码

2.1项目结构

image.png

2.2activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <ListView
        android:id="@+id/lv"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginStart="1dp"
        android:layout_marginTop="1dp"
        android:layout_marginEnd="1dp"
        android:layout_marginBottom="1dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
image.png

2.3item.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <HorizontalScrollView
        android:id="@+id/horizontalScrollView"
        android:layout_width="0dp"
        android:scrollbars="none"
        android:layout_height="wrap_content"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:orientation="horizontal">

            <TextView
                android:id="@+id/tv"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="TextView" />

            <TextView
                android:id="@+id/textView2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="删除" />
        </LinearLayout>
    </HorizontalScrollView>
</androidx.constraintlayout.widget.ConstraintLayout>
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<String> 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<String> list;
        private Context context;
        int width;

        public MyAdapter(List<String> 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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容