我试图动态地实现textview,进入我的视图持有者,在第一个卷轴上一切顺利,卡片等都是每个属性,但如果我再次向上滚动,textview开始弹出他们不应该的地方。
我的定制适配器:
public class CustomAdapter extends RecyclerView.Adapter<CustomAdapter.ViewHolder> {
public interface OnItemClickListener {
void onItemClick(MyProduct product);
}
int counter = 0;
private OnItemClickListener listener;
private Context context;
List<MyProduct> myProducts;
public CustomAdapter(OnItemClickListener listener, List<MyProduct> myProducts, Context context)
{
super();
this.listener = listener;
this.myProducts = myProducts;
this.context = context;
}
@Override
public CustomAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View v = LayoutInflater.from(parent.getContext())
.inflate(R.layout.product_list, parent, false);
ViewHolder viewHolder = new ViewHolder(v);
return viewHolder;
}
@Override
public void onBindViewHolder(CustomAdapter.ViewHolder holder, int position) {
if( myProducts != null) {
holder.bind(myProducts.get(position), listener);
counter++;
}
}
@Override
public int getItemCount() {
return myProducts.size();
}
public class ViewHolder extends RecyclerView.ViewHolder {
//Views
public ImageView imageView;
public TextView textViewProductTitle;
public TextView textViewProductDescription;
public TextView textViewProductSerialNumber;
public TextView textViewProductPrice;
List<TextView> textViews;
ViewGroup viewGroup;
//Initializing Views
public ViewHolder(View itemView) {
super(itemView);
viewGroup = (ViewGroup)itemView.findViewById(R.id.linearCatalog);
textViews = new LinkedList<>();
imageView = (ImageView) itemView.findViewById(R.id.thumbnail);
textViewProductTitle = (TextView) itemView.findViewById(R.id.textViewProductTitle);
textViewProductDescription = (TextView) itemView.findViewById(R.id.textViewProductDescription);
textViewProductSerialNumber = (TextView) itemView.findViewById(R.id.textViewProductSerialNumber);
textViewProductPrice = (TextView) itemView.findViewById(R.id.textViewProductPrice);
}
public void bind(final MyProduct item, final OnItemClickListener listener) {
Glide.with(context).load(item.getProductImage())
/*.asBitmap().format(DecodeFormat.PREFER_ARGB_8888).*/
.crossFade()
.diskCacheStrategy(DiskCacheStrategy.ALL)
.into(imageView);
textViewProductTitle.setText(item.getProductTitle());
textViewProductDescription.setText(item.getProductDescription());
textViewProductSerialNumber.setText(item.getProductSn());
textViewProductPrice.setText(item.getProductPrice());
if(counter< myProducts.size())
{
for (int i = 0; i < item.getBranchCounter(); i++) {
TextView textView = new TextView(context);
textView.setText(item.getAddressList().get(i));
textViews.add(textView);
viewGroup.addView(textView);
}
}
itemView.setOnClickListener(new View.OnClickListener() {
@Override public void onClick(View v) {
listener.onItemClick(item);
}
});
}
}
任何建议都会有所帮助,ty!
动态地将视图添加到回收器视图中是一个不错的想法。 回收者视图的重点是它在多个项目上回收相同的视图结构。 因此,当它回收时,您突然将该视图添加到不需要它的新项目中。 没有动态视图几乎是拥有回收者视图的先决条件。
更好的方法是玩弄可见性。 将文本视图放在所有视图中,但将其设置为GONE。 在绑定中,您可以为每个项目设置文本视图的可见性 - GONE或VISIBLE。 这会给你你想要的效果。
另一种方法是使用不同的视图类型,有或没有额外的视图,但往往更复杂。
我完全赞同@Gabe Sechan。 但即使您有兴趣动态添加textView。 然后你可以在适配器类的顶部声明一个整数,如
int repeat=0;
现在使用变量来计算您添加的每个文本视图。 还要检查它是否超出了阵列的大小。
if (repeat <= yourArray.size()) {
for (int i = 0; i < yourArray.size(); i++) {
repeat++;
TextView valueTV = new TextView(getApplicationContext());
valueTV.setText(yourArray[i]);
valueTV.setLayoutParams(new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT));
linearlayout.addView(valueTV);
}
}
这将限制textview的重复。