首先需要为行(Row)创建自定义的Presenter。
private class GridItemPresenter : Presenter(){
override fun onCreateViewHolder(parent: ViewGroup?): ViewHolder {
val view = TextView(parent.context) // 此处以一个简单的TextView为示例,可根据需求自定义复杂的数据结构
view.apply {
layoutParams = ViewGroup.LayoutParams(GRID_ITEM_WIDTH, GRID_ITEM_HEIGHT) // 为单个卡片设定宽高
isFocusable = true
isFocusableInTouchMode = true
setBackgroundColor(ContextCompat.getColor(context, R.color.default_background)) // 参考值#3d3d3d
setTextColor(Color.WHITE)
gravity = Gravity.CENTER
}
return Presenter.ViewHolder(view)
}
// 绑定数据,为每个view赋值
override fun onBindViewHolder(viewHolder: ViewHolder?, item: Any?) {
(viewHolder?.view as TextView).text = item as String
}
override fun onUnbindViewHolder(viewHolder: ViewHolder?) {}
}
Presenter的作用是将View添加到Row中,类似RecyclerView的Adater。
之后使用我们自定义的Presenter,用于手动添加单个view到Row中。
// 手动添加Row
val gridHead = HeaderItem(TabList.size.toLong(), "可手动添加项")
// 手动添加View到Row中
val mGridPresenter = GridItemPresenter()
val girdRowAdapter = ArrayObjectAdapter(mGridPresenter)
girdRowAdapter.apply {
add("Grid View")
add("Error Page")
add("Settings")
}
// 将我们新增的Row添加到页面的adapter
rowsAdapter.add(ListRow(gridHead, girdRowAdapter))