Элементы ListView не доступны для кликов. Зачем?

У меня есть ListView, который использует настраиваемый адаптер, но я не могу щелкнуть элемент ListView.

Активность для просмотра списка.

package com.adhamenaya.projects;

import java.util.ArrayList;

import android.app.Activity;
import android.content.Context;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.Filter;
import android.widget.Filterable;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

import com.adhamenaya.classes.Place;

public class PlacesListActivity extends Activity {
    private ArrayList<Place> places;
    private ArrayList<String> items;
    GridviewAdapter mAdapter;
    private ListView lvPlaces;
    private EfficientAdapter adap;
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.places_list);
        lvPlaces = (ListView) this.findViewById(R.id.lvPlaces);
        new DowanloadPlaces().execute("");
    }
    private void bindList(ArrayList<Place> places) {
        this.places = places;
        // Start creating the list view to show articles
        items = new ArrayList<String>();
        for (int i = 0; i < places.size(); i++) {
            items.add(String.valueOf(places.get(i).mName));
        }
        adap = new EfficientAdapter(this);
        adap.notifyDataSetChanged();
        lvPlaces.setAdapter(adap);
    }

    // EfficientAdapter : to make a customized list view item
    public class EfficientAdapter extends BaseAdapter implements Filterable {

        // The function of inflater to convert objects from XML layout file (i.e. main.xml) to a programmable 
        LayoutInflater inflater;
        Context context;

        public EfficientAdapter(Context context) {
            inflater = LayoutInflater.from(context);
            this.context = context;
        }

        public int getCount() {
            // Get the number of items in the list
            return items.size();
        }

        public Object getItem(int position) {
            // To return item from a list in the given position 
            return items.get(position);
        }

        public long getItemId(int position) {
            // TODO Auto-generated method stub
            return 0;
        }

        public View getView(final int position, View convertView,ViewGroup parent) {
            ViewHolder holder;
            if (convertView == null) {
                convertView = inflater.inflate(R.layout.adaptor_content, null);

                holder = new ViewHolder();// Create an object to hold at components in the list view item
                holder.textLine = (TextView) convertView.findViewById(R.id.textLine);
                holder.buttonLine = (Button) convertView.findViewById(R.id.buttonLine);
                holder.buttonLine.setOnClickListener(new OnClickListener() {
                    private int pos = position;

                    public void onClick(View v) {
                        places.remove(pos);
                        bindList(places);// to bind list items
                        Toast.makeText(getApplicationContext(),"Deleted successfuly :)", Toast.LENGTH_LONG).show();
                    }
                });
                convertView.setTag(holder);
            } else {
                holder = (ViewHolder) convertView.getTag();
            }
            // Bind the data efficiently with the holder.
            holder.textLine.setText(String.valueOf(places.get(position).mName));
            return convertView;
        }

        public Filter getFilter() {
            // TODO Auto-generated method stub
            return null;
        }

    }

    // ViewHolder : class that represents a list view items
    static class ViewHolder {
        TextView textLine;
        Button buttonLine;
    }

    // DownloadRSSFeedsTask: works in a separate thread
    private class DowanloadPlaces extends AsyncTask<String, Void, ArrayList<Place>> {

        @Override
        protected ArrayList<Place> doInBackground(String... params) {
            ArrayList<Place> places = new ArrayList<Place>();
            Place p = new Place();
            for(int i =0;i<25;i++){
                p.mName = "Al Mathaf Hotel";
                places.add(p);              
            }

            return places;
        }

        @Override
        protected void onPostExecute(ArrayList<Place> places) {
            bindList(places);


        }

    }


}

layout_list.xml макет

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <ListView 
        android:layout_width="match_parent" 
        android:layout_height="wrap_content"
        android:id="@+id/lvPlaces">

    </ListView>
</LinearLayout>

layout_content.xml

<ImageView
    android:id="@+id/imageView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignLeft="@+id/textLine"
    android:layout_centerVertical="true"
    android:src="@drawable/settings" />

</RelativeLayout>

Ответ 1

попробуйте сделать это, чтобы получить фокус:   View.getFocus();

Ответ 2

Android не позволяет выбирать элементы списка, которые имеют элементы с возможностью фокусировки (кнопки). Измените атрибут xml кнопки:

android:focusable="false"

Он должен по-прежнему быть кликабельным, просто не будет фокусироваться...

Ответ 3

У меня была такая же проблема с ListView, которая содержала только RadioButton:

<?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" >

<RadioButton
    android:id="@+id/userNameRadioButton"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

</LinearLayout>

Я использовал RadioButton в каждой строке для отображения выбора элемента по умолчанию, чтобы сделать клики с кликом ListView, которые я должен был использовать:

radioButton.setFocusableInTouchMode(false);
radioButton.setFocusable(false);

или в XML файле:

android:focusable="false" 
android:focusableInTouchMode="false"

Итак, это проблема, связанная с фокусом. С помощью указанных выше модификаторов фокус направлен на ListView при щелчке.

Ответ 4

Этот ответ здесь работал у меня: fooobar.com/questions/192837/...

В основном он добавил в LinearLayout или RelativeLayout следующее:

android:descendantFocusability="blocksDescendants"

Вам также необходимо УДАЛИТЬ из всего вашего xml следующее:

android:focusable="false"
android:focusable="true"
android:clickable="true"
android:clickable="false"

Ответ 5

Рассмотрите возможность выбора значения текста, указав андроид: textIsSelectable = "true"

Не слушайте Google. В макете строк установите

textIsSelectable="false"

Спасибо, Линт (нет!)

Ответ 6

Я хотел добавить комментарий к запросу rupps, но у меня недостаточно репутации.

Если вы используете настраиваемый адаптер, расширяющий ArrayAdapter, вы можете перезаписать с помощью isAllItemsEnabled() и isEnabled (int position) в своем классе:

@Override
public boolean areAllItemsEnabled() {
    return true;
}

@Override
public boolean isEnabled(int position) {
    return true;
}

Вышеупомянутый фиксированный мой просмотр без кликов. Возможно, этот комментарий также помогает другим, так как поисковый запрос "андроид не кликабельный" довольно высок в Google.

Ответ 7

Элементы просмотра списка можно щелкнуть. Чтобы использовать его, вы должны установить прослушиватель элемента списка в своем списке. Тогда это сработает.

Ответ 8

Я довольно поздно, но обнаружил, что я думаю, что это интересно об этом:

если ваш адаптер сходит с ArrayAdapter, сколько бы я ни пытался, onItemClickListener не вызывается.

Однако, если ваш адаптер сходит с BaseAdapter (поэтому вам нужно реализовать getCount() и getItem(), тривиально для массива), он всегда вызывается.

Ответ 9

Я использовал представление и кнопку внутри списка, поэтому я использовал:

android:focusable="false"

для <button> и <view>...

После этого я использовал следующий код для своего списка и работал

// Attach the adapter to a ListView
ListView listView = (ListView) findViewById(R.id.shipping_item_list);
listView.setAdapter(adapter);
listView.setOnItemClickListener(listPairedClickItem);

private AdapterView.OnItemClickListener listPairedClickItem = new AdapterView.OnItemClickListener() {
    @Override
    public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {

    Toast.makeText(getBaseContext(), "Item ", Toast.LENGTH_LONG).show();
    }
};

Ответ 10

Для меня проблема заключалась в том, что у моих элементов в моем ListView было clickable установлено значение true.

Ответ 11

набор андроид: кликабельны = "ложь" андроид: фокусируемый = "fasle"