val binding by inflate()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding.title.text = “XXX”
}
}
好像这样还可以,不能再省了,毕竟T这个是死的,必须要单独设置。
如果是Dialog,同样也可以创建类似的拓展函数:
inline fun Dialog.inflate() = lazy {
inflateViewBinding(layoutInflater).apply { setContentView(root) }
}
基类
不过这样还是要创建一个变量binding,能不能也省了呢?回到最初的基类设计,既然都用反射了,那就把这块逻辑都放基类吧。
abstract class BaseBindingActivity : BaseActivity() {
protected lateinit var binding: T
@Suppress(“UNCHECKED_CAST”)
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val type = javaClass.genericSuperclass
if (type is ParameterizedType) {
val clazz = type.actualTypeArguments[0] as Class
val method = clazz.getMethod(“inflate”, LayoutInflater::class.java)
binding = method.invoke(null, layoutInflater) as T
contentView = binding.root
}
}
}
这样我们的调用终于干净了。
class PocketSquareActivity : BaseBindingActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding.title.text = “XXX”
}