RecyclerView的简单用法

本文介绍如何使用RecyclerView实现多种布局效果,包括ListView、GridView及瀑布流布局,并提供代码示例。

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

RecyclerView既能实现listview的效果又可以实现GrideView的效果还可以实现瀑布流。
它是通过改变LayoutManager来改变item的排列方式。
系统给我们提供了三种:
1、LinearLayoutManager 类似于listview
2、GridLayoutManager 类似于listview
3、StagerGridLayoutManager 类似于瀑布流
首先添加依赖库:
这里写图片描述
布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scrollbars="vertical" />

</LinearLayout>
 /**
     * 初始化布局
     *
     * @param context
     */
    private void initView(final Context context) {
        LayoutInflater inflater = LayoutInflater.from(context);
        View view = inflater.inflate(R.layout.data_view, this);
        mRecyclerView = (RecyclerView) view.findViewById(R.id.recyclerview);
        //类似listview
        mLinearLayoutManager = new LinearLayoutManager(MyApplication.getContext());
        //设置listview的滑动是横着的,还是竖着的
        mLinearLayoutManager.setOrientation(RecyclerView.VERTICAL);
        //类似GridView
        // GridLayoutManager gridLayoutManager = new GridLayoutManager(MyApplication.getContext(), 2);
        //代表竖直排列,然后是两列
        //StaggeredGridLayoutManager staggeredGridLayoutManager = new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL);
        //设置布局管理器
        mRecyclerView.setLayoutManager(mLinearLayoutManager);
        //知道每个item得高度可以提高性能
        mRecyclerView.setHasFixedSize(true);
        MyOnScrollListener myOnScrollListener = new MyOnScrollListener();
        //添加监听,到最后一个时加载下一页
        mRecyclerView.addOnScrollListener(myOnScrollListener);
        initData();
    }
static class MyOnScrollListener extends RecyclerView.OnScrollListener {

        @Override
        public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
            super.onScrollStateChanged(recyclerView, newState);
            int position = mLinearLayoutManager.findLastCompletelyVisibleItemPosition() + 1;
            int count = recyclerView.getAdapter().getItemCount();
            if (newState == RecyclerView.SCROLL_STATE_IDLE && position == count) {
                Toast.makeText(MyApplication.getContext(), "加载更多", Toast.LENGTH_SHORT).show();
            }
        }
    }

    private void initData() {
        ArrayList<Person> persons = new ArrayList<>();
        for (int i = 0; i < Cheeses.NAMES.length; i++) {
            String name = Cheeses.NAMES[i];
            persons.add(new Person(name));
        }
        adapter = new MyRecyclerAdpter(persons);
        mRecyclerView.setAdapter(adapter);
        mRecyclerView.setItemAnimator(new DefaultItemAnimator());

adapter需要继承RecyclerView.Adapter

public class MyRecyclerAdpter extends RecyclerView.Adapter<MyRecyclerAdpter.ViewHolder> implements View.OnClickListener, View.OnLongClickListener {
    private ArrayList<Person> persons;
    private OnRecyclerViewItemClickListener listener;

    public MyRecyclerAdpter(ArrayList<Person> persons) {
        this.persons = persons;

    }

    @Override
    public MyRecyclerAdpter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item, parent, false);
        //将view和viewholder关联
        ViewHolder viewHolder = new ViewHolder(view);
        return viewHolder;
    }

    @Override
    public void onBindViewHolder(MyRecyclerAdpter.ViewHolder holder, int position) {
        Person person = persons.get(position);
        holder.mTextView.setText(person.name);
        holder.itemView.setTag(person);
        //创建view得注册点击事件
        if (!holder.itemView.hasOnClickListeners()) {
            holder.itemView.setOnLongClickListener(this);
            holder.itemView.setOnClickListener(this);
        }
    }

    @Override
    public int getItemCount() {
        return persons.size();
    }

    @Override
    public void onClick(View v) {
        if (listener != null) {
            listener.onItemClick(v, (Person) v.getTag());
        }
    }

    @Override
    public boolean onLongClick(View v) {
        if (listener != null) {
            listener.onItemLongClick(v, (Person) v.getTag());
            return true;
        }
        return false;
    }

    public class ViewHolder extends RecyclerView.ViewHolder {
        public TextView mTextView;

        public ViewHolder(View itemView) {
            super(itemView);
            mTextView = (TextView) itemView.findViewById(R.id.text);
        }
    }

    interface OnRecyclerViewItemClickListener {
        /**
         * 单一点击事件
         *
         * @param view
         * @param person
         */
        void onItemClick(View view, Person person);

        /**
         * 长按点击事件
         *
         * @param view
         * @param person
         */
        void onItemLongClick(View view, Person person);
    }

    public void setOnItemClickListener(OnRecyclerViewItemClickListener listener) {
        this.listener = listener;
    }
}

item的布局用了一下cardview:

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="200dp"
    android:layout_marginBottom="5dp"
    android:layout_marginLeft="5dp"
    android:layout_marginRight="5dp"
    card_view:cardCornerRadius="4dp">

    <TextView
        android:id="@+id/text"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:layout_gravity="center"
        android:singleLine="true"
        android:text="雪儿"
        android:textColor="@android:color/black" />

</android.support.v7.widget.CardView>

小弟暂时就了解这么多了。

内容概要:本文详细探讨了基于MATLAB/SIMULINK的多载波无线通信系统仿真及性能分析,重点研究了以OFDM为代表的多载波技术。文章首先介绍了OFDM的基本原理和系统组成,随后通过仿真平台分析了不同调制方式的抗干扰性能、信道估计算法对系统性能的影响以及同步技术的实现与分析。文中提供了详细的MATLAB代码实现,涵盖OFDM系统的基本仿真、信道估计算法比较、同步算法实现和不同调制方式的性能比较。此外,还讨论了信道特征、OFDM关键技术、信道估计、同步技术和系统级仿真架构,并提出了未来的改进方向,如深度学习增强、混合波形设计和硬件加速方案。; 适合人群:具备无线通信基础知识,尤其是对OFDM技术有一定了解的研究人员和技术人员;从事无线通信系统设计与开发的工程师;高校通信工程专业的高年级本科生和研究生。; 使用场景及目标:①理解OFDM系统的工作原理及其在多径信道环境下的性能表现;②掌握MATLAB/SIMULINK在无线通信系统仿真中的应用;③评估不同调制方式、信道估计算法和同步算法的优劣;④为实际OFDM系统的设计和优化提供理论依据和技术支持。; 其他说明:本文不仅提供了详细的理论分析,还附带了大量的MATLAB代码示例,便于读者动手实践。建议读者在学习过程中结合代码进行调试和实验,以加深对OFDM技术的理解。此外,文中还涉及了一些最新的研究方向和技术趋势,如AI增强和毫米波通信,为读者提供了更广阔的视野。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值