получить данные о ListView из базы данных Firebase Realtime в Android не работает - PullRequest
0 голосов
/ 03 октября 2018

Я пытаюсь извлекать данные из firebase динамически и отображать их на странице, но когда я это делаю, ошибок нет, но на экране появляется сообщение только о пустом экране (см. Рисунок ниже)

Это вывод, когда я нажимаю на страницу

Может ли кто-нибудь помочь мне с этим?

Это моя Firebase структура базы данных.

my database structure

Это мой код Java:

package com.example.atheer.booklyv1;

import android.app.ListActivity;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.ArrayAdapter;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;

import com.google.firebase.database.DataSnapshot;
import com.google.firebase.database.DatabaseError;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.database.ValueEventListener;

import java.util.ArrayList;

public class orgServices extends AppCompatActivity {

ListView ListView;
FirebaseDatabase database;
DatabaseReference ref;
ArrayList<Service> list;
ArrayAdapter<Service>  adapter;
Service ser;



    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_org_services);




        ser = new Service();
        ListView = (ListView) findViewById(R.id.ListView);
        database = FirebaseDatabase.getInstance();
        ref =database.getReference().child("client");
        list = new ArrayList<>();
        adapter = new ArrayAdapter<Service>(this, R.layout.service_info,R.id.serviceInfo,list);
        ref.addValueEventListener(new ValueEventListener(){


            @Override
            public void onDataChange(DataSnapshot dataSnapshot){
for(DataSnapshot ds: dataSnapshot.getChildren())
{
    if (dataSnapshot.hasChild("services")){
    ser= ds.getValue(Service.class);
    list.add(ser);}

}
ListView.setAdapter(adapter);
            }



            @Override
            public void onCancelled(DatabaseError databaseError){


            }
        });

    }




}

Это код XML для ListView:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.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=".orgServices">
<ListView
    android:id="@+id/ListView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">

</ListView>
</android.support.constraint.ConstraintLayout>

Это код XMLдля каждого элемента в ListView:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
    android:layout_height="match_parent">


    <TextView
        android:id="@+id/serviceInfo"
        android:textSize="30sp"
        android:text="Name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />


</android.support.constraint.ConstraintLayout>

Я настроил класс адаптера: Класс адаптера:

package com.example.atheer.booklyv1;

import android.support.v7.app.AppCompatActivity;

public class Service extends AppCompatActivity {

private int price;
private String name;
private int totalpoint;
private int rating;


public Service(){

}

 public Service (String name){
    this.name=name;
 }

 public Service (String name, int price , int totalpoint , int rating ){
    this.name=name;
    this.price=price;
    this.totalpoint=totalpoint;
    this.rating=rating;


 }

    public int getPrice() {
        return price;
    }

    public void setPrice(int price) {
        this.price = price;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getTotalpoint() {
        return totalpoint;
    }

    public void setTotalpoint(int totalpoint) {
        this.totalpoint = totalpoint;
    }

    public int getRating() {
        return rating;
    }

    public void setRating(int rating) {
        this.rating = rating;
    }
}

, и эти сообщения приходят из секции выполнения:

V/FA: Recording user engagement, ms: 748436
V/FA: Connecting to remote service
V/FA: Activity paused, time: 1449333
D/FA: Logging event (FE): user_engagement(_e), Bundle[{firebase_event_origin(_o)=auto, engagement_time_msec(_et)=748436, firebase_screen_class(_sc)=Service, firebase_screen_id(_si)=-4092656992746331939}]
I/atheer.booklyv: Waiting for a blocking GC ProfileSaver
V/FA: Connection attempt already in progress
V/FA: Connection attempt already in progress
      Activity resumed, time: 1449354
D/FA: Logging event (FE): screen_view(_vs), Bundle[{firebase_event_origin(_o)=auto, firebase_previous_class(_pc)=Service, firebase_previous_id(_pi)=-4092656992746331939, firebase_screen_class(_sc)=Mynavigation, firebase_screen_id(_si)=-4092656992746331940}]
I/atheer.booklyv: WaitForGcToComplete blocked ProfileSaver on ProfileSaver for 62.701ms
V/FA: Connection attempt already in progress
D/EGL_emulation: eglMakeCurrent: 0xebd05420: ver 3 0 (tinfo 0xebd033e0)
D/FA: Connected to remote service
V/FA: Processing queued up service tasks: 4
V/FA: Recording user engagement, ms: 3384
W/ActivityThread: handleWindowVisibility: no activity for token android.os.BinderProxy@6a2bdcc
V/FA: Activity paused, time: 1452737
V/FA: onActivityCreated
D/FA: Logging event (FE): user_engagement(_e), Bundle[{firebase_event_origin(_o)=auto, engagement_time_msec(_et)=3384, firebase_screen_class(_sc)=Mynavigation, firebase_screen_id(_si)=-4092656992746331940}]
V/FA: Activity resumed, time: 1452998
D/FA: Logging event (FE): screen_view(_vs), Bundle[{firebase_event_origin(_o)=auto, firebase_previous_class(_pc)=Mynavigation, firebase_previous_id(_pi)=-4092656992746331940, firebase_screen_class(_sc)=Service, firebase_screen_id(_si)=-4092656992746331938}]
D/EGL_emulation: eglMakeCurrent: 0xebd05420: ver 3 0 (tinfo 0xebd033e0)

Ответы [ 2 ]

0 голосов
/ 04 октября 2018

Чтобы решить эту проблему, просто переместите следующую строку кода:

adapter = new ArrayAdapter<Service>(this, R.layout.service_info,R.id.serviceInfo,list);

прямо перед:

ListView.setAdapter(adapter);

К тому времени, когда вы устанавливаете адаптер, ваш список пуст,вот почему появляется пустой экран.

0 голосов
/ 04 октября 2018

Проблема в поиске с использованием dataSnapshot.Что вы делаете, так это то, что если вы обнаружите ребенка с именем services, вы попытаетесь получить данные из текущего dataSnapshot в Services.class.

.правильная установка databaseReference на ребенка по вашему выбору.

Таким образом, вместо кода, который вы используете для извлечения, вы можете попробовать это в вашем выражении if:

String name = dataSnapshot.child("name").getValue(String.class);
String name = dataSnapshot.child("price").getValue(Integer.class);
String name = dataSnapshot.child("rating").getValue(Integer.class);
String name = dataSnapshot.child("totalpoint").getValue(Integer.class);

Если вы хотите получить все значения без установки других getValue() заявления, вы можете использовать map для этого.Это может помочь вам одновременно обновлять и извлекать значения из вашей базы данных.

Чтобы узнать больше о получении данных из FirebaseDatabase с помощью map.

, вы можете обратиться по следующей ссылке.данные с использованием карты из базы данных Firebase

...