文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Flexbox+ReclyclerView怎么实现流式布局

2023-06-25 17:01

关注

本篇内容主要讲解“Flexbox+ReclyclerView怎么实现流式布局”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Flexbox+ReclyclerView怎么实现流式布局”吧!

效果:

Flexbox+ReclyclerView怎么实现流式布局

module build.gradle引入

implementation 'com.google.android.flexbox:flexbox:3.0.0'

布局

activity_main.xml

<?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">    <androidx.recyclerview.widget.RecyclerView        android:id="@+id/rv_Flexbox"        android:layout_width="match_parent"        android:layout_height="match_parent"/></LinearLayout>

MainActivity

package com.example.myapplication;import androidx.appcompat.app.AppCompatActivity;import androidx.recyclerview.widget.RecyclerView;import android.os.Bundle;import android.util.Log;import android.view.View;import com.google.android.flexbox.FlexDirection;import com.google.android.flexbox.FlexWrap;import com.google.android.flexbox.FlexboxLayoutManager;import com.google.android.flexbox.JustifyContent;import java.util.ArrayList;import java.util.List;public class MainActivity extends AppCompatActivity {    private RecyclerView rv_Flexbox;    private List<String> list_data;    private FlexBoxAdapter fAdapter;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        rv_Flexbox = (RecyclerView)findViewById(R.id.rv_Flexbox);        FlexboxLayoutManager flexboxLayoutManager = new FlexboxLayoutManager(this);        //flexDirection 属性决定主轴的方向(即项目的排列方向)。类似 LinearLayout 的 vertical 和 horizontal。        flexboxLayoutManager.setFlexDirection(FlexDirection.ROW);//主轴为水平方向,起点在左端。        //flexWrap 默认情况下 Flex 跟 LinearLayout 一样,都是不带换行排列的,但是flexWrap属性可以支持换行排列。//        flexboxLayoutManager.setFlexWrap(FlexWrap.WRAP);//按正常方向换行        //justifyContent 属性定义了项目在主轴上的对齐方式。//        flexboxLayoutManager.setJustifyContent(JustifyContent.FLEX_START);//交叉轴的起点对齐。        rv_Flexbox.setLayoutManager(flexboxLayoutManager);        list_data = new ArrayList<>();        list_data.add("小米手机");        list_data.add("平衡車");        list_data.add("无人机");        list_data.add("神舟笔记本电脑");        list_data.add("小鹏汽车");        list_data.add("特斯拉");        fAdapter = new FlexBoxAdapter(this,list_data);//        fAdapter.notifyDataSetChanged();        rv_Flexbox.setAdapter(fAdapter);        fAdapter.setOnItemClickLitener(new FlexBoxAdapter.OnItemClickLitener() {            @Override            public void OnItemClick(View view, int positon) {                Log.e("wy", "position: "+positon+"  data:" + list_data.get(positon));            }        });    }}

FlexBoxAdapter

package com.example.myapplication;import android.content.Context;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.TextView;import androidx.annotation.NonNull;import androidx.recyclerview.widget.RecyclerView;import java.util.List;public class FlexBoxAdapter extends RecyclerView.Adapter<FlexBoxAdapter.myHolder> {    private Context mContext;    private List<String> list_data;    private LayoutInflater inflater;    public FlexBoxAdapter(Context mContext, List<String> list_data) {        this.mContext = mContext;        this.list_data = list_data;        this.inflater = LayoutInflater.from(mContext);    }    @NonNull    @Override    public myHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {        View view = inflater.inflate(R.layout.fragment_rv_item,viewGroup,false);        return new myHolder(view);    }    @Override    public void onBindViewHolder(@NonNull final myHolder myHolder, int i) {        myHolder.tv_title.setText(list_data.get(i));        // 如果设置了回调,则设置点击事件        if (mOnItemClickLitener != null)        {            myHolder.itemView.setOnClickListener(new View.OnClickListener()            {                @Override                public void onClick(View v)                {                    int pos = myHolder.getLayoutPosition();                    mOnItemClickLitener.OnItemClick(myHolder.itemView, pos);                }            });        }    }    @Override    public int getItemCount() {        return list_data.size();    }    class myHolder extends RecyclerView.ViewHolder    {        TextView tv_title;        public myHolder(@NonNull View itemView) {            super(itemView);            tv_title = (TextView)itemView.findViewById(R.id.tv_title);        }    }        public interface OnItemClickLitener    {        void OnItemClick(View view, int positon);    }    private OnItemClickLitener mOnItemClickLitener;    public void setOnItemClickLitener(OnItemClickLitener mOnItemClickLitener)    {        this.mOnItemClickLitener = mOnItemClickLitener;    }}

drawable下

flex_item_bg.xml

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle">    <!-- 填充-->    <solid android:color="#00000000"/>    <!-- 描边 -->    <stroke        android:width="1dp"        android:color="#7F7F7F" />    <!-- 圆角 -->    <corners        android:radius="2dp" /></shape>

到此,相信大家对“Flexbox+ReclyclerView怎么实现流式布局”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯