在上一篇文章:使用Kotlin开发Android 创建工程与配置 主要是Kotlin相关的配置,这一篇主要是Kotlin Android Extensions
Kotlin Android Extensions
我们在使用Java时,findViewById是比较麻烦的,通过控件的ID来查找控件,当然也有第三方框架ButterKnife,Dagger等来减少findViewById的使用,通过插件自动生成,但在使用Kotlin时,便不必如此。在app的Gradle下添加
apply plugin: 'kotlin-android-extensions'
Paste_Image.png
使用扩展函数的好处
在Kotlin官方文档中对ButterKnife类似的库是这样介绍
Being libraries dependent on runtime, they require annotating fields for each View
也就是说类似ButterKnife这类库,在运行时,需要对每一个控件进行注解。而对于Kotlin, 官方是这样介绍
The Kotlin Android Extensions plugin allows us to obtain the same experience we have with some of these libraries, without having to add any extra code or shipping any additional runtime.
Kotlin提供类似于这些库的相同体验,但不需要额外的代码和运行时间。我自己理解为减少findViewById的使用的同时,没有产生额外的代码,也不用在运行时对每个控件进行注解。
第一个项目 木子饼干
然后在xml文件里给TextView和Button添加一个Id,直接在MainActivity中
import kotlinx.android.synthetic.main.activity_main.*
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
main_text.text = "木子饼干"
main_button.setOnClickListener {
val intent =Intent(this,RecyclerViewActivity::class.java)
startActivity(intent)
}
}
注意要导包import kotlinx.android.synthetic.main.activity_main.*,一般情况下Android Studio会自动添加这一句,格式一般为
import kotlinx.android.synthetic.main.<layout>.*
<layout>为控件所在的布局文件,不同于Java ,在声明一个变量时,需要在变量前说明类型,Kotlin 一般使用val 和 var, var声明的变量是可变的,val 声明的变量是不可变的,同时也省略new关键字。运行如图
Paste_Image.png在Adapter中的用法也类似,在布局文件中给控件添加ID,
Paste_Image.png在Adapter中直接使用ID
Paste_Image.pngAndroid Studio也会导入相应的包,格式一般为
import kotlinx.android.synthetic.main.<layout>.view.*
此处RecyclerVIew的布局文件为recycler_item ,因此这里为
Paste_Image.png简单的列表展示Demo
和新建Java类类似,新建Kotlin类只要在New的时候选择Kotlin File/Class
Paste_Image.png在小弹框中选择Class,输入名称即可,我这里是RecyclerViewAdapter
Paste_Image.png
不同于平常的Adapter,Kotlin的Adapter可以在类名后直接加入调用时要传入的参数,相当于Java类中的Adapter的构造函数,Viewholder也不需要findViewById,也是直接使用ID,这里贴出代码
class RecyclerViewAdapter(val context: Context, val list: List<String>) : RecyclerView.Adapter<RecyclerViewAdapter.RecyclerHolder>() {
override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): RecyclerHolder {
return RecyclerHolder(LayoutInflater.from(context).inflate(R.layout.recylcer_item, parent, false))
}
override fun getItemCount(): Int {
return list.size
}
override fun onBindViewHolder(holder: RecyclerHolder, position: Int) {
val s = list.get(position)
holder.itemView.item_text.text = s
}
class RecyclerHolder(itemView: View?) : RecyclerView.ViewHolder(itemView) {
}
}
在Activity中使用也相对简单,Kotlin 的for循环相对于java也有不同,不用声明 i变量,代码中的?意思我理解为否,?=也就是不等于空,这也是Kotlin相对于Java的优点,可以避免空指针,缺少?,AS会报错提示,或者可以再null后面添加!!,断言不为空。代码中..表示xx到xx,也就是一个范围
class RecyclerViewActivity : AppCompatActivity() {
var adapter:RecyclerViewAdapter ?= null
// var adapter:RecyclerViewAdapter = null!!
var list =ArrayList<String>()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_recycler_view)
initView()
}
fun initView() {
for (i in 0 ..20){
list.add("木子饼干" + i)
}
recyclerView.layoutManager = LinearLayoutManager(this)
adapter = RecyclerViewAdapter(this,list)
recyclerView.adapter = adapter
}
}
运行如图
Paste_Image.png
代码地址:KotlinDemo
网友评论
已经添加这行,为什么在页面import时 ,引用不到kotlinx... ?