zoukankan      html  css  js  c++  java
  • android RecyclerView的瀑布流布局案例

    1、先创建 activity_water_fall.xml 和 activity_water_fall_item.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=".WaterFallActivity">
    
        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/rv3"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            tools:layout_editor_absoluteX="207dp"
            tools:layout_editor_absoluteY="62dp" />
    </androidx.constraintlayout.widget.ConstraintLayout>
    <?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="wrap_content"
        android:layout_height="wrap_content"
        tools:context=".WaterFallItemActivity">
    
        <ImageView
            android:id="@+id/imageView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:contentDescription="@string/ivdesc"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:srcCompat="@drawable/p1" />
    </androidx.constraintlayout.widget.ConstraintLayout>

    2、创建Adapter

    package com.example.myapplication;
    
    import android.content.Context;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.ImageView;
    
    import androidx.annotation.NonNull;
    import androidx.annotation.WorkerThread;
    import androidx.recyclerview.widget.RecyclerView;
    
    public class WaterFallAdapter extends RecyclerView.Adapter<WaterFallAdapter.WaterFallViewHolder> {
        private Context context;
    
        public WaterFallAdapter(Context context) {
            this.context = context;
        }
        @NonNull
        @Override
        public WaterFallAdapter.WaterFallViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
            return new WaterFallViewHolder(LayoutInflater.from(context).inflate(R.layout.activity_water_fall_item,parent,false));
        }
    
        @Override
        public void onBindViewHolder(@NonNull WaterFallAdapter.WaterFallViewHolder holder, int position) {
            if(position %2==0) {
                holder.iv.setImageResource(R.drawable.p1);
            }else{
                holder.iv.setImageResource(R.drawable.p2);
            }
        }
    
        @Override
        public int getItemCount() {
            return 60;
        }
    
        class WaterFallViewHolder extends RecyclerView.ViewHolder{
    
            private ImageView iv;
            public WaterFallViewHolder(@NonNull View itemView) {
                super(itemView);
    
                iv = itemView.findViewById(R.id.imageView);
            }
        }
    }

    3、WaterFallActivity.java

    package com.example.myapplication;
    
    import androidx.appcompat.app.AppCompatActivity;
    import androidx.recyclerview.widget.RecyclerView;
    import androidx.recyclerview.widget.StaggeredGridLayoutManager;
    
    import android.os.Bundle;
    
    public class WaterFallActivity extends AppCompatActivity {
        private RecyclerView rv;
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_water_fall);
    
            rv = findViewById(R.id.rv3);
            rv.setLayoutManager(new StaggeredGridLayoutManager(2,StaggeredGridLayoutManager.VERTICAL));
            rv.setAdapter(new WaterFallAdapter(WaterFallActivity.this));
        }
    }

    ps:图片路径,直接复制到drawable目录里面:

    4、效果:

  • 相关阅读:
    HTTP Header 详解
    面试题----网页/应用访问慢突然变慢,如何定位问题
    PHP实现斐波那契数列
    常见的HTTP返回状态值
    通过实例理解单列索引、多列索引以及最左前缀原则
    Btree索引和Hash索引
    遍历和删除文件夹
    面试题之----禁掉cookie的session使用方案
    面试题之----写个函数来解决多线程同时读写一个文件的问题
    heredoc
  • 原文地址:https://www.cnblogs.com/zoro-zero/p/11407884.html
Copyright © 2011-2022 走看看