Когда я нажимаю на свой счетчик, я вижу свои данные, но когда я пытаюсь его выбрать, он не устанавливает данные?

Я пытаюсь создать счетчик, который берет данные из базы данных Firebase в реальном времени. Я отлично извлекаю данные в своих отчетах журнала, и я также вижу свои данные, когда нажимаю раскрывающийся список. Но когда я пытаюсь выбрать что-то в своем счетчике, он не устанавливает данные. Также, когда я пытаюсь вызвать свой метод getSelectedItem(), он выдает ошибку java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.Object.toString()' on a null object reference

В журналах, которые я пишу, нет нулевых значений, поэтому я совершенно не понимаю, почему я получаю такую ​​​​ошибку.


import android.content.Intent;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.Spinner;

import com.example.bankapp.BankAccount;
import com.example.bankapp.R;
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 TransferOwnAccount extends AppCompatActivity {

    private Spinner accountFrom, accountTo;
    private EditText transferAmount;
    private FirebaseDatabase database;
    ArrayList<BankAccount> accounts = new ArrayList<>();


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

    }

    public void transferMoney(View view) {
        Log.d("grinern", "olool"+accountFrom.getSelectedItem().toString());
    }

    public void loadAccounts() {
        Intent getIntent = getIntent();
        String userCPR = getIntent.getStringExtra("CPR");
        DatabaseReference dbref = database.getReference("usersbankaccounts/" + userCPR);
        dbref.addListenerForSingleValueEvent(new ValueEventListener() {
            @Override
            public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                for (DataSnapshot data : dataSnapshot.getChildren()) {
                    DatabaseReference bankaccounts = database.getReference("bankaccounts/" + data.getKey());
                    Log.d("grinern", data.getKey());
                    bankaccounts.addListenerForSingleValueEvent(new ValueEventListener() {
                        @Override
                        public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                            BankAccount bankAccount = dataSnapshot.getValue(BankAccount.class);
                            accounts.add(bankAccount);
                            Log.d("grinern", ""+accounts);
                        }

                        @Override
                        public void onCancelled(@NonNull DatabaseError databaseError) {

                        }
                    });
                }
                Log.d("grinern", ""+accounts);

                ArrayAdapter<BankAccount> adapter = new ArrayAdapter<>(getApplicationContext(), android.R.layout.simple_spinner_dropdown_item, accounts);
                accountFrom.setAdapter(adapter);
                accountTo.setAdapter(adapter);
                adapter.notifyDataSetChanged();


            }

            @Override
            public void onCancelled(@NonNull DatabaseError databaseError) {

            }
        });

    }

    public void init() {
        this.accountFrom = findViewById(R.id.transferFromSpinner);
        this.accountTo = findViewById(R.id.transferToSpinner);
        this.transferAmount = findViewById(R.id.transferAmount);
        this.database = FirebaseDatabase.getInstance();


    }
}

Он должен выбрать все, что я нажму в моем раскрывающемся счетчике, и распечатать это в моем журнале, который вызывается в моем методе TransferMoney().

Ниже мой файл макета:

<?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"
    android:background = "@color/background"
    tools:context = ".TransferOwnAccount">

    <Button
        android:id = "@+id/transferButton"
        style = "@style/Widget.AppCompat.Button.ButtonBar.AlertDialog"
        android:layout_width = "100dp"
        android:layout_height = "48dp"
        android:layout_marginTop = "80dp"
        android:layout_marginBottom = "8dp"
        android:background = "@drawable/contrast_background"
        android:text = "@string/transfer"
        android:textColor = "#FFFFFF"
        android:typeface = "serif"
        app:layout_constraintBottom_toBottomOf = "parent"
        app:layout_constraintEnd_toEndOf = "parent"
        app:layout_constraintHorizontal_bias = "0.501"
        app:layout_constraintStart_toStartOf = "parent"
        app:layout_constraintTop_toBottomOf = "@+id/transferToSpinner"
        app:layout_constraintVertical_bias = "0.006"
        tools:targetApi = "lollipop" />

    <TextView
        android:id = "@+id/transferToTitle"
        android:layout_width = "wrap_content"
        android:layout_height = "wrap_content"
        android:layout_marginTop = "56dp"
        android:text = "@string/transfer_to"
        android:textColor = "#FFFFFF"
        android:textSize = "18sp"
        app:fontFamily = "serif"
        app:layout_constraintEnd_toEndOf = "parent"
        app:layout_constraintStart_toStartOf = "parent"
        app:layout_constraintTop_toBottomOf = "@+id/transferFromSpinner" />

    <TextView
        android:id = "@+id/transferFromTitle"
        android:layout_width = "wrap_content"
        android:layout_height = "wrap_content"
        android:layout_marginTop = "44dp"
        android:text = "@string/transfer_from"
        android:textColor = "#FFFFFF"
        android:textSize = "18sp"
        app:fontFamily = "serif"
        app:layout_constraintEnd_toEndOf = "parent"
        app:layout_constraintStart_toStartOf = "parent"
        app:layout_constraintTop_toBottomOf = "@+id/transferAmount" />

    <TextView
        android:id = "@+id/transferTitle"
        android:layout_width = "wrap_content"
        android:layout_height = "wrap_content"
        android:layout_marginTop = "44dp"
        android:text = "@string/transfer_money"
        android:textColor = "#F9FAF9"
        android:textSize = "24sp"
        app:fontFamily = "serif"
        app:layout_constraintEnd_toEndOf = "parent"
        app:layout_constraintHorizontal_bias = "0.5"
        app:layout_constraintStart_toStartOf = "parent"
        app:layout_constraintTop_toTopOf = "parent" />

    <EditText
        android:id = "@+id/transferAmount"
        android:layout_width = "wrap_content"
        android:layout_height = "wrap_content"
        android:layout_marginTop = "99dp"
        android:autofillHints = ""
        android:ems = "10"
        android:hint = "@string/choose_amount"
        android:inputType = "textPersonName"
        android:text = "@string/choose_amount"
        android:textColor = "#FFFFFF"
        android:typeface = "serif"
        app:layout_constraintEnd_toEndOf = "parent"
        app:layout_constraintHorizontal_bias = "0.5"
        app:layout_constraintStart_toStartOf = "parent"
        app:layout_constraintTop_toBottomOf = "@+id/transferTitle"
        tools:targetApi = "o" />

    <Spinner
        android:id = "@+id/transferFromSpinner"
        android:layout_width = "288dp"
        android:layout_height = "32dp"
        android:layout_marginTop = "8dp"
        app:layout_constraintEnd_toEndOf = "parent"
        app:layout_constraintHorizontal_bias = "0.504"
        app:layout_constraintStart_toStartOf = "parent"
        app:layout_constraintTop_toBottomOf = "@+id/transferFromTitle" />

    <Spinner
        android:id = "@+id/transferToSpinner"
        android:layout_width = "288dp"
        android:layout_height = "32dp"
        android:layout_marginTop = "8dp"
        app:layout_constraintEnd_toEndOf = "parent"
        app:layout_constraintHorizontal_bias = "0.5"
        app:layout_constraintStart_toStartOf = "parent"
        app:layout_constraintTop_toBottomOf = "@+id/transferToTitle" />
</android.support.constraint.ConstraintLayout>

Ниже приведен JSON из моей базы данных Firebase.

{
  "bankaccounts" : {
    "126" : {
      "accNumber" : "126",
      "balance" : 0,
      "title" : "Default"
    },
    "127" : {
      "accNumber" : "127",
      "balance" : 0,
      "title" : "Budget"
    },
    "128" : {
      "accNumber" : "128",
      "balance" : 0,
      "title" : "Pension"
    }
  },
  "nextNumber" : "128",
  "users" : {
    "1111111111" : {
      "address" : "qwe",
      "cpr" : "1111111111",
      "email" : "qwe",
      "firstname" : "qwe",
      "lastname" : "qwe",
      "password" : "111111",
      "phonenumber" : "793"
    }
  },
  "usersbankaccounts" : {
    "1111111111" : {
      "126" : "Default Account",
      "127" : "Budget Account",
      "128" : "Pension Account"
    }
  }
}

В какой строке кода вы получаете эту ошибку?

Alex Mamo 27.05.2019 16:04

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

Frank van Puffelen 27.05.2019 16:11

когда вы вызвали TransferMoney в этом коде?

ismail alaoui 27.05.2019 16:24

Получение ошибки в первой строке моего метода transferMoney(). @АлексМамо

Sean D'Arcy 27.05.2019 17:32

Вызов метода transferMoney() для кнопки onClick в моем макете. @ismailalaoui

Sean D'Arcy 27.05.2019 17:33

Вы уверены, что accountFrom.getSelectedItem() не null? Я боюсь, что это так, верно?

Alex Mamo 27.05.2019 17:34

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

Sean D'Arcy 27.05.2019 17:39

@SeanD'Arcy, так где же определение onclick в вашей части кода?

ismail alaoui 27.05.2019 17:54

можете ли вы поделиться своей базой данных json, связанной с вопросом?

Ticherhaz FreePalestine 27.05.2019 19:07

@ismailalaoui Ах, забыл добавить мой файл макета. Я добавил это сейчас. Используя дизайн в Android Studio, вы можете просто перейти к файлу макета и добавить onClick к кнопке или к чему угодно.

Sean D'Arcy 27.05.2019 19:08

@Zuhrain Да, только что добавил. Спасибо!

Sean D'Arcy 27.05.2019 19:10

вы не инициализировали кнопку передачи. @Шон Д'Арси

Ticherhaz FreePalestine 27.05.2019 19:43
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
1
12
32
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вам нужно изменить свой массив банковских счетов на статический (чтобы убедиться, что он такой же, даже если состояние изменится)

Затем я переместил адаптер как поле и инициализировал его в методе инициализации. Проверьте приведенный мной код:

package com.example.bankapp;

import android.content.Intent;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.Spinner;

import com.example.bankapp.BankAccount;
import com.example.bankapp.R;
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 TransferOwnAccount extends AppCompatActivity {

    private Spinner accountFrom, accountTo;
    private EditText transferAmount;
    private FirebaseDatabase database;
    static  ArrayList<BankAccount> accounts = new ArrayList<>();
    ArrayAdapter<BankAccount> adapter;


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

    }

    public void transferMoney(View view) {
        Log.d("test", "olool" + accountFrom.getSelectedItem().toString());
    }

    public void loadAccounts() {
        Intent getIntent = getIntent();
        String userCPR = getIntent.getStringExtra("CPR");
        DatabaseReference dbref = database.getReference("usersbankaccounts/" + userCPR);
        dbref.addListenerForSingleValueEvent(new ValueEventListener() {
            @Override
            public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                for (DataSnapshot data : dataSnapshot.getChildren()) {
                    DatabaseReference bankaccounts = database.getReference("bankaccounts/" + data.getKey());
                    Log.d("test", data.getKey());
                    bankaccounts.addListenerForSingleValueEvent(new ValueEventListener() {
                        @Override
                        public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                            BankAccount bankAccount = dataSnapshot.getValue(BankAccount.class);
                            accounts.add(bankAccount);
                            adapter.notifyDataSetChanged();

                            Log.d("test", "" + accounts);
                        }

                        @Override
                        public void onCancelled(@NonNull DatabaseError databaseError) {

                        }
                    });
                }
                Log.d("test", "" + accounts);


                adapter.notifyDataSetChanged();


            }

            @Override
            public void onCancelled(@NonNull DatabaseError databaseError) {

            }
        });

    }

    public void init() {
        this.adapter = new ArrayAdapter<>(this, android.R.layout.simple_dropdown_item_1line, accounts);
        this.accountFrom = findViewById(R.id.transferFromSpinner);
        this.accountTo = findViewById(R.id.transferToSpinner);
        this.transferAmount = findViewById(R.id.transferAmount);
        this.database = FirebaseDatabase.getInstance();
        this.accountFrom.setAdapter(adapter);
        this.accountTo.setAdapter(adapter);

    }
}

Затем вам нужно убедиться, что у вас есть метод toString() в вашем банковском счете.

 @Override
    public String toString() {
        return title + "--- " +accNumber + "  " + balance ;
    }

Это должно сработать :)

Другие вопросы по теме