自定义View - MyViewPager和MyTabLayout

本文介绍了作者为了练习而自定义的View组件——MyViewPager和MyTabLayout。虽然实际开发中可以使用预置的ViewPager和TabLayout,但作者详细展示了实现这两个自定义组件的过程,包括效果图展示、Activity和Adapter的代码,以及自定义View的源码分享。
摘要由CSDN通过智能技术生成
首先声明一点,写这两个View纯粹为了练习而已,要实现这个功能完全可以直接用ViewPager和TabLayout完成
下面首先给出效果图

[](在这里插入图片描述

Activity、Adapter代码如下
public class MyViewPagerActivity extends Activity {
   

    private MyViewPager mVp;
    private MyTabLayout mTab;
    public static final String[] mTitles = {
   "视频","图片","小说","杂志","明星","体育","游戏","竞技","中医"};

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
   
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_viewpager);
        mVp = findViewById(R.id.vp);
        mTab = findViewById(R.id.tab);
        BaseAdapter adapter = new MyBaseAdapter();
        mVp.setAdapter(adapter);
        mTab.setViewPager(mVp);
    }
    class MyBaseAdapter extends BaseAdapter {
   

        @Override
        public int getItemCount() {
   
            return mTitles.length;
        }

        @Override
        public View getView(int position) {
   
            return MyViewManager.getInstance().getView(getApplicationContext(), position);
        }

        @Override
        public String getTitle(int position) {
   
            return mTitles[position];
        }
    }

    static class MyViewManager {
   

        private SparseArray<View> mViews = new SparseArray<>();

        public static MyViewManager getInstance() {
   
            return MyViewManagerHolder.mViewManager;
        }

        public View getView(Context context, int position) {
   
            if (mViews.get(position) != null) {
   
                return mViews.get(position);
            }
            RecyclerView rv = new RecyclerView(context);
            rv.setLayoutManager(new LinearLayoutManager(context));
            rv.addItemDecoration(new DividerItemDecoration(context, DividerItemDecoration.VERTICAL));
            rv.setAdapter(new CommonAdapter(context, mTitles[position]));
            mViews.put(position, rv);
            return rv;
        }

        private static class MyViewManagerHolder {
   
            private static MyViewManager mViewManager = new MyViewManager();
        }
    }
}

public class CommonAdapter extends RecyclerView.Adapter<CommonAdapter.ViewHolder> {
   

    private List<String> mList;
    private OnItemClickListener mListener;
    private Context mContext;

    CommonAdapter(Context context, String title) {
   
        mList = new ArrayList<>();
        mContext = context;
        for (int i=0; i<100; i++) {
   
            mList.add(title + " " + i);
        }
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
   
        return new ViewHolder(LayoutInflater.from(parent.getContext()).inflate(R.layout.item_main_layout, parent, false));
    }

    @Override
    public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
   
        holder.mTv.setText(mList.get(position));
        holder.mTv.setOnClickListener((v) -> {
   
            Toast.makeText(mContext, mList.get(position), Toast.LENGTH_SHORT).show();
        });
        holder.itemView.setOnClickListener((view) -> {
   
            if (mListener != null) {
   
                mListener.onItemClick(view, holder.getLayoutPosition());
            }
        });
        holder.itemView.setOnLongClickListener((view) -> {
   
            if (mListener != null) {
   
                mListener.onItemLongClick(view, holder.getLayoutPosition());
            }
  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值