Изо всех сил пытается получить значения из базы данных Firebase Realtime - PullRequest
0 голосов
/ 15 мая 2018

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

Когда я нажимаю на пользователя в списке, мне нужно получить значение имени пользователя для создания идентификаторов чата. Это моя проблема, чтобы получить значения внутри ключей. То, что я делаю, похоже, не работает.

Это моя база данных

enter image description here

Мне нужно принять значение, данное "name".

Это мой код

package br.sosqueen.com.sosqueen;

import android.app.ProgressDialog;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;

import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;

import org.json.JSONException;
import org.json.JSONObject;

import java.util.ArrayList;
import java.util.Iterator;

public class UserMessageListFragment extends Fragment {

    private ProgressDialog progressDialog;
    private final String TAG = "UsersMessageLis";
    private ArrayList<String> arrayList = new ArrayList<>();
    private int totalUsers = 0;
    private ListView usersList;
    private TextView noUsersText;

    public static UserMessageListFragment newInstance() {
        return new UserMessageListFragment();
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        View view = inflater.inflate(R.layout.fragment_user_message_list, container, false);

        usersList = view.findViewById(R.id.usersList);
        noUsersText = view.findViewById(R.id.noUsersText);

        progressDialog = new ProgressDialog(getContext());
        progressDialog.setMessage("Carregando...");
        progressDialog.show();

        //String url = "https://sosqueen-6b80b.firebaseio.com/users.json";
        String url = "https://sosqueen-6b80b.firebaseio.com/usuarios.json";
        StringRequest request = new StringRequest(Request.Method.GET, url, new Response.Listener<String>() {
            @Override
            public void onResponse(String response) {
                doOnSuccess(response);
            }
        }, new Response.ErrorListener(){
            @Override
            public void onErrorResponse(VolleyError error) {
                Log.d(TAG, "Error on trying to do request");
            }
        });

        RequestQueue rQueue = Volley.newRequestQueue(getContext());
        rQueue.add(request);

        usersList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                UserDetails.chatWith = arrayList.get(position);
                startActivity(new Intent(getContext(), Chat.class));
            }
        });

        return view;
    }

    public void doOnSuccess(String response) {

        try {
            JSONObject object = new JSONObject(response);
            Iterator iterator = object.keys();
            String key = "";

            while(iterator.hasNext()) {
                key = iterator.next().toString();

                if(! key.equals(UserDetails.username)) {
                    arrayList.add(key);
                }
                totalUsers++;
            }

        } catch (JSONException e) {
            e.printStackTrace();
        }

        checkIfThereIsAnUser(totalUsers);
    }

    public void checkIfThereIsAnUser(int totalUsers) {


        if(totalUsers <=1){
            noUsersText.setVisibility(View.VISIBLE);
            usersList.setVisibility(View.GONE);
        }
        else{
            noUsersText.setVisibility(View.GONE);
            usersList.setVisibility(View.VISIBLE);
            usersList.setAdapter(new ArrayAdapter<>(getContext(), R.layout.my_list, arrayList));
        }
        progressDialog.dismiss();
    }
}

1 Ответ

0 голосов
/ 15 мая 2018

Вы хотите создать ChildEventListener и присоединить его к своей "пользовательской" ветке.

При первом подключении к ветви с использованием ChildEventListener, OnChildAdded будет срабатывать для каждогодочерний элемент, возвращающий снимок дочерней ветви данных.

Лично я сохранял бы весь результат datasnapshot и при отображении его в списке отображал бы snapshot.getValue ("name") вместо ключа ветви.

В противном случае вам потребуется сохранить ключ ветви и пару имен, а затем выполнить поиск дополнительной информации с помощью запроса DatabaseRef OnValue.


В качестве альтернативы, вы можете создать Запрос на основе некоторого значения ветви (с включенным свойством .indexon), такого как 'ciudad' и фильтра на основе локальных имен.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...