对FirebaseRecyclerAdapter进行排序 [英] Sort a FirebaseRecyclerAdapter

查看:56
本文介绍了对FirebaseRecyclerAdapter进行排序的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在制作一个显示来自FireBase的星期几的应用程序,问题是我把它们弄乱了,我希望对它们进行排序.

I'm making an app that shows the days of the week coming from FireBase, the problem is that I have them messed up and I want them to be sorted.

我已经搜索了很多地方,并使用适配器的排序方法进行了排序:

I have searched in many places and put order with the sort method of the adapter:

使用阵列适配器排序列表视图

问题是我无法使用此方法,因为我使用的FirebaseRecyclerAdapter是从不具有sort方法的适配器派生的.

The problem is that I can not use this method because I use a FirebaseRecyclerAdapter which derives from an Adapter, which does not have the sort method.

最后,我能够对适配器的数据进行排序,但是当我显示适配器时,仅显示最后一个元素,而没有显示前一个元素.

At the end I was able to sort the data of the adapter but when I show it only the last element is shown and the previous one is not.

我输入了代码:

适配器:

public class MyFireAdapterDiasFiestaRecyclerView extends FirebaseRecyclerAdapter<DiaFiestaMeta, MyFireAdapterDiasFiestaRecyclerView.MyFireViewHolder>
    implements View.OnClickListener {
private View.OnClickListener listener;
private List<DiaFiestaMetaFecha> dias;
private static List<TextView> views ;
private DiaFiestaMetaFecha fechaDia;

public MyFireAdapterDiasFiestaRecyclerView(Class<DiaFiestaMeta> modelClass, int modelLayout, Class<MyFireViewHolder> viewHolderClass, DatabaseReference ref) {
    super(modelClass, modelLayout, viewHolderClass, ref);
    dias = new ArrayList<>();
    views = new ArrayList<>();

}

@Override
public MyFireViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {
    View itemView = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.fila_diasfiesta_layout, viewGroup, false);
    itemView.setOnClickListener(this);
    MyFireViewHolder holder = new MyFireViewHolder(itemView);
    return holder;
}

public void setOnClickListener(View.OnClickListener listener) {
    this.listener = listener;
}

@Override
public void onClick(View view) {
    if (listener != null)
        listener.onClick(view);
}

@Override
protected void populateViewHolder(MyFireViewHolder viewHolder, DiaFiestaMeta modelo, int position) {
    fechaDia = new DiaFiestaMetaFecha(modelo.getUidDiaFiesta(), modelo.getTituloDiaFiesta());
    dias.add(fechaDia);
    if (this.getItemCount() == position + 1) {
        viewHolder.bindDatos(dias);
    }
}

public static class MyFireViewHolder extends RecyclerView.ViewHolder {
    private TextView textoTv;
    private int num;



    public MyFireViewHolder(View itemView) {
        super(itemView);
        textoTv = (TextView) itemView.findViewById(R.id.tvTituloDiaFiesta);

        views.add(textoTv);

    }

    public void bindDatos(String titulo) {
        textoTv.setText(titulo);
    }

    public void bindDatos(List<DiaFiestaMetaFecha> dias) {
        burbuja(dias);
        for (int i = 0; i < dias.size(); i++) {
            views.get(i).setText(dias.get(i).getTituloDiaFiesta());
        }
    }


}

}

还有我使用它的片段:

@Override
public void onAttach(Activity activity) {
    super.onAttach(activity);
    uidsFiestas = getUidsFiestas();
    //Por defecto mostramos la ultima fecha
    uidFiestaSeleccionada = getUltimaFiesta();
    adaptadorFiestas = new ArrayAdapter<String>(getContext(), android.R.layout.simple_spinner_item, uidsFiestas);
    //Ponemos el uidFiestaSeleccionada el primero para que nos lo muestre
    adaptadorFiestas.remove(uidFiestaSeleccionada);
    adaptadorFiestas.insert(uidFiestaSeleccionada,0);
    mDataBaseDiasFiestaSelRef = mDataBaseFiestasRef.child(uidFiestaSeleccionada).child("diasFiestas");
    adaptadorDiasFiestas = new MyFireAdapterDiasFiestaRecyclerView(DiaFiestaMeta.class, R.layout.fila_diasfiesta_layout, MyFireAdapterDiasFiestaRecyclerView.MyFireViewHolder.class, mDataBaseDiasFiestaSelRef);
}

@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fiestas_layout, container, false);

    ButterKnife.bind(this, view);
    spFiestas.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
        @Override
        public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
            TextView textoTv = (TextView) view;
            uidFiestaSeleccionada = textoTv.getText().toString();
            //fiestaSeleccionada = crearFiesta(uidFiestaSeleccionada);
            mDataBaseDiasFiestaSelRef = mDataBaseFiestasRef.child(uidFiestaSeleccionada).child("diasFiestas");
            adaptadorDiasFiestas = new MyFireAdapterDiasFiestaRecyclerView(DiaFiestaMeta.class, R.layout.fila_diasfiesta_layout, MyFireAdapterDiasFiestaRecyclerView.MyFireViewHolder.class, mDataBaseDiasFiestaSelRef);
            adaptadorViejoDiasFiestas = (MyFireAdapterDiasFiestaRecyclerView) recView.getAdapter();
            recView.setAdapter(adaptadorDiasFiestas);

            if (adaptadorViejoDiasFiestas!=null)
                adaptadorViejoDiasFiestas.cleanup();
        }

        @Override
        public void onNothingSelected(AdapterView<?> parent) {
        }
    });
    spFiestas.setAdapter(adaptadorFiestas);
    setHasOptionsMenu(true);

    recView.setHasFixedSize(true);
    manager = new LinearLayoutManager(getContext(), LinearLayoutManager.VERTICAL, false);
    recView.setLayoutManager(manager);
    recView.setAdapter(adaptadorDiasFiestas);
    return view;
}

谢谢!

推荐答案

仅显示一项的原因是,您仅有条件地调用bindViewHolder:

The reason only one item shows up is that you only call bindViewHolder conditionally:

if (this.getItemCount() == position + 1) {
    viewHolder.bindDatos(dias);
}

删除该条件,其他条件也会出现.

Remove that condition and the others will show up too.

要获得排序和过滤后的结果,您必须将查询传递到FirebaseRecyclerAdapter构造函数中,现在您要在其中传递DatabaseReference.因此,将构造函数添加到采用Query的适配器:

To get a sorted and filtered result, you have to pass a query into the FirebaseRecyclerAdapter constructor, where you are now passing in a DatabaseReference. So add a constructor to your adapter that takes a Query:

public MyFireAdapterDiasFiestaRecyclerView(
    Class<DiaFiestaMeta> modelClass, 
    int modelLayout, 
    Class<MyFireViewHolder> viewHolderClass, 
    Query query) {
    ...

然后使用对命令进行排序和过滤的查询来调用它:

And then invoke it with a query that orders and filters:

adapter = new MyFireAdapterDiasFiestaRecyclerView(
   DiaFiestaMeta.class,
   layout_that_you_use,
   MyFireViewHolder.class,
   ref.orderByChild("property_to_sort_and_filter_on").equalTo("value_to_filter_on")
);

这篇关于对FirebaseRecyclerAdapter进行排序的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆