- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在我的应用程序中使用 Realm,但没有成功。问题似乎是我在同一个应用程序中使用数据绑定(bind)和 Realm 。
目标是让用户使用 View 输入我通过数据绑定(bind)获得的一些数据,并插入到 Realm 数据库中
我有以下错误:
Character is not part of the schema for this Realm
at io.realm.internal.modules.CompositeMediator.getMediator(CompositeMediator.java:172)
at io.realm.internal.modules.CompositeMediator.getTableName(CompositeMediator.java:90)
at io.realm.RealmSchema.getTable(RealmSchema.java:296)
at io.realm.Realm.createObjectInternal(Realm.java:817)
at io.realm.Realm.createObject(Realm.java:801)
这是我的角色声明
@RealmClass
public class Character extends RealmObject implements Serializable
private String classGame;
private String name;
private RealmList<Item> equipments;
private RealmList<CaracteristicClass> caracteristicClasses;
private RealmList<Caracteristic> parchemin;
private RealmList<Caracteristic> caracteristics;
private RealmList<Sort> spells;
private int nbCaracteristicPointAvailable;
private ObservableField<String> nbCaracteristicPointAvailableStringOb;
private int level;
private String levelString;
public Character() {
initCharacter();
}
private void initCharacter(){
nbCaracteristicPointAvailableStringOb = new ObservableField<>();
caracteristics = new RealmList<>();
parchemin = new RealmList<>();
spells = new RealmList<>();
/*
* Init base caracteristic
*/
Caracteristic caracteristic = new Caracteristic(TypeCaracteristic.VITALITE.toString(),0,0,11,0);
caracteristics.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.SAGESSE.toString(),0,0,12,0);
caracteristics.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.FORCE.toString(),0,0,13,0);
caracteristics.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.INTELLIGENCE.toString(),0,0,14,0);
caracteristics.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.CHANCE.toString(),0,0,15,0);
caracteristics.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.AGILITE.toString(),0,0,16,0);
caracteristics.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.LEVEL.toString(),1,200,-1,200);
caracteristics.add(caracteristic);
/*
* Parchemin caractéristique
*/
caracteristic = new Caracteristic(TypeCaracteristic.VITALITE.toString(),0,100,11,100);
parchemin.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.SAGESSE.toString(),0,100,12,100);
parchemin.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.FORCE.toString(),0,100,13,100);
parchemin.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.INTELLIGENCE.toString(),0,100,14,100);
parchemin.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.CHANCE.toString(),0,100,15,100);
parchemin.add(caracteristic);
caracteristic = new Caracteristic(TypeCaracteristic.AGILITE.toString(),0,100,16,100);
parchemin.add(caracteristic);
caracteristicClasses = new RealmList<>();
CaracteristicClass caracteristicClass = new CaracteristicClass(0,TypeCaracteristic.VITALITE.toString(),1);
caracteristicClasses.add(caracteristicClass);
caracteristicClass = new CaracteristicClass(0,TypeCaracteristic.SAGESSE.toString(),3);
caracteristicClasses.add(caracteristicClass);
caracteristicClass = new CaracteristicClass(0,TypeCaracteristic.AGILITE.toString(),1);
caracteristicClasses.add(caracteristicClass);
caracteristicClass = new CaracteristicClass(0,TypeCaracteristic.CHANCE.toString(),1);
caracteristicClasses.add(caracteristicClass);
caracteristicClass = new CaracteristicClass(0,TypeCaracteristic.FORCE.toString(),1);
caracteristicClasses.add(caracteristicClass);
caracteristicClass = new CaracteristicClass(0,TypeCaracteristic.INTELLIGENCE.toString(),1);
caracteristicClasses.add(caracteristicClass);
}
public Character(final String name, final int level ){
initCharacter();
}
public String getClassGame() {
return classGame;
}
public void setClassGame(String classGame) {
this.classGame = classGame;
}
public String getName(){
return name;
}
public void setName(String name) {
this.name = name;
}
public RealmList<Item> getEquipments() {
return equipments;
}
public void setEquipments(RealmList<Item> equipments) {
this.equipments = equipments;
}
public RealmList<Caracteristic> getParchemin() {
return parchemin;
}
public void setParchemin(RealmList<Caracteristic> parchemin) {
this.parchemin = parchemin;
}
public RealmList<Caracteristic> getCaracteristics() {
return caracteristics;
}
public void setCaracteristics(RealmList<Caracteristic> caracteristics) {
this.caracteristics = caracteristics;
}
public RealmList<Sort> getSpells() {
return spells;
}
public void setSpells(RealmList<Sort> spells) {
this.spells = spells;
}
public int getLevel() {
return level;
}
public String getLevelString() {
return levelString;
}
public ObservableField<String> getNbCaracteristicPointAvailableStringOb() {
return nbCaracteristicPointAvailableStringOb;
}
public void setNbCaracteristicPointAvailableStringOb(String nbCaracteristicPointAvailableStringOb) {
this.nbCaracteristicPointAvailableStringOb.set(nbCaracteristicPointAvailableStringOb);
this.nbCaracteristicPointAvailableStringOb.notifyPropertyChanged(BR.character);
}
public void setLevelString(String levelString) {
this.levelString = levelString;
try{
if(!this.levelString.equals("")){
this.level = Integer.parseInt(this.levelString);
if(level>0 && level<=Constants.MAX_LEVEL){
nbCaracteristicPointAvailable = (level -1) * 5;
this.setNbCaracteristicPointAvailableStringOb(String.valueOf(nbCaracteristicPointAvailable));
}
}
}catch (NumberFormatException ex){
Log.i("Character","emptyString or Invalid");
}
}
这里是我的模块 build.gradle
apply plugin: 'com.android.application'
apply plugin: 'realm-android'
apply plugin: 'com.jakewharton.butterknife'
android {
compileSdkVersion 25
buildToolsVersion "25.0.1"
defaultConfig {
applicationId "*******"
minSdkVersion 15
targetSdkVersion 25
versionCode 1
versionName "0.0.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
dataBinding{
enabled = true;
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
androidTestCompile('com.android.support.test.espresso:espresso- core:2.2.2', {
exclude group: 'com.android.support', module: 'support-annotations'
})
compile 'com.android.support:appcompat-v7:25.0.1'
compile 'com.android.support:design:25.0.1'
compile 'com.android.support.constraint:constraint-layout:1.0.0-beta4'
compile 'com.android.support:appcompat-v7:25.0.1'
compile 'com.android.support:recyclerview-v7:25.0.1'
compile 'com.android.support:cardview-v7:25.0.1'
compile 'com.android.support:support-v4:25.0.1'
compile 'pl.droidsonroids.gif:android-gif-drawable:1.2.3'
compile 'com.github.amlcurran.showcaseview:library:5.0.0'
compile 'org.jsoup:jsoup:1.7.3'
compile 'com.android.support:design:25.0.1'
compile 'com.google.android.gms:play-services-appindexing:9.8.0'
compile 'com.jakewharton:butterknife:8.4.0'
compile 'com.android.support.constraint:constraint-layout:1.0.0-beta4'
compile 'org.apache.commons:commons-collections4:4.1'
compile 'org.apache.commons:commons-lang3:3.4'
annotationProcessor 'com.jakewharton:butterknife-compiler:8.4.0'
testCompile 'junit:junit:4.12'
compile project(path: ':androidhttprequestlibrairy')
这里是我的项目build.gradle
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.0-alpha1'
classpath "io.realm:realm-gradle-plugin:2.2.1"
classpath 'com.jakewharton:butterknife-gradle-plugin:8.4.0'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
这里是我使用 Realm 和 DataBinding 的 Activity
final ActivityCreateBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_create);
ButterKnife.bind(binding.getRoot());
Realm.init(getApplicationContext());
RealmConfiguration config = new RealmConfiguration.Builder().build();
realm = Realm.getInstance(config);
realm.beginTransaction();
character = realm.createObject(Character.class);
binding.setCharacter(character);
下面是我使用的监听器中的一些代码
realm.commitTransaction();
我不明白这是什么问题......
此致
最佳答案
来自文档:
Field types
Realm supports the following field types: boolean, byte, short, int, long, float, double, String, Date and byte[]. The integer types byte, short, int, and long are all mapped to the same type (long actually) within Realm.
Moreover, subclasses of
RealmObject
andRealmList<? extends RealmObject>
are supported to model relationships.
好吧,你还有这个:
private ObservableField<String> nbCaracteristicPointAvailableStringOb;
那不是一个受支持的 RealmModel 字段,所以它不会起作用。您必须添加 @Ignore
注释。
@RealmClass
public class Character extends RealmObject implements Serializable
//...
@Ignore
private ObservableField<String> nbCaracteristicPointAvailableStringOb;
此外,您可以测试这是否有效,但我认为使用静态工厂方法比在实例化时也使用的默认构造函数中初始化所有这些列表和内容更安全托管代理。
public static Character create() {
Character character = new Character();
character.initCharacter();
return character;
}
(在一个完全不相关的旁注中,我不知道为什么这个类是 Serializable
,你为什么要通过 ObjectOutputStream 抛出一个 RealmObject...?)
编辑:您也可以尝试通过添加 android-apt
来强制它工作插件。
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.0-alpha1'
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
classpath "io.realm:realm-gradle-plugin:2.2.1"
}
}
然后
apply plugin: 'com.android.application'
apply plugin: 'com.neenbedankt.android-apt'
apply plugin: 'realm-android'
//...
compile 'com.jakewharton:butterknife:8.4.0'
// ...
apt 'com.jakewharton:butterknife-compiler:8.4.0'
关于android - Realm 和 Android 数据绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40940253/
我不知道该怎么做... function f1() { var x = 10; function f2(fx) { var x; x = 6;
早期绑定(bind)和后期绑定(bind)有什么区别? 最佳答案 简短的回答是,早期(或静态)绑定(bind)是指编译时绑定(bind),后期(或动态)绑定(bind)是指运行时绑定(bind)(例如
如何在 SwiftUI View 上使用 Binding(get: { }, set: { }) 自定义绑定(bind)与 @Binding 属性。我已成功使用此自定义绑定(bind)与 @State
我经常发现自己遇到问题,即控件的两个(相关)值被更新,并且两者都会触发昂贵的操作,或者控件可能会暂时处于不一致的状态。 例如,考虑一个数据绑定(bind),其中两个值 (x,y) 相互减去,最终结果用
我想通过我的 ViewModel 控制我的一个窗口的高度和宽度。 这看起来很简单。 但没有。它不起作用。 它检查 ViewModel 的 Width但不是 Height . 奇怪的是,如果我切换 W
UI5中一次性绑定(bind)和单向绑定(bind)有什么区别? 是否有任何用户特定的用例我会使用它们? 我无法从文档中获得太多信息。 最佳答案 单程 它的作用:单向数据流。模型数据的变化(例如通过
(define make (lambda (x) (lambda (y) (cons x (list y))))) (let ((x 7) (p (make 4))) (cons
尽管我或多或少地了解什么是语言绑定(bind),但我很难理解它们是如何工作的。 例如,谁能解释一下如何为 WinAPI 制作 Java 绑定(bind)? 最佳答案 如果您搜索 Foreign Fun
谁能解释为什么我可以重新绑定(bind)列表但不能+? (binding [list vector] (list 1 3)) (binding [list +] (list 1 3)) (bi
我真的很喜欢 Caliburn 和命名约定绑定(bind),我很惊讶 可见性与“CanNAME”约定用于保护 Action 的方式不同。 据我所知, BooleanToVisibilityConver
我了解动态绑定(bind)的实现方式以及静态绑定(bind)和动态绑定(bind)之间的区别,但我只是无法理解动态绑定(bind)的定义。基本上它是一种运行时绑定(bind)类型。 最佳答案 基本上,
http://jsfiddle.net/3NRsd/ var foo = $("div").bind("click", function() { $("div").animate({"hei
这个问题我快疯了...我有一个用户控件,它有一个用于插入操作的 FormView 和一个用于所有其他操作的 GridView。 在这两个控件中,我都有一个 DropDownList,如下所示: '
我有一个绑定(bind)到 ListBox 的地址的 ObservableCollection。然后在 ItemTemplate 中,我使用 {Binding .} 绑定(bind)到当前地址记录。这
如果我有以下简单的 js/knockout 代码: .js( View 模型): var image = ko.observable('http://placehold.it/300x150'); 看
我正在 aurelia 上开发一个自定义属性,让用户在输入文本区域时从列表中进行选择。例如,用法将是这样的: 正如您可能注意到的,auto-complete是属性。现在,当我想显示提示时,我想在自定
我正在使用 EventEmitter2作为我的应用程序内部的消息总线。现在我需要绑定(bind)和取消绑定(bind)一些事件处理程序。因为我也希望他们bind将它们添加到给定的上下文中,我最终得到以
我有以下函数调用: $(".selector").on("click", callback.bind(this, param1, param2)); 在我的回调函数中,我想使用绑定(bind)的 th
我目前正在试验新的编译绑定(bind),并且(再次)达到了我在拼图中遗漏了一个小问题:为什么我必须调用 Bindings.Update?直到现在,我还认为实现 INotifyPropertyChang
我正在阅读一本关于编写 JavaScript 框架的书,并找到了这段代码。但是我不明白它是如何工作的,尤其是 bind.bind 的用法?有人知道吗? var bind = Function.prot
我是一名优秀的程序员,十分优秀!