- 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/
我最近在/ drawable中添加了一些.gifs,以便可以将它们与按钮一起使用。这个工作正常(没有错误)。现在,当我重建/运行我的应用程序时,出现以下错误: Error: Gradle: Execu
Android 中有返回内部存储数据路径的方法吗? 我有 2 部 Android 智能手机(Samsung s2 和 s7 edge),我在其中安装了一个应用程序。我想使用位于这条路径中的 sqlit
这个问题在这里已经有了答案: What's the difference between "?android:" and "@android:" in an android layout xml f
我只想知道 android 开发手机、android 普通手机和 android root 手机之间的实际区别。 我们不能从实体店或除 android marketplace 以外的其他地方购买开发手
自Gradle更新以来,我正在努力使这个项目达到标准。这是一个团队项目,它使用的是android-apt插件。我已经进行了必要的语法更改(编译->实现和apt->注释处理器),但是编译器仍在告诉我存在
我是android和kotlin的新手,所以请原谅要解决的一个非常简单的问题! 我已经使用导航体系结构组件创建了一个基本应用程序,使用了底部的导航栏和三个导航选项。每个导航选项都指向一个专用片段,该片
我目前正在使用 Facebook official SDK for Android . 我现在正在使用高级示例应用程序,但我不知道如何让它获取应用程序墙/流/状态而不是登录的用户。 这可能吗?在那种情
我在下载文件时遇到问题, 我可以在模拟器中下载文件,但无法在手机上使用。我已经定义了上网和写入 SD 卡的权限。 我在服务器上有一个 doc 文件,如果用户单击下载。它下载文件。这在模拟器中工作正常但
这个问题在这里已经有了答案: What is the difference between gravity and layout_gravity in Android? (22 个答案) 关闭 9
任何人都可以告诉我什么是 android 缓存和应用程序缓存,因为当我们谈论缓存清理应用程序时,它的作用是,缓存清理概念是清理应用程序缓存还是像内存管理一样主存储、RAM、缓存是不同的并且据我所知,缓
假设应用程序 Foo 和 Eggs 在同一台 Android 设备上。任一应用程序都可以获取设备上所有应用程序的列表。一个应用程序是否有可能知道另一个应用程序是否已经运行以及运行了多长时间? 最佳答案
我有点困惑,我只看到了从 android 到 pc 或者从 android 到 pc 的例子。我需要制作一个从两部手机 (android) 连接的 android 应用程序进行视频聊天。我在想,我知道
用于使用 Android 以编程方式锁定屏幕。我从 Stackoverflow 之前关于此的问题中得到了一些好主意,并且我做得很好,但是当我运行该代码时,没有异常和错误。而且,屏幕没有锁定。请在这段代
文档说: android:layout_alignParentStart If true, makes the start edge of this view match the start edge
我不知道这两个属性和高度之间的区别。 以一个TextView为例,如果我将它的layout_width设置为wrap_content,并将它的width设置为50 dip,会发生什么情况? 最佳答案
这两个属性有什么关系?如果我有 android:noHistory="true",那么有 android:finishOnTaskLaunch="true" 有什么意义吗? 最佳答案 假设您的应用中有
我是新手,正在尝试理解以下 XML 代码: 查看 developer.android.com 上的文档,它说“starStyle”是 R.attr 中的常量, public static final
在下面的代码中,为什么当我设置时单选按钮的外观会发生变化 android:layout_width="fill_parent" 和 android:width="fill_parent" 我说的是
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
假设我有一个函数 fun myFunction(name:String, email:String){},当我调用这个函数时 myFunction('Ali', 'ali@test.com ') 如何
我是一名优秀的程序员,十分优秀!