对FirebaseRecyclerAdapter进行排序 [英] Sort a 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屋!