ViewBinding遇到include的时候怎么玩

2020年11月11日,更新用法:Android ViewBinding更新,include得到优化
ViewBinding根据xml来生成单个binding文件,通过资源id来生成对应字段,比如:

fragment_tab_me里引入include_mine_head_layout

<!--布局 fragment_tab_me-->
<LinearLayout
	android:orientation="vertical"
	android:layout_width="match_parent"
    android:layout_height="match_parent" >
	
	<!--引入布局 include_mine_head_layout-->
	<include layout="@layout/include_mine_head_layout" />
</LinearLayout>

基于ViewBinding的inflate方法,使用时可能想到:

 // 在Fragment使用
 private lateinit val mLayout: FragmentTabMeBinding
 
 override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
 		mLayout = FragmentTabMeBinding.inflate(inflater,container,false)
		mHeadLayout =  IncludeMineHeadLayoutBinding.inflate(inflater)
	return mLayout.root
 }

但实际上你如下直接使用其实是无效的

// 使用引用布局里的控件
mHeadLayout.tvName.text = "name"
mHeadLayout.tvName.setOnclickListener{ ... }

一、 方式1

如果引入的xml文件外层有包裹<merge></merge>标签,可以使用bind方法,传入父布局的rootView

private lateinit val mLayout: FragmentTabMeBinding
private lateinit val mLayout: IncludeMineHeadLayoutBinding
 
// 使用bind(view: View),给引入的布局绑定
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
        mLayout = FragmentTabMeBinding.inflate(inflater,container,false)
        mHeadLayout = IncludeMineHeadLayoutBinding.bind(mLayout.root)
        return mLayout.root
    }
    

再这样使用就没问题了

mHeadLayout.tvName.text = "name"

二、方式2

常规的方式通过id也能实现,例如:

<include
	android:id="@+id/include_head"
    layout="@layout/include_mine_head_layout" />
    
// 就好比 mLayout.findViewById(R.id.include_head).tvName.text = "name"
mLayout.includeHead.tvName.text = "name"
Logo

Agent 垂直技术社区,欢迎活跃、内容共建,欢迎商务合作。wx: diudiu5555

更多推荐