Android databinding之RecycleView使用与介绍(二)

news2024/12/28 22:36:29

一 、介绍 

        通过上一篇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”开头的方法

3、notifyPropertyChanged(BR+id):

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

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

对应文件生成

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

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

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

相关文章

左(6)hash,大数据,位运算

前言 仅记录学习笔记&#xff0c;如有错误欢迎指正。 一、哈希函数和哈希表&#xff1a; hash()&#xff1a; (1) 输入是无限的&#xff0c;输出有限&#xff01; (2)相同的输入&#xff0c;相同的输出&#xff08;无随机因子&#xff09; (3)不同的输入&#xff0c;也可能相…

jQuery 语法

通过 jQuery&#xff0c;您可以选取&#xff08;查询&#xff0c;query&#xff09; HTML 元素&#xff0c;并对它们执行"操作"&#xff08;actions&#xff09;。 jQuery 语法 jQuery 语法是通过选取 HTML 元素&#xff0c;并对选取的元素执行某些操作。 基础语法…

【Python教学】pyqt6入门到入土系列,超详细教学讲解

一、什么是PyQt6? 简单介绍一下PyQt6 1、基础简介 PyQt6 Digia 公司的 Qt 程序的 Python 中间件。Qt库是最强大的GUI库之一。PyQt6的官网&#xff1a;www.riverbankcomputing.co.uk/news。PyQt6是由Riverbank Computing公司开发的 资料大礼包点击蓝色字体领取 Python零基础…

机器学习6scikit-learn中的scaler

文章目录一、scikit-learn中的scaler对测试数据集如何归一化&#xff1f;测试数据是模拟真实环境&#xff1a;综上二、演示一、scikit-learn中的scaler 对测试数据集如何归一化&#xff1f; 测试数据集不能跟训练数据集归一化一样&#xff0c;应该把测试数据集与训练数据集归…

Java JDK 环境变量配置教程

文章目录Java JDK 环境变量配置JDK 11 环境变量配置详细步骤Java JDK 环境变量配置 环境变量&#xff08;environment variables&#xff09;一般是指在操作系统中用来指定操作系统运行环境的一些参数&#xff0c;如&#xff1a;临时文件夹位置和系统文件夹位置等。 环境变量…

第二证券|抖音发布三季度安全透明度报告,整治贩卖焦虑广告近3万条

近来&#xff0c;抖音发布《2022年第三季度安全透明度陈述》(以下简称《陈述》)。《陈述》显现经过要点整治&#xff0c;渠道不标准表达削减超越30%&#xff0c;不实信息被告发量同比下降36.7%&#xff0c;整治贩卖焦虑广告2.9万条。一起&#xff0c;抖音还更新了《社区自律条约…

关于我对线程安全问题中死锁的理解

文章目录1.什么是死锁2.三个典型情况3.可重入与不可重入4.死锁的四个必要条件5.如何破除死锁1.什么是死锁 比如张三谈了一个女朋友&#xff0c;张三就对这个女朋友加锁了。 此时李四也看上了这个女生&#xff0c;但是他只能等待张三分手&#xff08;解锁&#xff09;后&#xf…

[附源码]计算机毕业设计保护濒危动物公益网站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…

赋能千百行加快 “5G+工业互联网”落地深耕

目前&#xff0c;我国5G基站已达196.8万个&#xff0c;“5G工业互联网”建设项目3100个&#xff0c;5G与工业互联网融合应用深入工业设计、制造、管理、服务等各环节&#xff0c;在促进传统企业提质降本增效的同时&#xff0c;不断拓展信息通信产业新蓝海。 记者从工信部获悉&a…

Nginx部署Vue前端项目

系统环境&#xff1a;Mac Pro—10.15.7版本 Nginx版本&#xff1a;1.19.6 一、安装Nginx brew install nginx 1、安装完成 Nginx的配置文件目录&#xff1a;/usr/local/etc/nginx Nginx的安装目录&#xff1a;/usr/local/Cellar/nginx 2、启动Nginx brew services star…

Linux虚拟机共享文件夹不显示问题终极解决方法

打开共享文件夹处查看一下&#xff0c;我的结果如下图&#xff08;没有显示共享文件内容&#xff09;&#xff1a; 接着打开终端&#xff1a; 输入命令&#xff1a;没有共享目录显示 解决方法&#xff1a; 输入&#xff1a;sudo apt-get install open-vm-tools 等待安装完 …

音乐在线教育解决方案,打造在线教育高品质教学体验

音乐是一种在时间中流动的形态&#xff0c;有节奏的音乐&#xff0c;能给人带来心理的快乐和艺术的享受&#xff0c;学一门乐器成为了很多人的选择。因此&#xff0c;音乐教育培训机构在搭建线上音乐课程时&#xff0c;就需要选择低延时、高同步、画质还原、高保真的技术方案&a…

基于轻量级CNN的12306验证码识别分析系统

在我很早的一篇文章中有写过图标型验证码识别的实践项目&#xff0c;这里主要是基于以往的实践经历做出的技术升级&#xff0c;包括&#xff1a;模型轻量化、界面开发、Grad-CAM热力图集成等。 话不多说&#xff0c;首先看效果&#xff1a; 基于CNN的轻量级12306验证码识别分析…

用Python预测世界杯球赛结果,还别说准确度还是蛮高的

前言 那么四年一度的世界杯即将要在卡塔尔开幕了&#xff0c;对于不少热爱足球运动的球迷来说&#xff0c;这可是十分难得的盛宴&#xff0c;而对于最后大力神杯的归属&#xff0c;相信很多人都满怀着期待&#xff0c;每个人心中都有不同的答案。 今天我就通过Python数据分析…

Word控件Spire.Doc 【图像形状】教程(10): 如何在C#中重置word文档的形状大小

Spire.Doc for .NET是一款专门对 Word 文档进行操作的 .NET 类库。在于帮助开发人员无需安装 Microsoft Word情况下&#xff0c;轻松快捷高效地创建、编辑、转换和打印 Microsoft Word 文档。拥有近10年专业开发经验Spire系列办公文档开发工具&#xff0c;专注于创建、编辑、转…

SEO优化之扁平化目录结构PbootCMS

在网站内部优化中&#xff0c;扁平化的目录结构对于一个网站来讲是非常有意义的。我们经常看到一些网站结构混乱&#xff0c;搞的你都不知道哪里是哪里了。而有的网站结构非常清晰&#xff0c;这样用户喜欢&#xff0c;搜索引擎也喜欢。而PbootCMS 2.0开始&#xff0c;系统也默…

2022,开发转测试,会不会后悔?

每个人做任何选择都是趋利避害的&#xff0c;当选择了认为对自己更有利的选择后&#xff0c;发现结果和期望不符&#xff0c;甚至发现大失所望&#xff0c;才会出现后悔的情绪。 那么为什么开发转测试就会后悔呢&#xff0c;只有一个原因&#xff1a; 那就是转到测试行业后&a…

PIL+pyplot+transforms.ToTensor+unsqueeze+div

目录PIL & pyplottransforms.ToTensortorch.unsqueeze(input,dim,outNone)torch.squeeze(input, dimNone, outNone)torch.divPIL & pyplot from PIL import Image import matplotlib.pyplot as plt from torchvision import transforms# PIL打开图片 img_PIL Image.o…

面试华为必备:华为18级技术官呕心沥血三年整理的 趣谈网络协议

华为是一个热门的互联网大厂&#xff0c;华为每年都要进很多新人&#xff0c;对于新人来说&#xff0c;那些高大上的技术是用不到的&#xff0c;反倒是非常需要这些基础的文档&#xff0c;有这些新手进步会快很多&#xff0c;搞清楚TCP IP协议栈&#xff0c;其他的学起来也就容…

运动规划问答 -路径规划

1、Dijstra算法&#xff0c;算法流程 关键 初始化&#xff1a; 算法是基于图搜索的思想&#xff0c;所以需要先构建一个图&#xff0c;图中不包含障碍物&#xff0c;读入起点和终点信息&#xff0c;设置一个以代价作为键值排序的multiMap&#xff0c;起点入队&#xff0c;并设…