私のFirebaseリアルタイムデータベースからすべての要素を読みたい(私のアプリケーションで埋められない.jsonファイルを読み込みます)。しかし、彼らは動作しませんでした。ここに私のリアルタイムデータベースである:ここでApp Firebaseリアルタイムデータベースから読み込むとクラッシュする
は私が主な活動でデータを読み取る方法を示します。ここでは
public final ArrayList<Parking> parkingArrayList=new ArrayList<Parking>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
FirebaseDatabase firebaseDatabase=FirebaseDatabase.getInstance();
firebaseDatabase.setPersistenceEnabled(true);
DatabaseReference databaseReference=firebaseDatabase.getReference();
databaseReference.child("Parking").addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for(DataSnapshot dataSnapshot1:dataSnapshot.getChildren()){
Parking p=dataSnapshot1.getValue(Parking.class);
}
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
});
は私の駐車クラスです:
public class Parking implements Comparable<Parking>,Parcelable {
public String name;
public String zone;
public String location;
public int capacity;
public double latitude;
public double longtitude;
int free=0;
int taken=0;
int id;
public Parking(){
}
public Parking(int capacity,double latitude,String location, double longtitude,String name,String zone){
this.capacity=capacity;
this.location=location;
this.name=name;
this.zone=zone;
this.latitude=latitude;
this.longtitude=longtitude;
this.taken=getTaken();
this.free=getFree();
}
protected Parking(Parcel in) {
name = in.readString();
zone = in.readString();
location = in.readString();
capacity = in.readInt();
latitude = in.readDouble();
longtitude = in.readDouble();
free = in.readInt();
taken = in.readInt();
}
public static final Creator<Parking> CREATOR = new Creator<Parking>() {
@Override
public Parking createFromParcel(Parcel in) {
return new Parking(in);
}
@Override
public Parking[] newArray(int size) {
return new Parking[size];
}
};
public int getCapacity() {
return capacity;
}
public int getFree() {
return capacity-getTaken();
}
public int getTaken() {
Random random=new Random();
this.taken=random.nextInt(capacity+1);
return taken;
}
public void setFree(int taken){
free=capacity-taken;
}
public void setTaken(int taken) {
Random random=new Random();
this.taken=random.nextInt(capacity+1);
}
public double getLatitude(){
return latitude;
}
public double getLongtidue(){
return longtitude;
}
@Override
public String toString() {
return String.format("%s\t\tZone: %s\nlocation: %s\nCapacity: %d\t\tFree: %d",name,zone,location,capacity,getFree());
}
@Override
public int compareTo(@NonNull Parking parking) {
return Integer.compare(parking.free,this.free);
}
@Override
public int describeContents() {
return 0;
}
@Override
public void writeToParcel(Parcel parcel, int i) {
parcel.writeInt(capacity);
parcel.writeDouble(latitude);
parcel.writeString(location);
parcel.writeDouble(longtitude);
parcel.writeString(name);
parcel.writeString(zone);
parcel.writeInt(getTaken());
parcel.writeInt(getFree());
}
}
私はFirebaseとそれを接続している、(firebaseツールを使用して)グーグル・services.jsonファイルをインストールしますが、私はそれがクラッシュしたアプリを起動したとき(「残念ながら、najdiparking(私のアプリ名)止まりました) 。リストをデータベースから読み込まずに手動で入力すると、アプリケーションが機能します。 これは依存関係の「com.google.firebase:firebase-database:10.0.1」です。
また、私の.jsonファイル名をクラス内の名前でチェックします。
私のlogcat(私はこれはあなたを助けることを願っています)
08-27 15:41:31.884 19384-19384/com.example.simeon.najdiparking E/AndroidRuntime: FATAL EXCEPTION: main Process: com.example.simeon.najdiparking, PID: 19384 java.lang.NoSuchMethodError: No virtual method zzTt()Z in class Lcom/google/firebase/FirebaseApp; or its super classes (declaration of 'com.google.firebase.FirebaseApp' appears in /data/app/com.example.simeon.najdiparking-1/split_lib_dependencies_apk.apk:classes20.dex) at com.google.firebase.database.FirebaseDatabase.getInstance(Unknown Source) at com.google.firebase.database.FirebaseDatabase.getInstance(Unknown Source) at com.example.simeon.najdiparking.MainActivity.onCreate(MainActivity.java:48) at android.app.Activity.performCreate(Activity.java:6237) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) at android.app.ActivityThread.-wrap11(ActivityThread.java) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:148) at android.app.ActivityThread.main(ActivityThread.java:5417) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
あなたの問題をよりよく理解できるようにログを提供することができます – Sergey
投稿後のログエラーです。 –
あなたはlogcatの間違ったセクションをコピーしたようです。 –