- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个带有复选框和文本框的 ListView 。当我选中复选框并上下滚动它时,它会自动取消选中。如何在 ListView 中解决这个问题?请给我解决方案。
下面是我的屏幕截图和代码。
activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<ListView
android:id="@+id/lvMain"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" />
<Button
android:id="@+id/btnSelectAll"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:text="Select All" >
</Button>
</LinearLayout>
list_item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" >
<CheckBox
android:id="@+id/cbItem"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:buttonTint="#000000">
</CheckBox>
<TextView
android:id="@+id/tvItem"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#000000">
</TextView>
</LinearLayout>
MainActivity.java
package com.example.checkallcheckbox;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ListView;
public class MainActivity extends Activity {
ListView lvMain;
String[] name = { "Jenis", "Pratik", "Jaydeep", "Hiren", "Himansu",
"yagnik", "Atul", "Prakas", "Nihal", "Darshan", "Chetan", "Sagar",
"Nikhil", "Sanket", "Rahul", "Jigar" };
Button btnSelectAll;
boolean isSelectAll = true;
ListAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lvMain = (ListView) findViewById(R.id.lvMain);
btnSelectAll = (Button) findViewById(R.id.btnSelectAll);
btnSelectAll.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
// TODO Auto-generated method stub
if(isSelectAll)
{
adapter = new ListAdapter(getApplicationContext(), name, true);
lvMain.setAdapter(adapter);
adapter.notifyDataSetChanged();
btnSelectAll.setText("ClearAll");
isSelectAll=false;
}
else
{
adapter = new ListAdapter(getApplicationContext(), name, false);
lvMain.setAdapter(adapter);
adapter.notifyDataSetChanged();
btnSelectAll.setText("CheckAll");
isSelectAll=true;
}
}
});
adapter = new ListAdapter(getApplicationContext(), name,false);
lvMain.setAdapter(adapter);
adapter.notifyDataSetChanged();
}
}
ListAdapter.java
package com.example.checkallcheckbox;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.CheckBox;
import android.widget.TextView;
public class ListAdapter extends BaseAdapter {
Context mContext;
String[] name;
private static LayoutInflater inflater = null;
Boolean state=false;
public ListAdapter(Context c, String[] name, boolean isSelectAll) {
// TODO Auto-generated constructor stub
mContext = c;
this.name = name;
inflater = (LayoutInflater) mContext
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
state=isSelectAll;
}
@Override
public int getCount() {
return name.length;
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
public class ViewHolder {
TextView tvName;
CheckBox cbName;
}
@Override
public View getView(int position, View convertView, ViewGroup arg2) {
// TODO Auto-generated method stub
ViewHolder viewHolder;
if (convertView == null) {
convertView = inflater.inflate(R.layout.list_item, null);
viewHolder = new ViewHolder();
viewHolder.tvName = (TextView) convertView
.findViewById(R.id.tvItem);
viewHolder.cbName = (CheckBox) convertView
.findViewById(R.id.cbItem);
convertView.setTag(viewHolder);
} else {
viewHolder = (ViewHolder) convertView.getTag();
}
viewHolder.tvName.setText(name[position]);
if(state){
viewHolder.cbName.setChecked(true);
}else{
viewHolder.cbName.setChecked(false);
}
return convertView;
}
}
最佳答案
问题是因为您的 ListView View 正在重新制作。当您将它们滚动到屏幕外时,android 不会保留它们(列表可能真的很长,所以这意味着有很多您看不到的 View )。
因此,每次您将某个项目滚动回屏幕时,Android 会再次调用 getView
并返回一个未选中复选框的 View 。
您需要做的是在每个列表项上设置一个单击/选中的监听器,以便能够记住它们何时被选中。然后当 android 向你询问 View 时,你可以检查它是否应该被检查。
您可以看到 getItem
方法已经存在,可以帮助您完成此操作。您可以尝试重写 ArrayAdapter
,因为这样您就可以存储一些可以保存“已单击”状态的简单对象。请参阅:http://developer.android.com/reference/android/widget/ArrayAdapter.html
这就是为什么 Aditya 会问您模型类在哪里。目前你只有一份学生名单,你想要的是一份学生名单以及他们是否被选中。也许是这样的类(class):
class Student
{
private String mName;
public Boolean selected;
public Student(String name)
{
mName = name;
}
public String getName()
{
return mName;
}
}
然后你可以用这些数组代替。单击某个项目时,您将在相关学生项目上设置 selected
。
您的 getView
可能如下所示:
@Override
public View getView(int position, View convertView, ViewGroup arg2) {
// TODO Auto-generated method stub
ViewHolder viewHolder;
if (convertView == null) {
convertView = inflater.inflate(R.layout.list_item, null);
viewHolder = new ViewHolder();
viewHolder.tvName = (TextView) convertView
.findViewById(R.id.tvItem);
viewHolder.cbName = (CheckBox) convertView
.findViewById(R.id.cbItem);
convertView.setTag(viewHolder);
} else {
viewHolder = (ViewHolder) convertView.getTag();
}
Student thisStudent = students[position];
viewHolder.tvName.setText(thisStudent.getName());
if(state || thisStudent.selected){
viewHolder.cbName.setChecked(true);
}else{
viewHolder.cbName.setChecked(false);
}
return convertView;
}
有很多关于此的指南,这里有一个这样的指南,它解释了 View 回收在列表中的工作原理(您的问题)以及如何使用 ArrayAdapter
https://github.com/codepath/android_guides/wiki/Using-an-ArrayAdapter-with-ListView
关于android - 滚动 ListView 时自动取消选中复选框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35939788/
是否可以使用标准输入/标准输出在 bash 中压缩/解压缩字符串? 我试过了,但显然不支持它? hey=$(echo "hello world" | gzip -cf) echo $hey # ret
我的任务是让一个企业网站适用于 IE7,它必须“足够好”,因此我禁用了任何导致问题的花哨/非必要功能。 其中之一是正在使用的搜索栏,需要进行哪些搜索,我猜测幕后某个地方有某种 JavaScript 用
我有一个执行大量处理的小程序。您可以通过按回车键打印进度。 我实现它的方法是在主线程中完成处理,同时我有一个 pthread 不断循环 getchar() 以等待输入键。 问题是当我完成处理时。发生这
我完全理解 suspendCoroutine 与 suspendCancellableCoroutine 在我的示例中的工作方式。但我想知道为什么 println("I finished") (第 1
我是 QT 的新手。目前在我的项目中我实现了 QFileDialog . 在我的用例中:每当用户选择一个文本文件时,它都会执行 functionA .但是,我发现如果在文件对话框中单击取消,funct
我有代码,仅在用户选择“另存为”时运行。为此并获取我正在使用的文件的新名称 Application.GetSaveAsFilename功能。 我遇到的问题是类型不匹配,同时检查用户是否在他没有这样做时
我的 UILocalNotification 有问题。 我正在用我的方法安排通知。 - (void) sendNewNoteLocalReminder:(NSDate *)date alrt:(NS
祝你有美好的一天 我有一个网站,其中有很多“工具提示”。这些工具提示是在将鼠标悬停在文本的特定部分上时创建的。工具提示是一个 div block ,它显示在网站上所有其他内容的顶部,并且当光标从文本移
我遇到以下问题。每隔 2 秒,程序就会进入 if 语句。在这个 if 语句中,我想要一个计时器,它会在 15 秒后给我一条消息。计时器应延迟 1 秒运行。但是当我用计时器“等待”时,if 语句将再执行
基本上我有以下代码片段, (let [task (FutureTask. fn) thr (Thread. task)] (.start thr) ;;wait for signa
取消正在进行的 ASIHttpRequest 请求的正确位置在哪里?这就是我取消的方式,但是当我 时它继续崩溃在不让请求完成的情况下从一个 View Controller 转移到另一个 View Co
我在我的 winforms 应用程序中使用 BackgroundWorker 来执行另一个类中发生的长时间运行的任务(执行数据库操作)。由于所有工作都是在另一个类中完成的,因此取消并不那么简单。我在另
我正在使用 OneSignal 向我的用户显示通知。通知工作正常,但我注意到,如果我在通知栏中“滑动”取消通知,则通知将永远保留,这是一张显示应用程序图标上的通知的图像,我想在应用程序已打开: 我看到
正在运行的 AsyncTask 的 .cancel(boolean) 方法如何工作?这是文档: Attempts to cancel execution of this task. This atte
我注意到,当我激活约束时,我会立即在该行代码处收到一条警告,指出不能同时满足约束。 我假设布局是在“UI 更新周期”之类的稍后时间点计算的,而不是每次约束都被(取消)激活。因此,在(取消)激活约束的代
这是我创建线程的方式: readFromWebThread = [[NSThread alloc] initWithTarget:self selector:@selector(loadThread:
我目前正在尝试取消与我的数据模型中的对象关联的特定 UILocalNotifications。为此,每个数据对象都有一个唯一标识符,即 NSUUID。 创建 UILocalNotification:
当我提交并单击“确定”时,它会继续,但当我按“取消”时,它仍然会提交。我尝试使用此代码,但提交和取消按钮仍然执行相同的操作。 model.saveForm = function() { var
我有一个警报弹出窗口,当发生特定操作时会出现该弹出窗口。 5 秒后,使用 setTimeout() 隐藏警报弹出窗口。 我遇到的问题是,如果我多次触发弹出窗口,有时后续的弹出窗口会出现但立即消失。我相
我有一些 javascipt (jQuery),其中单击按钮时会淡入 #myDiv,然后使用超时函数在 5 秒后再次淡出。它工作正常,但如果用户在超时内的 fadeOut 函数运行之前再次单击该按钮,
我是一名优秀的程序员,十分优秀!