首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >视图绑定与EpoxyModelWithHolder

视图绑定与EpoxyModelWithHolder
EN

Stack Overflow用户
提问于 2022-01-28 12:04:13
回答 1查看 671关注 0票数 0

我在一个Epoxy模型类中使用多个布局的EpoxyModelWithHolder。我该怎么做ViewBinding呢?目前,我正在使用Kotlin-android-extensions。下面是我的代码

代码语言:javascript
复制
@EpoxyModelClass
abstract class ItemSampleEpoxyModel : EpoxyModelWithHolder() {

@EpoxyAttribute
var itemSampleShelf: ComponentFactoryLanderPagesHeroShelf.ComponentLanderPageHeroShelf.ItemLanderPageHeroShelf? =
    null

override fun getDefaultLayout() =
    when {
        itemSampleShelf?.heroStyle == "Project" -> {
            R.layout.item_project_sample
        }
        itemSampleShelf?.shelfItemType == "Course" -> {
            R.layout.item_course_sample
        }
        else -> {
            R.layout.item_sample
        }
    }

override fun bind(itemHolder: ItemSampleEpoxyHolder) {
    itemHolder.titleView.text = itemSampleShelf?.title
} }



class ItemSampleEpoxyHolder : EpoxyHolder() {


lateinit var titleView: AppCompatTextView

override fun bindView(itemView: View) {
    titleView = itemView.tv_title
}}
EN

回答 1

Stack Overflow用户

发布于 2022-01-28 12:47:17

第一,增加环氧树脂的依赖性:

代码语言:javascript
复制
def epoxyVersion = '4.6.3'
implementation "com.airbnb.android:epoxy:$epoxyVersion"
implementation "com.airbnb.android:epoxy-databinding:$epoxyVersion"
kapt "com.airbnb.android:epoxy-processor:$epoxyVersion"

之后,我们需要配置环氧树脂。为了做到这一点,我们需要在app模块中创建一个包info.java文件,并编写以下代码。

代码语言:javascript
复制
@EpoxyDataBindingPattern(rClass = R.class, layoutPrefix = "epoxy_item")
interface Config {
}

然后,我们需要记住一件事,,每当我们创建布局时,它应该是一个data binding layout,它的名称应该遵循在package-info中的layoutPrefix变量中定义的值,例如,在我的示例中,layoutPrefix是epoxy_item,所以每当我命名一个布局时,它的名称都是以epoxy_item开头的。

示例布局:(布局名称-> epoxy_item_loading)

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>

  <layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">

<data>

    <variable
        name="isVisible"
        type="Boolean" />


</data>

<androidx.constraintlayout.widget.ConstraintLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:isVisible="@{isVisible}">

    <ProgressBar
        android:layout_width="20dp"
        android:layout_height="20dp"
        android:layout_marginTop="10dp"
        android:layout_marginBottom="10dp"
        android:theme="@style/ProgressBlueTheme"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
 </layout>

现在要将此布局添加到环氧树脂回收器视图中:

代码语言:javascript
复制
        epoxyRecycler.withModels {
               loading {
                id("progress layout")
                isVisible(isLoading)// boolean variable
            }
        }

这就是我们所需要做的:)

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70893492

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档