前言
之前已经讲过ViewBinding
在Activity
和Fragment
中的使用,大家有兴趣的话,可参考
ViewBinding(1) — 在Activity中使用
ViewBinding(2) — Activity中ViewBinding和include标签使用
ViewBinding(3) — ViewBinding在fragment中使用
这节我们讲讲ViewBinding
在Adapter
中的使用。
今天涉及内容:
- 布局中添加
RecycleView
控件 -
Activity
中RecycleView
加载数据 -
ViewBinding
在Adapter
中使用 - 效果图和项目结构图
一. 布局中添加 RecycleView 控件
先在MainActivity
对应的布局activity_main.xml
中添加RecycleView
控件:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".ui.MainActivity">
<TextView
android:id="@+id/tv_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.08" />
<Button
android:id="@+id/btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
android:text="点击"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/tv_name" />
<Button
android:id="@+id/btn2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
android:text="点击2"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn" />
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/rv"
android:layout_width="match_parent"
android:layout_height="150dp"
android:layout_marginTop="10dp"
app:layout_constraintTop_toBottomOf="@+id/btn2"
tools:layout_editor_absoluteX="0dp" />
<androidx.fragment.app.FragmentContainerView
android:id="@+id/fragment_container"
android:layout_width="match_parent"
android:layout_height="60dp"
app:layout_constraintBottom_toBottomOf="parent"/>
</androidx.constraintlayout.widget.ConstraintLayout>
二. Activity 中 RecycleView 加载数据
下面贴出Activity
中RecycleView
加载数据相关代码:
class MainActivity : AppCompatActivity(), View.OnClickListener {
private lateinit var mBingding: ActivityMainBinding
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
mBingding = ActivityMainBinding.inflate(layoutInflater)
setContentView(mBingding.root)
initData()
setListener()
}
private var initData = {
mBingding.tvName.text = "我是谁"
val list= mutableListOf("Java","Kotlin","C/C++","Python","HTML","Javascript")
mBingding.rv.layoutManager= LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false)
mBingding.rv.adapter=MyAdapter(list,this)
}
private var setListener={
LogUtil.i("====setListener=====")
mBingding.btn.setOnClickListener(this)
}
override fun onClick(v: View) {
when (v.id) {
R.id.btn -> {
LogUtil.i("====我点击了=====")
}
else -> {
}
}
}
}
三. ViewBinding 在 Adapter 中使用
先贴出适配器MyAdapter
对应的布局文件item_my.xml
代码:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".ui.MainActivity">
<TextView
android:id="@+id/tv_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingStart="60dp"
android:paddingEnd="60dp"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"/>
</androidx.constraintlayout.widget.ConstraintLayout>
接着贴出自定义适配器MyAdapter
的代码:
网友评论