文章目录

  • I . 视图绑定 ( ViewBinding ) 界面的两种方式
  • II . Activity 界面中 应用 视图绑定 ( ViewBinding )
  • III . Dialog 对话框界面中 应用 视图绑定 ( ViewBinding )
  • IV . 自定义组件 应用 视图绑定 ( ViewBinding )
  • V . RecyclerView 列表布局 应用 视图绑定 ( ViewBinding )
  • VI . GitHub 代码地址

I . 视图绑定 ( ViewBinding ) 界面的两种方式


1 . ViewBinding 视图绑定类提供了两种与界面的绑定方式 , 分别是

① XxxBinding.inflate( LayoutInflater )

② XxxBinding.inflate( LayoutInflater , ViewParent, attachToRoot )

两种方式 ; ( XxxBinding 是视图绑定类 )

2 . XxxBinding.inflate( LayoutInflater ) 与界面绑定 : 这种方式加载的布局与界面关联性不大 , 需要调用额外的函数 , 将视图绑定类与界面进行绑定 , Activity 界面 与 Dialog 对话框 , 就使用这种绑定方式 ;

3 . XxxBinding.inflate( LayoutInflater , ViewParent, attachToRoot ) 直接与界面绑定 : 自定义布局组件 和 RecyclerView 适配器中为条目加载布局选项 , 就是使用的这种方式 , 调用该方法后 , 可以直接与界面进行绑定 , 界面中显示的就是 XxxBinding 对应的布局内容 ;

II . Activity 界面中 应用 视图绑定 ( ViewBinding )


Activity 界面中 应用 视图绑定 ( ViewBinding ) :

① 获取视图绑定类 : 使用 ActivityMainBinding.inflate(getLayoutInflater()) 只是单纯的加载布局 ;

② 关联界面 : 还需要调用 setContentView(binding.getRoot()) 方法 , 将 视图绑定类与 Activity 界面关联 , 此时才能通过视图绑定类获取组件 , 进而控制 UI 界面 ;

public class MainActivity extends AppCompatActivity {/*** 视图绑定类 对象*/private ActivityMainBinding binding;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// 1 . 获取视图绑定类binding = ActivityMainBinding.inflate(getLayoutInflater());// 2 . 关联视图绑定类 与 ActivitysetContentView(binding.getRoot());// 3 . 使用视图绑定类设置binding.textView.setText("视图绑定 ( ViewBinding ) 示例");// 4 . 视同视图绑定类获取按钮 , 并未按钮设置点击事件binding.button.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {ViewBindingDialog dialog = new ViewBindingDialog(MainActivity.this);dialog.show();}});// 5 . 设置 Recycler View// 5.1  为 RecyclerView 列表设置布局管理器LinearLayoutManager layoutManager = new LinearLayoutManager(this);layoutManager.setOrientation(RecyclerView.VERTICAL);binding.recyclerView.setLayoutManager(layoutManager);// 5.2 为 RecyclerView 列表设置适配器binding.recyclerView.setAdapter(new Adapter());}
}

III . Dialog 对话框界面中 应用 视图绑定 ( ViewBinding )


Dialog 对话框界面中 应用 视图绑定 ( ViewBinding ) : 该界面与 Activity 界面用法基本相同 ;

① 获取视图绑定类 : 使用 DialogBinding binding = DialogBinding.inflate(getLayoutInflater()) 只是单纯的加载布局 ;

② 关联界面 : 还需要调用 setContentView(binding.getRoot()) 方法 , 将 视图绑定类与 Dialog 对话框界面关联 , 此时才能通过视图绑定类获取组件 , 进而控制 UI 界面 ;

package kim.hsl.vb;import android.app.Dialog;
import android.content.Context;
import android.os.Bundle;
import android.util.AttributeSet;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.recyclerview.widget.RecyclerView;import kim.hsl.vb.databinding.DialogBinding;public class ViewBindingDialog extends Dialog {public ViewBindingDialog(@NonNull Context context) {super(context);}public ViewBindingDialog(@NonNull Context context, int themeResId) {super(context, themeResId);}protected ViewBindingDialog(@NonNull Context context, boolean cancelable,@Nullable OnCancelListener cancelListener) {super(context, cancelable, cancelListener);}@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// 1 . 获取视图绑定类DialogBinding binding = DialogBinding.inflate(getLayoutInflater());// 2 . 设置对话框布局setContentView(binding.getRoot());// 3 . 通过视图绑定类访问布局中的视图组件binding.textView.setText("视图绑定对话框示例 \nDialogBinding");// 4 . 设置对话框大小 ( 仅做参考 美观处理 与主题无关 )WindowManager.LayoutParams params = getWindow().getAttributes();params.width = WindowManager.LayoutParams.MATCH_PARENT;params.height = 400;getWindow().setAttributes(params);}
}

效果展示 :

IV . 自定义组件 应用 视图绑定 ( ViewBinding )


自定义组件 应用 视图绑定 ( ViewBinding ) :

① 自定义组件首先是 ViewGroup 子类 , View 子类无法使用视图绑定 ;

② 初始化视图绑定类并关联界面 : 使用 MyViewBinding binding = MyViewBinding.inflate(inflater, this, true) 进行视图绑定初始化 , 及 关联界面操作 , 其中的 this 就是 ViewGroup 类型的 , 即组件本身 , 调用上述方法 , 可以将两个操作都完成 ;

package kim.hsl.vb;import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.os.Build;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.LinearLayout;import androidx.annotation.Nullable;
import androidx.annotation.RequiresApi;import kim.hsl.vb.databinding.MyViewBinding;public class ViewBindingView extends LinearLayout {/*** 在代码中创建组件调用该构造函数* @param context*/public ViewBindingView(Context context) {super(context);}/*** 在 xml 布局文件中使用该组件 , 并且还定义了自定义属性 , 调用该构造函数* @param context* @param attrs*/public ViewBindingView(Context context, @Nullable AttributeSet attrs) {super(context, attrs);// 1 . 获取布局加载器LayoutInflater inflater = LayoutInflater.from(this.getContext());// 2 . 获取视图绑定类//     需要将视图绑定类 与 本自定义 LinearLayout 进行关联MyViewBinding binding = MyViewBinding.inflate(inflater, this, true);// 3 . 通过视图绑定类访问布局中的 TextView 布局binding.textView.setText("视图绑定自定义组件示例\nMyViewBinding");}public ViewBindingView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);}@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)public ViewBindingView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {super(context, attrs, defStyleAttr, defStyleRes);}@Overrideprotected void onDraw(Canvas canvas) {super.onDraw(canvas);//绘制黄色背景canvas.drawColor(Color.YELLOW);}
}

V . RecyclerView 列表布局 应用 视图绑定 ( ViewBinding )


RecyclerView 列表布局 应用 视图绑定 ( ViewBinding ) :

① 视图绑定需要在 Adapter 适配器的 onCreateViewHolder( ) 方法中进行初始化 , 只有在这里才能拿到 ViewGroup parent 关联组件的父类容器 ;

② 初始化视图绑定类并关联界面 : 使用 ItemBinding binding = ItemBinding.inflate(LayoutInflater.from(MainActivity.this) , parent, false) 进行视图绑定初始化 , 及 关联界面操作 , 其中的 this 就是 ViewGroup 类型的 , 即组件本身 , 调用上述方法 , 可以将两个操作都完成 ;

③ 自定义 ViewHolder 构造函数 : public ViewHolder(ItemBinding binding) 传入视图绑定类 , 在构造函数中使用视图绑定类初始化 ViewHolder 中的组件 , 注意别忘了先调用父类的方法 ;

    class Adapter extends RecyclerView.Adapter<Adapter.ViewHolder>{@NonNull@Overridepublic ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {ItemBinding binding = ItemBinding.inflate(LayoutInflater.from(MainActivity.this) , parent, false);return new ViewHolder(binding);}@Overridepublic void onBindViewHolder(@NonNull ViewHolder holder, int position) {holder.textView.setText("第 " + position + " 行");if(position % 2 == 0){holder.textView.setBackgroundColor(Color.YELLOW);}else{holder.textView.setBackgroundColor(Color.WHITE);}}@Overridepublic int getItemCount() {return 10;}class ViewHolder extends RecyclerView.ViewHolder{TextView textView;/*** 自定义的构造函数 , 需要传入 视图绑定类* @param binding*            列表项布局的视图绑定类*/public ViewHolder(ItemBinding binding) {super(binding.getRoot());this.textView = binding.textView;}}}

效果展示 :

VI . GitHub 代码地址


GitHub 代码地址 : https://github.com/han1202012/001_JetPack_ViewBinding

【JetPack】视图绑定 ( ViewBinding ) 各种应用 ( 视图绑定两种方式 | Activity 布局 | 对话框布局 | 自定义组件布局 | RecyclerView 列表布局 )相关推荐

  1. oracle并行parallel update两张表_Oracle并行更新的两种方式(merge/update内联视图)

    对于Oracle的两表联合更新的场景(有A.B两表,以A.id=B.id关联,根据B表中的记录更新A表中的相应字段),一般有update内联视图和merge两种方式,下面举例介绍: 创建用例表: cr ...

  2. SQLServer:GUI方式、SQL语句两种方式建立视图和GUI方式设置主键、约束等

    SQLServer:GUI方式.SQL语句两种方式建立视图和GUI方式设置主键.约束等 目录 题目要求 解题流程 (1).建立视图 (2)GUI方式设置主键.约束等 ​ 题目要求 基于表DEPT01和 ...

  3. java两种绑定方式_Javascript绑定事件的两种方式的区别

    命名函数 function check(){ //code } 匿名函数 window.onload = function(){ //先获取元素对象,再绑定事件,绑定的是匿名函数不可重用 var bt ...

  4. SpringBoot配置绑定的两种方式

    SpringBoot配置绑定的两种方式 演示文件 bean public class Student {private String name;private Integer age;public S ...

  5. drf-路由组件:自动生成Routers路由、 使用方法、视图集中附加action的声明、自动生成路由router的两种方式的URL区别

    目录 一. 自动生成Routers路由 二. 使用方法 1) 创建router对象,并注册视图集,例如 2)添加路由数据 三. 代码演示 四. 视图集中附加action的声明 五. 自动生成路由rou ...

  6. MVVM处理TreeView的SelectedItem的绑定的两种方式

    TreeView的SelectedItem不支持MVVM绑定: 因为它是只读的. 有时候我们就需要对它进行绑定 最新经过测试的解决方案(附加属性的方式) 参考:https://stackoverflo ...

  7. 创建二叉树的代码_解二叉树的右视图的两种方式

    给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值. 示例: 问题分析 这题说的很明白,就是站在一棵二叉树的右边,你所能看到的结点值.对于二叉树的遍历,前面有简单 ...

  8. 啥是双向绑定,两种方式实现两个简单双向绑定

    看代码 <input type="text"><script>let ipt = document.querySelector("input&qu ...

  9. Android中通过数组资源文件xml与适配器两种方式给ListView列表视图设置数据源

    场景 实现效果如下 注: 博客: https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 获取编程相关电子书.教程推送与免费下载. 实现 将布局改 ...

最新文章

  1. 深入探讨Varnish缓存命中率
  2. CentOS7中MariaDB重置密码
  3. Linux中的文件描述符与打开文件之间的关系
  4. objective-c 2.0的字面量Literals
  5. 商业逻辑12讲之战略管理的逻辑
  6. python以什么表示代码层次_python 中几个层次的中文编码.md
  7. python装饰器_Python基础-装饰器
  8. Azure Services Platform
  9. 中电海康建车联网透明路 探索新型智慧城市商机
  10. scrapy tool 命令
  11. java opencv教程_史上最全 java 集成 opencv 教程
  12. Java飞机大战 项目-源码
  13. java long型时间戳_深入理解java long 存储时间戳
  14. docker部署分布式应用_Docker服务,堆栈和分布式应用程序捆绑
  15. Faster:一个高效就地更新的并发键值存储
  16. php实现的简单问卷调查系统
  17. v4l2框架—申请缓存(VIDIOC_REQBUFS)
  18. MySQL的下载与安装详细教程
  19. 苹果官方首曝iOS 15!这些经典iPhone都要被弃
  20. 【广州华锐互动】VR数字虚拟展厅为企业提升品牌形象和知名度

热门文章

  1. Python学习教程:Python爬虫抓取技术的门道
  2. hbase 问题整理
  3. 分享.Net 设计模式大全
  4. SpringBoot 2.0 编程方式配置,不使用默认配置方式
  5. ECharts 之 环形图
  6. Spring Boot由jar包转成war包
  7. microsoft visual sourcesafe explorer 获取不了文件夹的解决方法
  8. 算法学习:回文自动机
  9. tinyMce在线编辑器内JavaScript实现按Ctrl+S无刷新保存
  10. Oracle数据库----函数