- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我为我的英语道歉,我是法国人。
我在 RecyclerView 中的列表有问题。实际上,我想动态更改项目的 TextView。但是,当我更改第一项的 textView 时,最后一项也发生了变化。我使用 CardView 来表示我的项目。
我不认为这是我的代码,而是 RecyclerView 的特殊性。
先感谢您
我的适配器
public class CardAgendaAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> implements TimePickerDialog.OnTimeSetListener {
private static final int LENGTH = 7;
static private final int test[] = {1, 1, 1, 1, 1, 1, 1};
private int[][] dispo = new int[7][4];
private Context context;
private int startHour = -1;
private int finishHour = -1;
private int startMinute = -1;
private int finishMinute = -1;
private int pos = 0;
private RecyclerView.ViewHolder holderr;
public CardAgendaAdapter(Context context) {
this.context = context;
for (int i = 0; i < LENGTH; i++) {
dispo[i][0] = -1;
dispo[i][1] = -1;
dispo[i][2] = -1;
dispo[i][3] = -1;
}
}
@Override
public int getItemViewType(int position) {
// Just as an example, return 0 or 2 depending on position
// Note that unlike in ListView adapters, types don't have to be contiguous
return test[position];
}
@Override
public int getItemCount() {
return LENGTH;
}
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
LayoutInflater inflater = LayoutInflater.from(parent.getContext());
View view1 = inflater.inflate(R.layout.agenda_modify_card, parent, false);
View view2 = inflater.inflate(R.layout.agenda_card, parent, false);
switch (viewType) {
case 0: return new ViewHolder0(view1);
case 1: return new ViewHolder2(view2);
}
return null;
}
static final String days[] = {"Lundi", "Mardi","Mercredi","Jeudi","Vendredi","Samedi","Dimanche"};
@Override
public void onBindViewHolder(final RecyclerView.ViewHolder holder, final int position) {
switch (getItemViewType(position)) {
case 1 :
ViewHolder2 v2 = (ViewHolder2) holder;
v2.setDay(days[position]);
v2.setImage(position);
Log.d("item : ", String.valueOf(position));
v2.add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
pos = position;
holderr = holder;
TimePickerDialog timePickerDialog = new TimePickerDialog(context, listener, 0, 0, true);
timePickerDialog.show();
}
});
break;
case 0:
ViewHolder0 v0 = (ViewHolder0) holder;
v0.setTextCard();
v0.setDay(days[position]);
v0.setImage(position);
break;
}
}
public String testText(int startHour, int startMinute, int finishHour, int finishMinute) {
return String.valueOf(Html.fromHtml("Vous êtes disponnible de <b>" + String.valueOf(startHour) + "h" + String.valueOf(startMinute) +"</b> à <b> "+ String.valueOf(finishHour)+"h" +String.valueOf(finishMinute)+"</b>"));
}
public void setHour(int poistion, int startHour, int startMinute, int finishHour, int finishMinute, final RecyclerView.ViewHolder holder) {
dispo[poistion][0] = startHour;
dispo[poistion][1] = startMinute;
dispo[poistion][2] = finishHour;
dispo[poistion][3] = finishMinute;
switch (getItemViewType(poistion)) {
case 1:
ViewHolder2 v2 = (ViewHolder2) holder;
v2.setTextCard(startHour,startMinute,finishHour,finishMinute);
//view.findViewById(R.id.button_add).setVisibility(View.INVISIBLE);
//view.findViewById(R.id.button_modify).setVisibility(View.VISIBLE);
}
Log.d("Jour : " + poistion, String.valueOf(dispo[poistion][0]));
Log.d("Jour : " + poistion, String.valueOf(dispo[poistion][1]));
Log.d("Jour : " + poistion, String.valueOf(dispo[poistion][2]));
Log.d("Jour : " + poistion, String.valueOf(dispo[poistion][3]));
}
private void reinitHour() {
startHour = -1;
startMinute = -1;
}
@Override
public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
TimePickerDialog timePickerDialog2;
Log.d("Picker la", "AVANT");
timePickerDialog2 = new TimePickerDialog(context, listener, 0, 0, true);
Log.d("Picker la", "APRÈS");
timePickerDialog2.show();
}
protected TimePickerDialog.OnTimeSetListener listener =
new TimePickerDialog.OnTimeSetListener() {
@Override
public void onTimeSet(TimePicker view, int hourOfDay, int minuteOfDay) {
if (startHour == -1 && startMinute == -1) {
startHour = hourOfDay;
startMinute = minuteOfDay;
TimePickerDialog timePickerDialog2;
timePickerDialog2 = new TimePickerDialog(context, listener, 0, 0, true);
timePickerDialog2.show();
Toast.makeText(view.getContext(), "Heure de depart : " + startHour + " minutes de départ : " + startMinute, Toast.LENGTH_LONG).show();
} else {
finishHour = hourOfDay;
finishMinute = minuteOfDay;
Log.d("ça passe la", "FINNNNNNNN");
Toast.makeText(view.getContext(), "Heure de fin : " + finishHour + " minutes de fin : " + finishMinute, Toast.LENGTH_LONG).show();
setHour(pos,startHour,startMinute,finishHour,finishMinute, holderr);
reinitHour();
}
}
};
class ViewHolder2 extends RecyclerView.ViewHolder {
TextView title;
TextView disponibility;
ImageView imageView;
Button add;
Button modify;
public ViewHolder2(View itemView) {
super(itemView);
title = (TextView) itemView.findViewById(R.id.card_title);
disponibility = (TextView) itemView.findViewById(R.id.card_text);
imageView = (ImageView) itemView.findViewById(R.id.card_image);
add = (Button) itemView.findViewById(R.id.button_add);
modify = (Button) itemView.findViewById(R.id.button_modify);
}
public void setTextCard(int startHour, int startMinute, int finishHour, int finishMinute) {
disponibility.setText(Html.fromHtml("Vous êtes disponnible de <b>" + String.valueOf(startHour) + "h" + String.valueOf(startMinute) +"</b> à <b> "+ String.valueOf(finishHour)+"h" +String.valueOf(finishMinute)+" </b>"));
}
public void setDay(String str) {
if (title != null) {
title.setText(str);
}
}
public void setImage(int position) {
if (imageView != null) {
imageView.setImageResource(getId(position+1));
}
}
private int getId(int position) {
Context context = imageView.getContext();
int id = context.getResources().getIdentifier("tennis"+position, "drawable", context.getPackageName());
return id;
}
}
class ViewHolder0 extends RecyclerView.ViewHolder {
TextView textCard;
TextView textTitle;
ImageView imageView;
public ViewHolder0(View itemView){
super(itemView);
textCard = (TextView) itemView.findViewById(R.id.card_text);
textTitle = (TextView) itemView.findViewById(R.id.card_title);
imageView = (ImageView) itemView.findViewById(R.id.card_image);
}
public void setDay(String str) {
if (textTitle != null) {
textTitle.setText(str);
}
}
public void setTextCard() {
textCard.setText(Html.fromHtml("Vous êtes disponnible de <b>17h30</b> à <b>18h30</b>"));
}
public void setImage(int position) {
if (imageView != null) {
imageView.setImageResource(getId(position + 1));
}
}
private int getId(int position) {
Context context = imageView.getContext();
int id = context.getResources().getIdentifier("tennis"+position, "drawable", context.getPackageName());
return id;
}
}
}
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/card_view"
android:layout_width="match_parent"
android:layout_height="@dimen/card_height"
android:layout_gravity="center"
android:layout_marginBottom="@dimen/md_keylines"
android:layout_marginLeft="@dimen/md_keylines"
android:layout_marginRight="@dimen/md_keylines"
app:elevation="0dp"
android:foreground="?attr/selectableItemBackground">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/card_image"
android:layout_width="match_parent"
android:layout_height="@dimen/card_image_height"
android:scaleType="centerCrop"
android:src="@drawable/tennis1" />
<TextView
android:id="@+id/card_title"
android:layout_width="match_parent"
android:layout_height="@dimen/card_title_height"
android:text="Lundi"
android:textAppearance="@style/TextAppearance.AppCompat.Title"
android:textColor="@color/white"
android:layout_above="@+id/card_text"
android:layout_alignLeft="@+id/card_text"
android:layout_alignStart="@+id/card_text"
android:layout_marginLeft="5dp"
android:gravity="center_vertical" />
<TextView
android:id="@+id/card_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:text="Vous n'avez pas ajouté de disponibilité"
android:ellipsize="end"
android:singleLine="true"
android:textColor="@color/dark_grey"
android:textSize="@dimen/article_subheading"
android:layout_below="@+id/card_image"
android:layout_centerHorizontal="true"
android:gravity="center_horizontal" />
<Button
android:id="@+id/button_add"
android:layout_width="match_parent"
android:layout_height="wrap_content"
style="?android:attr/borderlessButtonStyle"
android:textColor="@color/green"
android:text="AJOUTER"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true" />
</RelativeLayout>
</android.support.v7.widget.CardView>
最佳答案
它与您的绑定(bind)以及适配器的工作方式有关。
就像名称已经告诉您的那样,如果不再显示原始位置,则适配器的 View 将被回收以显示在另一个位置。但是您的 ViewHolder2
的代码不会更新 View 持有者的所有数据。
ViewHolder2 v2 = (ViewHolder2) holder;
v2.setDay(days[position]);
v2.setImage(position);
Log.d("item : ", String.valueOf(position));
v2.add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
pos = position;
holderr = holder;
TimePickerDialog timePickerDialog = new TimePickerDialog(context, listener, 0, 0, true);
timePickerDialog.show();
}
});
v2.setTextCard()
的调用.所以你需要以某种方式确保
disponibility
设置正确。这通常适用于任何 View 持有者的所有领域。
update()
也很方便。 View 持有者上的方法来处理更改。
onCreateViewHolder()
方法可能会更有效一些。目前,您每次都在膨胀两个 View ,即使您只使用一个。
LayoutInflater inflater = LayoutInflater.from(parent.getContext());
switch (viewType) {
case 0: return new ViewHolder0(inflater.inflate(R.layout.agenda_modify_card, parent, false));
case 1: return new ViewHolder2(inflater.inflate(R.layout.agenda_card, parent, false));
default: return null;
}
关于Android RecyclerView - 当我更改第一个项目时,最后一个更改也是,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43026481/
我在另一个 RecyclerView(parentRecyclerView) 中实现了 RecyclerView(childRecyclerView),图片说明了所有的实现: 我想编写一个 espre
我正在构建一个应用程序,它使用ViewPager2在页面之间水平滚动,每个页面都有一个垂直滚动的内容RecyclerView,其中每个列表的第一个位置都有一行水平滚动小部件,例如附加到寻呼机指示器类型
我正在尝试实现一个水平的 recyclerview 并且 recyclerview 的每个项目都将是一个具有网格布局的垂直 recyclerview。我面临的问题是,当我尝试垂直滚动子 recycle
我使用显示条目列表的 RecyclerView。每个条目都托管另一个 RecyclerView,它是一个图像列表。 我现在想让这个嵌套的 RecyclerView 可点击,而不是它的项目,而是整个 V
我正在尝试将手机中的图像加载到我的回收 View 中。 到目前为止,我已经创建了一个 recyclerview.adapter 和一个 gridlayoutmanager,并将它们附加到我的 recy
我需要一个可扩展 View ,其中父/可扩展标题将具有文本和下拉箭头。每个此类标题的子项应该是在网格结构中具有多个项目的 View 。 (有点像带有 GridLayoutManager 的回收器 Vi
我正在使用显示不同类别列表的 RecyclerView。每行项目还包含 RecyclerView 以显示类别项目列表。父级 RecyclerView 由垂直 LinearLayoutManager 填
我正在更新一个旧的 Android 项目,现在我从 RecyclerView 中反复收到这条日志语句: W/RecyclerView:RecyclerView 不支持滚动到绝对位置。改为使用 scro
在我的 Adapter 中,我调用 LayoutManager.ChildAt(position) 来获取 itemview,但是我得到的 View 不是匹配的 itemview,当我调用 notif
我正在从 ListView 迁移到 RecyclerView,但是在 SQLite 中输入一些数据后,我的列表没有使用 notifyDataSetChanged() 更新;所以我总是要调用setAda
我正在用 Google Now Cards 的风格创建一组 5 张卡片。我首先关注的是总体布局。 我正在使用 CardView 和 RecyclerView ,我想要实现的是这样的: 这是我的 Car
在我的应用程序中,我有一个 RecyclerView,其中包含一个简单的项目 View ,每行包含一个 TextView 和一个 Spinner。 用户从操作栏中单击“保存”后,我需要遍历所有项目并获
我正在尝试检查 RecyclerView 中是否可以看到某些特定项目;但我无法实现。请帮助我确定我的项目是否在 RecyclerView 中完全可见。 mrecylerView.addOnScroll
我有一个提要片段,它的主要元素是帖子的 RecyclerView。 我正在使用 Lisa Wray 的 Groupie 库管理回收站 https://github.com/lisawray/group
我有这两个类似的行为回收器 View 适配器,它们之间的唯一区别是 onclick 方法和传递给它们的对象。所以,我正在考虑将类 B 设计为从回收器 View 适配器继承,这样我就可以更改构造函数来执
这很奇怪。我对这个问题感到沮丧。我将数据保存在 ArrayList 中。当我将数据放在 RecyclerView 上时。数据未显示在列表中。这是我的代码 listOrder.forEach { ord
编辑我通过使用 CoordinatorLayout 和 AppBarLayout 作为 header 和 TabLayout 的包装解决了这个问题。本来应该很明显,但是哦,好吧。 原始问题:我有一个设
我有一个回收 View 。我想从其适配器类更新回收器 View 。我尝试了 notiftDataSetChanged( ) 但它只适用于主类。下面是 recyclerview 适配器类的代码。 pac
我正在使用具有不同 viewholders 的 recyclerview(具有垂直 LinearLayout),其中一个有另一个 RecyclerView(带有水平 LL)。在第二个 recycler
我想创建一个与 Google Play Store 或 Netflix App 类似的布局,其中在单个 RecyclerView 中基本上有多个水平 RecyclerView。如果这不是他们做事的方式
我是一名优秀的程序员,十分优秀!