Android TV的行添加和行中数据项添加

首先需要为行(Row)创建自定义的Presenter。

Kotlin 复制代码
    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中。

Kotlin 复制代码
        // 手动添加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))
相关推荐
e***193535 分钟前
MySQL-触发器(TRIGGER)
android·数据库·mysql
不会写代码的猴子39 分钟前
Android16
android
@游子1 小时前
SQL注入之文件读写(四)
android·数据库·sql
b***66611 小时前
【慕伏白教程】Zerotier 连接与简单配置
android·前端·后端
城东米粉儿1 小时前
PropertyValuesHolder与Keyframe 笔记
android
W.Y.B.G1 小时前
vue3项目中集成天地图使用示例
android·前端
Haha_bj1 小时前
二、Kotlin数组(Array)
android·app
t***26591 小时前
万字详解 MySQL MGR 高可用集群搭建
android·mysql·adb
参宿四南河三2 小时前
Android Jetpack 存储篇(DataStore、Room)与 Flow 高效组合
android·app
y***13642 小时前
【MySQL】MVCC详解, 图文并茂简单易懂
android·数据库·mysql