Позиция строки в ListView, которая выбрана checkBox

44
3

У меня есть listView, где каждая строка состоит из checkbox, TextView и Button. Кнопка установлена в GONE. Когда пользователь выбирает текстовое поле, я хочу, чтобы кнопка стала видимой. Затем пользователь щелкнет эту кнопку, чтобы удалить строку.

Я реализовал прослушиватель checkbox, который работает, но то, что я не могу решить, - это убедиться, что соответствующий deleteButton стал видимым. С моим текущим кодом случайная кнопка становится видимой.

Что мне делать? Точка к учебнику или фрагменту кода была бы очень полезна.

public class DeleteCampaignCustomCursorAdapater extends CursorAdapter {

protected static final String TAG = null;
DatabaseHelper myDbHelper;
protected SQLiteDatabase db;

private final LayoutInflater mInflater;
protected ListView mListView;

TextView merchantNameView;
Button deleteButton;
CheckBox selectForDelete;
//ImageView moveButton;

public DeleteCampaignCustomCursorAdapater(Context context, Cursor c) {
super(context, c);
mInflater = LayoutInflater.from(context);
}

@Override
public void bindView(View view, Context context, final Cursor cursor) {

myDbHelper = new DatabaseHelper(context); //Links to DatabaseHelper class

merchantNameView = (TextView) view.findViewById(R.id.deleteMerchantNameView);
deleteButton = (Button) view.findViewById(R.id.deleteButton);
selectForDelete = (CheckBox) view.findViewById(R.id.deleteCheckBox);
//moveButton = (ImageView) view.findViewById(R.id.moveButton);

merchantNameView.setText(cursor.getString(cursor.getColumnIndex("merchantName")));

final int rowID = cursor.getInt(cursor.getColumnIndex("_id"));
//final long rowID = mListView.getSelectedItemId();

selectForDelete.setOnCheckedChangeListener(new OnCheckedChangeListener()
{
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked)
{
if ( isChecked )
{
// perform logic
deleteButton.setVisibility(0);
}
else {
deleteButton.setVisibility(8);
}
}
});

//deleteButton.setOnClickListener(new DeleteEntryOnClicklistener(itemID));
deleteButton.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {

if(rowID > 0) {
//Log.d(TAG, "Button Click. rowID = "+rowID);

myDbHelper.deleteRecordWithID(rowID);
cursor.requery();
notifyDataSetChanged();
}
}
});
}

@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
return mInflater.inflate(R.layout.delete_campaign_row_layout, null);
}

}

РЕДАКТИРОВАТЬ

Мой новый код с советом Барака. Первая версия работала, но как только строка была удалена, строка под ней будет проверена после обновления представления. Теперь я получаю cursorOutOfBoundsException в моем getView().

public class DeleteCampaignCustomCursorAdapater extends CursorAdapter {

protected static final String TAG = null;
DatabaseHelper myDbHelper;
protected SQLiteDatabase db;
private final Activity context;

private LayoutInflater mInflater;
protected ListView mListView;

private static Cursor c;
public static int[] checked;

TextView merchantNameView;
Button deleteButton;
CheckBox selectForDelete;
//ImageView moveButton;

public DeleteCampaignCustomCursorAdapater(Context context, Cursor c) {
super(context, c);
this.context = (Activity) context;
mInflater = LayoutInflater.from(context);
DeleteCampaignCustomCursorAdapater.c = c;
initializeChecked();
}

@Override
public void bindView(View view, Context context, final Cursor cursor) {

/*myDbHelper = new DatabaseHelper(context); //Links to DatabaseHelper class

merchantNameView = (TextView) view.findViewById(R.id.deleteMerchantNameView);
deleteButton = (Button) view.findViewById(R.id.deleteButton);
//selectForDelete = (CheckBox) view.findViewById(R.id.deleteCheckBox);
//moveButton = (ImageView) view.findViewById(R.id.moveButton);

merchantNameView.setText(cursor.getString(cursor.getColumnIndex("merchantName")));

final int rowID = cursor.getInt(cursor.getColumnIndex("_id"));
//final long rowID = mListView.getSelectedItemId();

if (checked[rowID] == 0) {
selectForDelete.setChecked(false);
} else {
selectForDelete.setChecked(true);
}

selectForDelete.setOnCheckedChangeListener(new OnCheckedChangeListener()
{
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked)
{
if ( isChecked )
{
// Make deleteButton appear
RelativeLayout ll = (RelativeLayout) buttonView.getParent();
deleteButton = (Button) ll.findViewById(R.id.deleteButton);
checked[rowID] = 1;
deleteButton.setVisibility(0);
}
else {
//Hide deleteButton
RelativeLayout ll = (RelativeLayout) buttonView.getParent();
deleteButton = (Button) ll.findViewById(R.id.deleteButton);
checked[rowID] = 1;
deleteButton.setVisibility(8);
}
}
});

deleteButton.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {

if(rowID > 0) {
//Log.d(TAG, "Button Click. rowID = "+rowID);

myDbHelper.deleteRecordWithID(rowID);
cursor.requery();
notifyDataSetChanged();
initializeChecked(); // re-set the checked array
}
}
}); */
}

@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
return mInflater.inflate(R.layout.delete_campaign_row_layout, null);
}

@Override
public View getView(final int position, View convertView, ViewGroup parent) {

myDbHelper = new DatabaseHelper(context); //Links to DatabaseHelper class

if (convertView == null) {
mInflater = context.getLayoutInflater();
convertView = mInflater.inflate(R.layout.delete_campaign_row_layout, null);
}

merchantNameView = (TextView) convertView.findViewById(R.id.deleteMerchantNameView);
deleteButton = (Button) convertView.findViewById(R.id.deleteButton);
selectForDelete = (CheckBox) convertView.findViewById(R.id.deleteCheckBox);

merchantNameView.setText(c.getString(c.getColumnIndex("merchantName")));

final int rowID = c.getInt(c.getColumnIndex("_id"));
//final long rowID = mListView.getSelectedItemId();

if (checked[position] == 0) {
selectForDelete.setChecked(false);
} else {
selectForDelete.setChecked(true);
}

selectForDelete.setOnCheckedChangeListener(new OnCheckedChangeListener()
{
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked)
{
if ( isChecked )
{
// Make deleteButton appear
RelativeLayout ll = (RelativeLayout) buttonView.getParent();
deleteButton = (Button) ll.findViewById(R.id.deleteButton);
checked[position] = 1;
deleteButton.setVisibility(0);
}
else {
//Hide deleteButton
RelativeLayout ll = (RelativeLayout) buttonView.getParent();
deleteButton = (Button) ll.findViewById(R.id.deleteButton);
checked[position] = 1;
deleteButton.setVisibility(8);
}
}
});

deleteButton.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {

if(rowID > 0) {
//Log.d(TAG, "Button Click. rowID = "+rowID);

myDbHelper.deleteRecordWithID(rowID);
c.requery();
notifyDataSetChanged();
initializeChecked(); // re-set the checked array
}
}
});

return convertView;
}

public static void initializeChecked() {
checked = new int[c.getCount()];
int i = 0;
while (i < c.getCount()) {
checked[i] = 0;
i++;
}
}

}

спросил(а) 2012-05-10T14:14:00+04:00 7 лет, 7 месяцев назад
2
Решение
44

Вы можете сделать это:

selectForDelete.setOnCheckedChangeListener(new OnCheckedChangeListener()
{
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked)
{
if ( isChecked )
{
// perform logic
LinearLayout ll = (LinearLayout) buttonView.getparent();
Button b = (Button) ll.findViewById(R.id.deleteButton)
b.setVisibility(0);
}
else {
LinearLayout ll = (LinearLayout) buttonView.getparent();
Button b = (Button) ll.findViewById(R.id.deleteButton)
b.setVisibility(8);
}
}
});

Вы проверили этот флажок, чтобы узнать строку, получить родительский флажок (который должен быть LinearLayout строки), затем получить идентификатор кнопки для этой строки и использовать это, чтобы установить видимость кнопки удаления для этой конкретной строка/вид.

Надеюсь это поможет.

РЕДАКТИРОВАТЬ

Чтобы устранить проблемы при удалении, вам нужно сделать что-то вроде следующего.

В пользовательском адаптере задайте массив:

private Cursor c;
public static int[] checked;

В вашем конструкторе установите курсор на локальный var и вызовите метод:

CursorAdapter_EditText.c = c;
initializeChecked();

Метод:

public static void initializeChecked() {
checked = new int[c.getCount()];
int i = 0;
while (i < c.getCount()) {
checked[i] = 0;
i++;
}
}

В вашей привязке перестройте и добавьте пару строк:

final int  rowID = cursor.getInt(cursor.getColumnIndex("_id"));
selectForDelete = (CheckBox) view.findViewById(R.id.deleteCheckBox);
if (checked(rowID) == 0) {
selectForDelete.setChecked(false);
} else {
selectForDelete.setChecked(true);
}

Затем измените мой первоначальный ответ onCheckedChanged следующим образом:

selectForDelete.setOnCheckedChangeListener(new OnCheckedChangeListener()
{
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked)
{
if ( isChecked )
{
// perform logic
LinearLayout ll = (LinearLayout) buttonView.getparent();
Button b = (Button) ll.findViewById(R.id.deleteButton);
checked[posSelected] = 1;
b.setVisibility(0);
}
else {
LinearLayout ll = (LinearLayout) buttonView.getparent();
Button b = (Button) ll.findViewById(R.id.deleteButton);
checked[posSelected] = 1;
b.setVisibility(8);
}
}
});

Наконец, в вашем прослушивателе кнопки удаления:

deleteButton.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {

if(rowID > 0) {
//Log.d(TAG, "Button Click. rowID = "+rowID);

myDbHelper.deleteRecordWithID(rowID);
cursor.requery();
notifyDataSetChanged();
initializeChecked(); // re-set the checked array
}
}
});

ответил(а) 2012-05-10T15:28:00+04:00 7 лет, 7 месяцев назад
Еще 1 ответ
34

проверьте, что вам нужно сделать, - вам нужно сохранить состояние ваших кнопок в arraylist, а затем отображать свои кнопки от этого arraylist вместо того, чтобы прямо устанавливать его как видимое, если вы не можете понять код по ссылке, тогда я попытаюсь написать код для вас дайте мне знать, что вы понимаете или нет...

Как реализовать кнопку, которая получает все состояние флажка и добавляет значение проверенного элемента в arraylist?

Я не знаю точно, но он должен работать, если проблема аналогична.

ответил(а) 2012-05-10T15:03:00+04:00 7 лет, 7 месяцев назад
Ваш ответ
Введите минимум 50 символов
Чтобы , пожалуйста,
Выберите тему жалобы:

Другая проблема