Я пытаюсь создать счетчик, который берет данные из базы данных 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"
}
}
}
Трудно точно сказать, что происходит, поскольку задействовано взаимодействие с пользовательским интерфейсом. Но вы можете установить точку останова внутри transferMoney
и посмотреть, что произойдет, когда вы запустите код в отладчике и выберите элемент в счетчике.
когда вы вызвали TransferMoney в этом коде?
Получение ошибки в первой строке моего метода transferMoney(). @АлексМамо
Вызов метода transferMoney() для кнопки onClick в моем макете. @ismailalaoui
Вы уверены, что accountFrom.getSelectedItem()
не null
? Я боюсь, что это так, верно?
Да это ноль. Это то, что меня смущает, потому что в моем отчете журнала, где я распечатываю свои учетные записи, он не равен нулю. Также, когда я нажимаю на счетчик, я вижу параметры счетчика, но внутри счетчика ничего не выбирается.
@SeanD'Arcy, так где же определение onclick в вашей части кода?
можете ли вы поделиться своей базой данных json, связанной с вопросом?
@ismailalaoui Ах, забыл добавить мой файл макета. Я добавил это сейчас. Используя дизайн в Android Studio, вы можете просто перейти к файлу макета и добавить onClick к кнопке или к чему угодно.
@Zuhrain Да, только что добавил. Спасибо!
вы не инициализировали кнопку передачи. @Шон Д'Арси
Вам нужно изменить свой массив банковских счетов на статический (чтобы убедиться, что он такой же, даже если состояние изменится)
Затем я переместил адаптер как поле и инициализировал его в методе инициализации. Проверьте приведенный мной код:
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 ;
}
Это должно сработать :)
В какой строке кода вы получаете эту ошибку?