Android databinding之RecycleView使用与讲解(二)

news2024/9/24 15:25:45

一 、介绍 

        通过上一篇databinding接入,我们已大概了解到databinding接入的流程和数据的简单绑定。

如果你刚看这边,并不了解databinding的使用,可以查看:Android databinding的接入使用与详解(一)

        Activity和fragment的数据绑定相对比较简单一些,在Android开发中recycleview使用频率也比较高。关于recycleview的数据绑定,接下来会做一个简单的介绍

二、Recycleview数据绑定

recycleview的数据绑定分为recycleview和adapter

1.RecycleView 

recycleview的view正常在布局中设置,如果你想要databind来初始化,按databind的布局设置即可。data节点可以不写

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">


        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/recycleview"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />

    </LinearLayout>
</layout>

这样就就会生成对应的文件。

class DataBindRecycleViewActivity : BaseActivity() {

    lateinit var databind: LayoutRecycleviewBinding;
    lateinit var adapter: MyAdapter

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        databind = DataBindingUtil.setContentView(this, R.layout.layout_recycleview)
        var manager = LinearLayoutManager(this)
        manager.orientation = LinearLayoutManager.VERTICAL
        databind.recycleview.layoutManager = manager

        adapter = MyAdapter(getData(), this);
        databind.recycleview.adapter = adapter
        adapter.notifyDataSetChanged()
        databind.recycleview.invalidate()
        databind.btnSubmit.setOnClickListener {
            toast("当前数据量:${databind.recycleview.childCount}")
        }


    }


    fun getData(): List<*> {

        var list = ArrayList<People>()
        for (i in 0 until 100) {
            var people = People()
            people.name = "我是第${i}"
            list.add(people)
        }

        return list
    }
}

2、adapter的databind处理

adapter核心在于如下几个地方

        ViewHolder继承

        onCreateViewHolder

        onBindViewHolder

接下来我们会分解一下这些区域

1.onCreateViewHolder

view的创建和fragment/Actvity不一样,这边的view创建是DataBindingUtil.inflate

 public static <T extends ViewDataBinding> T inflate(@NonNull LayoutInflater inflater,
            int layoutId, @Nullable ViewGroup parent, boolean attachToParent)

实战如下:

      var databind = DataBindingUtil.inflate<LayoutItemTextDatabindBinding>(
            LayoutInflater.from(context),
            R.layout.layout_item_text_databind,
            parent,
            false
        )

        var viewholder = ViewHolder(databind);
        return viewholder

2.ViewHolder继承

创建完view,这时候需要初始化view。

1.非databind创建

非databind直接继承RecyclerView.ViewHolder,然后通过构造器的itemview来初始化

    inner class ViewHolder(var root: View) :
        RecyclerView.ViewHolder(root) {


        var text = root.findViewById(R.id.text_title) as TextView


    }

2.databind完成ViewHolder的初始化

由于onCreateViewHolder中已完成了 databind常见,所以,view也同时完成了初始化

    inner class ViewHolder(var dtabind: LayoutItemTextDatabindBinding) :
        RecyclerView.ViewHolder(dtabind.root) {


        fun getDataBind(): LayoutItemTextDatabindBinding {
            return dtabind;
        }

    }

只需要将dataind.root传递给ViewHolder即可。无须再去初始化

3、onBindViewHolder数据绑定

数据绑定依旧在onBindViewHolder中进行。在绑定数据这边有两种

1、如果你是通过databind来完成,并且layout布局中已映射好,那我们只需要更新数据源即可。

    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
//        TODO("Not yet implemented")

        holder.dtabind.item =getItemObject(position)

    }

注意:如果采取映射,并且view中已绑定了,那我们在onBindViewHolder中不要再通过代码去设置,这样会导致recycleview不滑动,view虽然绘制,但是databind默认加载是空数据,这样就会导致是空白,只有滑动可见后,通过我们手动设置的数据取填充

错误写法:

    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
//        TODO("Not yet implemented")

        holder.dtabind.textTitle.text=getItemValue(position)


    }

异常显示

所以,如果你采取了databind,要去设置数据源,否则会有异常显示。

完整的Adapter如下:

package com.example.wiik.testdemo.databinding.recycleview

import android.content.Context
import android.view.LayoutInflater
import android.view.ViewGroup
import android.widget.TextView
import androidx.databinding.DataBindingUtil
import androidx.databinding.ViewDataBinding
import androidx.recyclerview.widget.RecyclerView
import com.example.wiik.testdemo.R
import com.example.wiik.testdemo.databinding.LayoutItemTextDatabindBinding
import com.example.wiik.testdemo.databinding.data.People

class MyAdapter(var list: List<*>, var context: Context) :
    RecyclerView.Adapter<MyAdapter.ViewHolder>() {


    override fun getItemCount(): Int {
//        TODO("Not yet implemented")
        return if (list == null) 0 else list.size
    }

    fun getItemValue(position: Int): String {

        var item = list?.get(position) as People
        return item.name
    }

    fun getItemObject(position: Int): People {
        var item = list?.get(position) as People
        return item
    }

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
//        TODO("Not yet implemented")

        var databind = DataBindingUtil.inflate<LayoutItemTextDatabindBinding>(
            LayoutInflater.from(context),
            R.layout.layout_item_text_databind,
            parent,
            false
        )

        var viewholder = ViewHolder(databind);
        return viewholder
    }


    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
//        TODO("Not yet implemented")

        holder.dtabind.item =getItemObject(position)

    }

    inner class ViewHolder(var dtabind: LayoutItemTextDatabindBinding) :
        RecyclerView.ViewHolder(dtabind.root) {


        fun getDataBind(): LayoutItemTextDatabindBinding {
            return dtabind;
        }

    }


}

XML布局如下:

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">

    <data>

        <import type="com.example.wiik.testdemo.databinding.data.People" />

        <variable
            name="item"
            type="People" />
    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">

        <TextView
            android:id="@+id/text_title"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:textSize="18dp"
            android:text="@{item.name}"
            android:textColor="@color/black"

            />

    </LinearLayout>
</layout>

数据源Bean:

class People : BaseObservable() {

    @get:Bindable
    var head = ""
        set(head) {
            field = head
            notifyPropertyChanged(BR.head)
        }


    @get:Bindable
    var address: String = ""
        set(value) {
            field = value
            notifyPropertyChanged(BR.address)
        }

    @get:Bindable
    var name: String = ""
        set(value) {
            field = value
            notifyPropertyChanged(BR.name)
        }

    @get:Bindable
    var age: Int = 0
        set(value) {
            field = value
            notifyPropertyChanged(BR.age)
        }


}

四、数据源的介绍

databind的数据源涉及到数据绑定,比如我这边使用了双向绑定,也就是说如果view的发送改变,bean对象数据也会发生改变

BaseObservable + @Bindable + notifyPropertyChanged()

1、BaseObservable :

        当数据发生变化,会通知更新view

2、Bindable:

        在get方法修饰,用于双方绑定,该注解用于标记实体类中的get方法或“is”开头的方法,会通过Bindable在BR中生成对应的fieldId(Int 型),如果未绑定,将无法生成,生成后便于

notifyPropertyChanged(BR.myname)更新,更新的机制是根据BR中id的记录
    @get:Bindable
    var myname = ""
    set(value) {
        field=value
        notifyPropertyChanged(BR.myname)
    }

3、notifyPropertyChanged(BR+id):

        当更新数据时,会更新BR下的id字段这个方法一般在set方法中使用

BR和其他文件生成如下,这边生成和AIDL的以及room数据库一样

对应文件生成

关于数据绑定,这边只做简单的介绍,后期会出完整的数据使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/56926.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Pr:导出设置之字幕

如果序列中包含字幕轨道&#xff0c;则导出设置中的字幕 CAPTIONS模块将提供用于处理字幕信息的选项。如果源序列不包含任何字幕轨道&#xff0c;此模块将被禁用。导出选项Export Options选择导出活动字幕轨道的方式。--无None若选择此项&#xff0c;则不以任何形式导出字幕。-…

flink状态与容错-1.13

1. 版本说明 本文档内容基于 flink-1.13.x&#xff0c;其他版本的整理&#xff0c;请查看本人博客的 flink 专栏其他文章。 2. Checkpoint 2.1. 概述 Checkpoint 使 Flink 的状态具有良好的容错性&#xff0c;通过 checkpoint 机制&#xff0c;Flink 可以对作业的状态和计算…

【Java实战】这样写代码与Bug说拜拜

目录 一、前言 二、OOP 规约 1.【强制】避免通过一个类的对象引用访问此类的静态变量或静态方法&#xff0c;无谓增加编译器解析成本&#xff0c;直接用类名来访问即可。 2.【强制】所有的覆写方法&#xff0c;必须加 Override 注解。 3.【强制】相同参数类型&#xff0c;相…

手把手教你成为荣耀开发者:账户结算操作指南

荣耀开发者服务平台是荣耀面向开发者的统一生态入口&#xff0c;通过聚合周边内外部系统&#xff0c;分全球多站点部署&#xff0c;为全球开发者提供业务全生命周期的商业支撑服务&#xff0c;拥有应用分发、智慧服务、开放能力、HONOR Connect等众多业务等您来合作。 账户结算…

408 考研《操作系统》第一章第二节:操作系统的发展与分类和操作系统的运行机制与体系结构

文章目录教程1. 操作系统的发展与分类1.1 手工操作阶段1.2 批处理阶段1.2.1 单道批处理系统1.2.2 多道批处理系统1.3 分时操作系统1.4 实时操作系统1.5 其他几种操作系统1.6 总结教程 操作系统的发展与分类https://www.bilibili.com/video/BV1YE411D7nH/?p4&share_source…

本周推荐 | mysql中业务系统可借鉴的设计

推荐语&#xff1a;学习优秀的开源系统来优化我们业务的架构设计&#xff0c;这是我们作为业务开发的必修课&#xff0c;这篇文章从经典的mysql系统原理引申到业务系统设计思考&#xff0c;让人耳目一新&#xff0c;值得我们学习。——大淘宝技术工程师 默达如果一个系统能存活…

HTML+CSS鲜花静态网页设计

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…

Win11的两个实用技巧系列之如何关闭文字热门搜索、任务栏上的应用

目录 in10和Win11 22H2如何关闭文字热门搜索? Win11 22H2关闭文字热门搜索 Win10 22H2关闭文字热门搜索 Win11中如何不用鼠标打开已固定在任务栏上的应用 鼠标的操作方式如下&#xff1a; 点击拿去 in10和Win11 22H2如何关闭文字热门搜索? 不管是Win10还是Win11&#…

R语言GARCH-DCC模型和DCC(MVT)建模估计

这个简短的演示说明了使用r软件包的DCC模型及其方法的使用&#xff0c;尤其是在存在MVT分布形状参数的情况下进行2级DCC估计的另一种方法。 最近我们被客户要求撰写关于GARCH-DCC的研究报告&#xff0c;包括一些图形和统计输出。 相关视频&#xff1a;时间序列分析&#xff…

[附源码]计算机毕业设计springboot小型银行管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

用HTML、CSS技术设计的个人网页与实现制作(web前端期末大作业)

&#x1f389;精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

“极致成本向左,本质安全向右”-谈谈锂电池储能系统的发展趋势

极致成本 or 本质安全? 1 快速增长的电化学储能电站 根据CNESA全球储能项目库的不完全统计,截至 2021 年底,全球已投运电力储能项目累计装机规模 209.4GW, 同比增长 9%。其中,抽水蓄能的累计装机规模占比首次低于 90%,比去年同期下降4.1个百分点;新型储能的累计装机规模…

Windows性能监视器使用说明

如何使用性能计数器 进入性能计数器 方式一&#xff1a; 命令行 perfmon 方式二&#xff1a;图形化操作 控制面板→系统与安全→管理工具→性能监视器 创建计数器收集器 创建收集器 在采集数据前&#xff0c;需要做好相应的收集器创建。 监视工具性能监视器&#xf…

Global Mapper将0-255的色彩映射表导出为RGB波段

当我们拿到0-255的色彩映射表栅格文件的时候&#xff0c;可能不太好用&#xff0c;需要导出为RGB波段或者其他波段形式的&#xff0c;在Global Mapper中可以做到。 打开0-255色彩映射表的栅格文件&#xff0c;在Arcmap中可以看到是这样的&#xff1a; 在Global Mapper中操作…

android灰色滤镜布局

android灰色滤镜布局 h5网页灰色滤镜 只要给 html 加下列css 样式就可以了 html {filter: progid:DXImageTransform.Microsoft.BasicImage(grayscale1);-webkit-filter: grayscale(100%); }Android组件灰色滤镜 ColorMartrix类&#xff0c;这个类对外提供了很多 API&#x…

重点问题!CPU利用率过高排查思路|原创

本文讲解了重点面试问题CPU利用率高如何排查和解决。点击上方“后端开发技术”&#xff0c;选择“设为星标” &#xff0c;优质资源及时送达CPU利用率高怎么办&#xff1f;如何排查和解决这是一个常见的面试问题&#xff0c;也是线上常遇到的问题之一。遇到线上服务器异常告警&…

【Win10】如何关闭Windows10自动更新

如何关闭Windows10自动更新 零、问题 Windows10老是自动更新&#xff0c;有时候第二天起来又得重新打开软件&#xff0c;真麻烦&#xff0c;Win10自动更新的时候还有点卡。 如何关闭&#xff1f; 经过上网查询&#xff0c;发现完全关闭难度比较大&#xff0c;但是我们可以选…

HTML学生个人网站作业设计 明星易烊千玺介绍(HTML+CSS) web前端开发技术 web课程设计 网页规划与设计

&#x1f389;精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

【信管2.5】项目可研(一)立项和可行性研究

项目可研&#xff08;一&#xff09;立项和可行性研究对于一个项目来说&#xff0c;最开始的步骤就是这个项目的立项过程。在这个过程中&#xff0c;我们要做的工作主要就是可行性研究。也就是说&#xff0c;这个项目值不值得我们来做&#xff0c;就需要对项目所涉及的领域、投…

fcpx插件:Stupid Raisins Grid Pop(网格弹出布局模板)

Stupid RAIsins Grid Pop是一款fcpx插件&#xff0c;可以在Final Cut Pro中快速布局任何网格弹出内容。为您轻松排队&#xff0c;均匀分配和安排任何物品&#xff01; 快速轻松地对齐fcpx中的所有内容&#xff01; Grid Pop是在Final Cut Pro X中进行布局&#xff0c;对齐和分布…