ViewPager复用

ViewPager复用代码很简单,记录一下importandroid.support.v4.view.PagerAdapter;importandroid.support.v4.view.ViewPager;importandroid.support.v7.app.AppCompatActivity;importandroid.os.Bundle;importandroid.view.View;…

大家好,又见面了,我是你们的朋友全栈君。

代码很简单,记录一下
主要是用LinkedList在destroyItem中添加移除的View,在instantiateItem中复用移除的View。

import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.TextView;

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

public class MainActivity extends AppCompatActivity { 
   

    private PagerAdapter mPagerAdapter;
    private List<String> mDataList = new ArrayList<>();
    private Button mUpdate, mDelete, mAdd, mClean;
    private LinkedList<View> mViewCache = new LinkedList<>();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mDataList.add("1");
        mDataList.add("2");
        mDataList.add("3");
        mDataList.add("4");
        mDataList.add("5");

        ViewPager viewPager = findViewById(R.id.viewPager);
        viewPager.setAdapter(mPagerAdapter = new PagerAdapter() {
            @Override
            public int getCount() {
                return mDataList.size();
            }

            @Override
            public boolean isViewFromObject(View view, Object object) {
                return view == object;
            }


            @Override
            public Object instantiateItem(ViewGroup container, int position) {
                View view = mViewCache.size() > 0 ? mViewCache.removeFirst() : null;
                String str = "";
                if (view == null) {
                    view = View.inflate(MainActivity.this, R.layout.item_pager, null);
                    str = "";
                } else{
                    str = "复用了position为= " + view.getTag() + " 的Item";
                }
                TextView textView = view.findViewById(R.id.pager_tv);
                textView.setText(str + "\n" +mDataList.get(position));
                view.setTag(position);
                container.addView(view);
                return view;
            }

            @Override
            public void destroyItem(ViewGroup container, int position, Object object) {
                View deleteView = (View) object;
                container.removeView(deleteView);
                mViewCache.add(deleteView);
            }

        });

    }

}

这里写图片描述

微信公众号
这里写图片描述

随意打赏
这里写图片描述

QQ群:365473065

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163220.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • GROUP BY和HAVING用法介绍

    GROUP BY和HAVING用法介绍一、groupby和having1、满足“SELECT子句中的列名必须为分组列或列函数”,因为SELECT有groupby中包含的列2、having必须和groupby一起用,且在groupby后面3、groupby、having、orderby的使用顺序:groupby、having、orderbySELECT*|字段列表[as别名]FROM表名[WHERE子句][GROUPBY子句][HAVING子句][ORDERBY子句][LIMIT…

    2022年6月18日
    21
  • Docker镜像相关命令

    Docker镜像相关命令1、查看docker版本 docker version 2、列出本地主机上的镜像: docker images REPOSITORY:表示镜像的仓库源 TAG:镜像的标签 IMAGE ID:镜像ID CREATED:镜像创建时间 SIZE:镜像大小3、查询镜像 docker search 镜像名称…

    2022年6月13日
    30
  • JSONObject 和object之间的转换

    JSONObject 和object之间的转换转换为json对象:JSONObjectjson=JSONObject.fromObject(Object);转换为json对象数组:JSONArrayjson=JSONArray.fromObject(person);

    2022年5月27日
    37
  • scipy读取不了imread_type object is not iterable

    scipy读取不了imread_type object is not iterable最近在运行代码的时候出现了这个错误——AttributeError:module’scipy.misc’hasnoattribute’imread’。查阅网上资料之后发现,大部分解决办法都是说没有安装PIL第三方库,库名现在为Pillow,推荐直接使用命令pipinstallPillow进行安装,但是我的问题并没有因此得到解决,还是继续报错AttributeError:modu…

    2022年10月14日
    4
  • oracle11g的standby性能分析报告statpack安装

    一般常见的分析standbydatabase的性能问题的方法就是通过动态性能视图来判断,从11g开始,随着ActiveDataGuard功能的出现,早期的Statspack工具可以在stand

    2021年12月24日
    61
  • ExecuteNonQuery()_java有返回值和无返回值

    ExecuteNonQuery()_java有返回值和无返回值查询某个表中是否有数据的时候,我用了ExecuteNonQuery(),并通过判断值是否大于0来判断数据的存在与否。结果与我所设想的很不一致,调试时才发现,其执行后返回的结果是-1,对此我很是不理解,回头查了下资料,如下显示:SqlCommand.ExecuteNonQuery方法对连接执行Transact-SQL语句并返回受影响的行数。备注:可以使用ExecuteNonQuery来执行…

    2025年11月1日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号