android - 在绑定适配器上传递视图 ID?
问题描述
我一直在尝试将 viewpager id 传递给绑定适配器方法。我在这条线上得到错误
setUpViewPager="@{(main_viewpager)}"
我在上面一行的这个“}”符号下得到这个错误
'->' or <expr> expected
这是我的 xml 文件
<?xml version="1.0" encoding="utf-8"?>
<layout>
<data>
<variable
name="viewModel"
type="com.example.project_budget_planner.main.MainViewModel" />
<variable
name="adapter"
type="com.example.project_budget_planner.main.TabBarAdapter" />
</data>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".main.MainActivity">
<com.example.project_budget_planner.shared.NonSwipableViewPager
android:id="@+id/main_viewpager"
android:layout_width="match_parent"
android:layout_height="0dp"
setAdapter="@{adapter}"
app:layout_constraintBottom_toTopOf="@+id/main_tab_layout"
app:layout_constraintTop_toTopOf="parent" />
<com.google.android.material.tabs.TabLayout
android:id="@+id/main_tab_layout"
android:layout_width="match_parent"
android:layout_height="70dp"
setUpViewPager="@{(main_viewpager)}"
app:layout_constraintBottom_toBottomOf="parent"/>
</androidx.constraintlayout.widget.ConstraintLayout>
</layout>
这是我的绑定适配器方法
@BindingAdapter("setUpViewPager", "setAdapterForIcons")
@JvmStatic fun bindViewPagerAndIcons(view: TabLayout, viewPager: ViewPager, tabBarAdapter: TabBarAdapter) {
view.setupWithViewPager(viewPager)
for (i in 1 until tabBarAdapter.count) {
view.getTabAt(i)?.let { it.setIcon(tabBarAdapter.getItem(i).icon) }
}
}
我该如何解决这个问题?
解决方案
像使用 mainViewpager
setUpViewPager="@{mainViewpager}"
它会工作
推荐阅读
- r - 如何使用 tmap 为每个坐标赋予另一种颜色
- java - 在 Java8 中清理数据列表
- reactjs - 通用类型'异步
' 需要使用 React Select 的 AsyncSelect 的 1 个类型参数 - java - 为什么我的 firestore 函数返回 null 给我的应用程序?
- python - 如何在 Python 中自动读取多个测试用例,其中测试用例存储在记事本文件中?
- mysql - MySQL:将字符串与查询结果进行比较
- vue.js - 无法将选中的值从自定义复选框组件传递给父组件
- javascript - 如何在 Owl Carousel 中只显示单个项目?
- reactjs - Reactjs:使用 axios 调用 Api
- pandas - 按聚合函数分组以进行乘法