Reputation: 827
I am stuck on this issue ....
I keep getting this particular error in my app:
java.lang.NullPointerException: Attempt to invoke virtual method 'com.google.firebase.database.ValueEventListener com.google.firebase.database.DatabaseReference.addValueEventListener(com.google.firebase.database.ValueEventListener)' on a null object reference
Now, what i am trying to do is post the results of items listed in a Firebase database.
here is my code for the making that list:
public class WatchListFragment extends Fragment {
private static final String TAG = "WatchListFragment";
private static final int NUM_GRID_COLUMNS = 3;
private static final int GRID_ITEM_MARGIN = 5;
//widgets
private FrameLayout mFrameLayout;
//reference for listening when items are added or removed from the watch list
//vars
// private DatabaseReference mReference = FirebaseDatabase.getInstance().getReference()
// .child(getString(R.string.node_watch_list))
// .child(FirebaseAuth.getInstance().getCurrentUser().getUid());
private PostAdapter mAdapter;
private ArrayList<Post> mPosts;
private RecyclerView mRecyclerView;
private DatabaseReference mReference;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_watch_list, container, true);
mRecyclerView = (RecyclerView) view.findViewById(R.id.watchListRecyclerView);
mFrameLayout = (FrameLayout) view.findViewById(R.id.watch_list_container);
Log.d(TAG, "init: initializing.");
mPosts = new ArrayList<>();
//set the listener to the reference
mReference.addValueEventListener(mLisenter);
if(isAdded()){
getResources().getString(R.string.app_name);
mReference = FirebaseDatabase.getInstance().getReference()
.child(getString(R.string.node_watch_list))
.child(FirebaseAuth.getInstance().getCurrentUser().getUid());
}
mPosts = new ArrayList<Post>();
mAdapter = new PostAdapter(this, mPosts);
mRecyclerView = (RecyclerView) view.findViewById(R.id.watchListRecyclerView); //unsere (Recycleriew)Liste aus dem Design wird in eine RecyclerView ungewandelt
mRecyclerView.setHasFixedSize(true);
mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity())); //Hier könnten wir auch verschiedene Layouts festlegen. Bei der ListView, die vorher hatten, ist das Linearlayout fest eingestellt.
mRecyclerView.addItemDecoration(new DividerItemDecoration(getActivity(), LinearLayoutManager.VERTICAL)); // Der Divider trennt die Zeilen mit einem Strich
mRecyclerView.setAdapter(mAdapter); //Adapter wird gesetzt
// RecyclerViewMargin itemDecorator = new RecyclerViewMargin(GRID_ITEM_MARGIN, NUM_GRID_COLUMNS);
// mRecyclerView.addItemDecoration(itemDecorator);
// GridLayoutManager gridLayoutManager = new GridLayoutManager(getActivity(), NUM_GRID_COLUMNS);
// mRecyclerView.setLayoutManager(gridLayoutManager);
// mAdapter = new PostListAdapter(getActivity(), mPosts);
// mRecyclerView.setAdapter(mAdapter);
return view;
}
public void viewPost(String postId){
ViewPostFragment fragment = new ViewPostFragment();
Activity activity = getActivity();
if (isAdded() && activity != null) {
FragmentTransaction transaction = getActivity().getSupportFragmentManager().beginTransaction();
Bundle args = new Bundle();
args.putString(getString(R.string.arg_post_id), postId);
fragment.setArguments(args);
transaction.replace(R.id.watch_list_container, fragment, getString(R.string.fragment_view_post));
transaction.addToBackStack(getString(R.string.fragment_view_post));
transaction.commit();
mFrameLayout.setVisibility(View.VISIBLE);
}
}
@Override
public void onDestroy() {
super.onDestroy();
mReference.removeEventListener(mLisenter);
}
ValueEventListener mLisenter = new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
Log.d(TAG, "onDataChange: a change was made to this users watch lits node.");
DatabaseReference reference = FirebaseDatabase.getInstance().getReference();
Query query = reference.child("posts")
.orderByKey()
.equalTo(FirebaseAuth.getInstance().getCurrentUser().getUid());
reference.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
DataSnapshot dShot = dataSnapshot.getChildren().iterator().next();
for (DataSnapshot dShot2 : dShot.getChildren()) {
Post post = (Post) dShot2.getValue(Post.class);
mPosts.add(post);
}
mAdapter.notifyDataSetChanged();
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
}
});
}
@Override
public void onCancelled(DatabaseError databaseError) {
}
};
}
The offending line of code flagged in the logcat is this: mReference.addValueEventListener(mLisenter);
I am not totally sure it is that is the issue. I have followed the tutorials and googled for an answer and I am still stuck as to why I am getting this particular issue
Upvotes: 0
Views: 124
Reputation: 610
You have commented out initialization of mReference:
// private DatabaseReference mReference = FirebaseDatabase.getInstance().getReference()
// .child(getString(R.string.node_watch_list))
// .child(FirebaseAuth.getInstance().getCurrentUser().getUid());
and instead initialize it to null:
private DatabaseReference mReference;
is same as private DatabaseReference mReference = null;
Later in your onCreateView, you try to add listener to this null reference:
mReference.addValueEventListener(mLisenter);
is same as null.addValueEventListener(mLisenter)
EDIT: Now I see, that you initialize mReference later in your code, try this:
if(isAdded()){
getResources().getString(R.string.app_name);
mReference = FirebaseDatabase.getInstance().getReference()
.child(getString(R.string.node_watch_list))
.child(FirebaseAuth.getInstance().getCurrentUser().getUid());
//move add listener here
mReference.addValueEventListener(mLisenter);
}
Upvotes: 1