android - Android 数据绑定生成的类成员类型错误
问题描述
我是 DataBinding 的新手,我一直在尝试根据指南设置绑定到示例应用程序。但是,当我创建名为“Data”的单独子文件夹将我的用户类放入其中并尝试运行它时,出现错误“无法访问类'Data.User'”。我想将我的类分开在不同的文件夹中(即制作 MVVM 结构)
我的活动代码:
package kozak.databindingtesting
import android.os.Bundle
import android.support.v7.app.AppCompatActivity
import android.databinding.DataBindingUtil
import kozak.databindingtesting.Data.User
import kozak.databindingtesting.databinding.ActivityMainBinding
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
val user = User("Marcin")
val binding = DataBindingUtil.setContentView<ActivityMainBinding>(this, R.layout.activity_main)
binding.user = user
}
}
用户等级:
package kozak.databindingtesting.Data;
public class User {
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String name;
public User(String name){
this.name=name;
}
}
活动布局:
<?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="user" type="kozak.databindingtesting.Data.User"/>
</data>
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/main_constraint_layout"
>
<TextView
android:id="@+id/x_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@{user.name}"/>
</android.support.constraint.ConstraintLayout>
</layout>
当我将此类粘贴到一般文件夹时,它工作正常。我在 gradle.properties 中有 android.databinding.enableV2=true,并在 gradle.build 中正确启用了 dataBinding - 如前所述,这个例子本身就可以正常工作。
PS请忽略fragment类,目前省略
解决方案
推荐阅读
- amazon-web-services - awscli列出ownerid创建的所有对象?
- python - 按日期将行透视到列 pandas
- c - 为什么 4 线程程序在 1 核 VM 上比在具有 4 核的同一 VM 上运行得更快?
- java - Elasticsearch嵌套排序 - 文档和用于排序的嵌套对象之间不匹配
- javascript - 使用原型时从类中获取方法
- c# - 阶乘计算器呈现一个负数,应该是正数。怎么修?
- sql - 使用 REPLACE 将回车添加到字符串不起作用
- vue.js - 如何从 Vue 组件返回多行?
- python - 在 Python Apache Beam 中计算 Google Cloud Storage 中的对象
- mysql - SELECT - 过滤掉符合条件的结果