【第一行代码】RecyclerView

简介

利用RecyclerView做一个列表图片+文字的展示,实现点击事件。
分别介绍了网格布局,水平滚动和垂直滚动的布局方式

成果展示

在这里插入图片描述在这里插入图片描述在这里插入图片描述

RecyclerView

RecyclerView属于新增的控件,为了在所以的Android版本上都能使用,而RecyclerView定义在support库中。
所以想要使用RecyclerView这个控件,需要添加相应的依赖库。

基本用法

在布局中添加代码

<androidx.recyclerview.widget.RecyclerView
    android:id="@+id/recycler_view"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>
对象类
class Team {
    private String name;
    private int imageId;

    public Team(String name, int imageId) {
        this.name = name;
        this.imageId = imageId;
    }

    public String getName() {
        return name;
    }

    public int getImageId() {
        return imageId;
    }
}
item布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp">

    <ImageView
        android:id="@+id/team_image"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"/>

    <TextView
        android:id="@+id/team_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="left"
        android:layout_marginLeft="10dp"/>

</LinearLayout>

<!--水平翻滚效果-->
<!--<?xml version="1.0" encoding="utf-8"?>-->
<!--<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"-->
<!--android:orientation="vertical"-->
<!--android:layout_width="100dp"-->
<!--android:layout_height="wrap_content">-->

<!--<ImageView-->
    <!--android:id="@+id/team_image"-->
    <!--android:layout_width="wrap_content"-->
    <!--android:layout_height="wrap_content"-->
    <!--android:layout_gravity="center_horizontal"/>-->

<!--<TextView-->
    <!--android:id="@+id/team_name"-->
    <!--android:layout_width="wrap_content"-->
    <!--android:layout_height="wrap_content"-->
    <!--android:layout_gravity="center_horizontal"-->
    <!--android:layout_marginLeft="10dp"/>-->

<!--</LinearLayout>-->

<!--垂直滑动效果-->
<!--<?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="wrap_content">-->

<!--<ImageView-->
    <!--android:id="@+id/team_image"-->
    <!--android:layout_width="wrap_content"-->
    <!--android:layout_height="wrap_content" />-->

<!--<TextView-->
    <!--android:id="@+id/team_name"-->
    <!--android:layout_width="wrap_content"-->
    <!--android:layout_height="wrap_content"-->
    <!--android:layout_gravity="center_vertical"-->
    <!--android:layout_marginLeft="10dp"/>-->

<!--</LinearLayout>-->
适配器类
public class TeamAdapter extends RecyclerView.Adapter<TeamAdapter.ViewHolder>  {
    private static final String TAG = "TeamAdapter";
    private List<Team> mTeamList;

    public class ViewHolder extends RecyclerView.ViewHolder {

        //实现点击事件
        View teamView;

        ImageView teamImage;
        TextView teamName;

        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            teamView = itemView;
            teamImage = (ImageView) itemView.findViewById(R.id.team_image);
            teamName = (TextView) itemView.findViewById(R.id.team_name);
        }
    }

    public TeamAdapter(List<Team> teamList) {
        mTeamList = teamList;
    }

    @NonNull
    @Override
    public TeamAdapter.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(
                R.layout.team_item,parent,false);
        final ViewHolder holder = new ViewHolder(view);

        holder.teamView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                int pos = holder.getAdapterPosition();
                Team team = mTeamList.get(pos);
                Log.d(TAG, "onClick: "+team.getName());
            }
        });
        holder.teamImage.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                int pos = holder.getAdapterPosition();
                Team team = mTeamList.get(pos);
                Log.d(TAG, "onClick: "+team.getName());
            }
        });

        return holder;
    }

    @Override
    public void onBindViewHolder(@NonNull TeamAdapter.ViewHolder holder, int position) {
        Team team = mTeamList.get(position);
        holder.teamImage.setImageResource(team.getImageId());
        holder.teamName.setText(team.getName());
    }

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

}
主活动类
public class MainActivity extends AppCompatActivity {

    private List<Team> teamList = new ArrayList<>();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initTeam();
        RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recycler_view);

        /*
        //实现垂直滑动效果
        LinearLayoutManager layoutManager = new LinearLayoutManager(this);
        //实现水平滑动效果
        LinearLayoutManager layoutManager = new LinearLayoutManager(this);
        layoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
        */
        //实现网络布局,第一个参数是布局的列数,第二个参数是排列方向
        StaggeredGridLayoutManager layoutManager = new StaggeredGridLayoutManager(
                1,StaggeredGridLayoutManager.VERTICAL);

        recyclerView.setLayoutManager(layoutManager);
        TeamAdapter adapter = new TeamAdapter(teamList);
        recyclerView.setAdapter(adapter);
    }

    private void initTeam() {
        Team rng = new Team("RNG",R.drawable.rng);
        teamList.add(rng);
        Team ig = new Team("IG",R.drawable.ig);
        teamList.add(ig);
        Team fpx = new Team("FPX",R.drawable.rng);
        teamList.add(fpx);
        Team skt = new Team("SKT",R.drawable.ig);
        teamList.add(skt);
        Team grf = new Team("GRF",R.drawable.rng);
        teamList.add(grf);
        Team dwg = new Team("DWG",R.drawable.ig);
        teamList.add(dwg);
        Team g2 = new Team("G2",R.drawable.rng);
        teamList.add(g2);
        Team fnc = new Team("FNC",R.drawable.ig);
        teamList.add(fnc);
        Team spy = new Team("SPY",R.drawable.rng);
        teamList.add(spy);
        Team tl = new Team("TL",R.drawable.ig);
        teamList.add(tl);
        Team c9 = new Team("C9",R.drawable.rng);
        teamList.add(c9);
        Team cg = new Team("CG",R.drawable.ig);
        teamList.add(cg);
        Team hka = new Team("HKA",R.drawable.rng);
        teamList.add(hka);
        Team ahq = new Team("AHQ",R.drawable.ig);
        teamList.add(ahq);
        Team gam = new Team("GAM",R.drawable.rng);
        teamList.add(gam);
        Team jt = new Team("JT",R.drawable.ig);
        teamList.add(jt);
    }
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值