Java Firebase UI 3.0.0:检索数据以回收视图

Java Firebase UI 3.0.0:检索数据以回收视图,java,android,firebase,firebase-realtime-database,Java,Android,Firebase,Firebase Realtime Database,有人能帮我从NodeFoods中检索数据并将其放入RecyclerView吗。这些是我一直在处理的文件,但结果是一个空列表。我在互联网上看过一个教程,但大多数教程都使用了旧版本的Firebase。最近,Firebase UI已更新,数据绑定过程已更改为新的FirebaseRecyclerAdapter结构 这是我的数据库结构: "foods" : { "AntipastoSalad" : { "duration" : "30", "img" : "https://firebasestor

有人能帮我从NodeFoods中检索数据并将其放入RecyclerView吗。这些是我一直在处理的文件,但结果是一个空列表。我在互联网上看过一个教程,但大多数教程都使用了旧版本的Firebase。最近,Firebase UI已更新,数据绑定过程已更改为新的FirebaseRecyclerAdapter结构

这是我的数据库结构:

"foods" : {
"AntipastoSalad" : {
  "duration" : "30",
  "img" : "https://firebasestorage.googleapis.com/v0/b/mealplanner-ec8ca.appspot.com/o/res%2Fsalad.jpg?alt=media&token=257d4392-8a1f-4fb7-84b5-b63abb4643f4",
  "name" : "Antipasto salad",
  "type" : "Salad"
},
public class Meal{

private String img;
private String duration;
private String name;
private String instruction;

public Meal(){

}

public Meal (String img, String duration, String name, String instruction){
    this.img = img;
    this.name = name;
    this.duration = duration;
    this.instruction = instruction;
}

public void update(String duration, String name, String instruction)
{
    this.name = name;
    this.duration = duration;
    this.instruction = instruction;
}
public String getName(){
    return name;
}

public String getDuration() {
    return duration;
}

public String getInstruction() {
    return instruction;
}

public String getImg(){return img;}
这是我的活动:

    private RecyclerView mRecycleView;
    private Query query;
    private FirebaseRecyclerOptions<Meal> options;
    private DatabaseReference mDatabase;

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

        mDatabase = FirebaseDatabase.getInstance().getReference().child("foods");

        //Recycle View
        mRecycleView = (RecyclerView) findViewById(R.id.meal_items);
        mRecycleView.setHasFixedSize(true);
        mRecycleView.setLayoutManager(new LinearLayoutManager(this));
    }


    @Override
    protected void onStart() {
        super.onStart();

        query = FirebaseDatabase.getInstance().getReferenceFromUrl("https://mealplanner-ec8ca.firebaseio.com/foods/AntipastoSalad");

        options = new FirebaseRecyclerOptions.Builder<Meal>()
                .setQuery(query, Meal.class)
                .build();

        FirebaseRecyclerAdapter<Meal, FoodListRowActivity.MealRowHolder> firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Meal, FoodListRowActivity.MealRowHolder>(
                options) {
            @Override
            public FoodListRowActivity.MealRowHolder onCreateViewHolder(ViewGroup parent, int viewType) {
                View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.food_row, parent, false);
                return new FoodListRowActivity.MealRowHolder(v);
            }

            @Override
            protected void onBindViewHolder(FoodListRowActivity.MealRowHolder holder, int position, Meal current) {
                holder.setTitle(current.getName());
                String duration = current.getDuration() + "min";
                holder.setDuration(duration);
            }
        };

        //Populate Item into Adapter
        mRecycleView.setAdapter(firebaseRecyclerAdapter);

        mRecycleView.addOnItemTouchListener(new RecycleViewItemClickListener(this, mRecycleView, new RecycleViewItemClickListener.OnItemClickListener() {
            @Override
            public void onItemClick(View view, int position) {
                Intent viewMeal = new Intent(FoodListRowActivity.this, CookingInstructionActivity.class);
                startActivity(viewMeal);
            }

            @Override
            public void onLongItemClick(View view, int position) {
                //TODO: DELETE
            }
        }));
    }

    public static class MealRowHolder extends RecyclerView.ViewHolder {

        View mView;

        public MealRowHolder(View itemView) {
            super(itemView);
            mView = itemView;

        }

        public void setTitle(String title) {
            TextView foodTitle = (TextView) mView.findViewById(R.id.list_item_foodList_name);
            foodTitle.setText(title);
        }


        public void setDuration(String title) {
            TextView foodDuration = (TextView) mView.findViewById(R.id.list_item_foodList_calories);
            foodDuration.setText(title);
        }
    }
}

以下是我使用Firebase UI在recyclerview中检索数据的方式:

 private FirebaseRecyclerAdapter<TaskPOJO, TaskViewHolder> adapter;
 private void loadTasks() {


        database = FirebaseDatabase.getInstance();
        tasks = database.getReference("Tasks");
        adapter = new FirebaseRecyclerAdapter<TaskPOJO, TaskViewHolder>(TaskPOJO.class, R.layout.task_item, TaskViewHolder.class, tasks) {
            @Override
            protected void populateViewHolder(TaskViewHolder viewHolder, final TaskPOJO model, int position) {


                Log.wtf("valueTEst", "populateViewHolder: "+model.toString() );
                Log.wtf("TEstScript1", "populateViewHolder: "+model.getTitle() );
                viewHolder.title.setText(model.getTitle());
                viewHolder.desc.setText(model.getDescripttion()+"\n");
                viewHolder.remaining.setText(model.getRemaining()+"/"+model.getPoint());
                viewHolder.points.setText("Points "+model.getRemaining());
                Glide.with(viewHolder.title.getContext())
                        .load(model.getImage())
                        .into(viewHolder.image);


                viewHolder.setClickListener(new ItemClickListener() {
                    @Override
                    public void onClick(View view, int position, boolean isLongClick) {
                        Toast.makeText(getActivity(), "" /*+ model.getTitle()*/, Toast.LENGTH_SHORT).show();

                        Intent TaskPOJODetail = new Intent(getActivity(), Main.class);
                        TaskPOJODetail.putExtra("value","detail");
                        TaskPOJODetail.putExtra("taskId",adapter.getRef(position).getKey());
                        startActivity(TaskPOJODetail);
                    }
                });
            }
        };
        progressBar.setVisibility(View.GONE);
        recyclerViewTasks.setAdapter(adapter);
    }
这是我的firebase结构:


希望这能对您有所帮助。

这是我如何使用Firebase UI在recyclerview中检索数据的:

 private FirebaseRecyclerAdapter<TaskPOJO, TaskViewHolder> adapter;
 private void loadTasks() {


        database = FirebaseDatabase.getInstance();
        tasks = database.getReference("Tasks");
        adapter = new FirebaseRecyclerAdapter<TaskPOJO, TaskViewHolder>(TaskPOJO.class, R.layout.task_item, TaskViewHolder.class, tasks) {
            @Override
            protected void populateViewHolder(TaskViewHolder viewHolder, final TaskPOJO model, int position) {


                Log.wtf("valueTEst", "populateViewHolder: "+model.toString() );
                Log.wtf("TEstScript1", "populateViewHolder: "+model.getTitle() );
                viewHolder.title.setText(model.getTitle());
                viewHolder.desc.setText(model.getDescripttion()+"\n");
                viewHolder.remaining.setText(model.getRemaining()+"/"+model.getPoint());
                viewHolder.points.setText("Points "+model.getRemaining());
                Glide.with(viewHolder.title.getContext())
                        .load(model.getImage())
                        .into(viewHolder.image);


                viewHolder.setClickListener(new ItemClickListener() {
                    @Override
                    public void onClick(View view, int position, boolean isLongClick) {
                        Toast.makeText(getActivity(), "" /*+ model.getTitle()*/, Toast.LENGTH_SHORT).show();

                        Intent TaskPOJODetail = new Intent(getActivity(), Main.class);
                        TaskPOJODetail.putExtra("value","detail");
                        TaskPOJODetail.putExtra("taskId",adapter.getRef(position).getKey());
                        startActivity(TaskPOJODetail);
                    }
                });
            }
        };
        progressBar.setVisibility(View.GONE);
        recyclerViewTasks.setAdapter(adapter);
    }
这是我的firebase结构:

希望这将对您有所帮助。

请重写FirebaseRecyclerAdapter的getItemCount方法

请重写FirebaseRecyclerAdapter的getItemCount方法

setQuery方法中指定的查询应该是对要在RecyclerView中显示的列表根的引用,如下所示:

query = FirebaseDatabase.getInstance().getReference().child("foods");
您还需要在适配器上调用startListening,以指示它开始从数据库检索数据

从:

FirebaseRecyclerAdapter使用事件侦听器监视对Firebase查询的更改。要开始侦听数据,请调用startListening方法。您可能希望在onStart方法中调用此函数。在调用startListening之前,请确保已完成读取数据所需的任何身份验证,否则查询将失败

@Override protected void onStart() {
    super.onStart();
    adapter.startListening();
}
类似地,stopListening调用将删除事件侦听器和适配器中的所有数据。当包含的活动或片段停止时调用此方法:

setQuery方法中指定的查询应该是对要在RecyclerView中显示的列表根的引用,如下所示:

query = FirebaseDatabase.getInstance().getReference().child("foods");
您还需要在适配器上调用startListening,以指示它开始从数据库检索数据

从:

FirebaseRecyclerAdapter使用事件侦听器监视对Firebase查询的更改。要开始侦听数据,请调用startListening方法。您可能希望在onStart方法中调用此函数。在调用startListening之前,请确保已完成读取数据所需的任何身份验证,否则查询将失败

@Override protected void onStart() {
    super.onStart();
    adapter.startListening();
}
类似地,stopListening调用将删除事件侦听器和适配器中的所有数据。当包含的活动或片段停止时调用此方法:


谢谢你的回答,但这似乎是Firebase UI的旧版本:谢谢你的回答,但这似乎是Firebase UI的旧版本:这似乎不是问题。应用程序刚刚崩溃并打印java.lang.IndexOutOfBoundsException:索引0无效,大小为0。但是谢谢你的帮助。看来这不是问题。应用程序刚刚崩溃并打印java.lang.IndexOutOfBoundsException:索引0无效,大小为0。但是谢谢你的帮助。