ListView с интерактивным/редактируемым виджетами

Можно ли использовать OnItemClickListener в ListView, когда макет Items имеет интерактивный/редактируемый виджет (RadioButton, EditText или CheckBox)?

Ответ 1

Возможно, вы захотите взглянуть на эту проблему. Наличие фокусируемого элемента в строке ListView вызывает вызов OnItemClickListener NOT. Однако это не означает, что вы не можете иметь объекты с возможностью фокусировки/клики в строке, есть некоторые обходные пути, например этот.

Кроме того, вы можете посмотреть экран "Журналы вызовов". Он имеет ListView с кликабельным элементом (значок вызова справа). См. здесь исходный код

Ответ 2

Цитата № 31 в ссылке, упомянутой Самухом (которая решила проблему для меня):

Фактически вы можете добавить его в макет XML (если он завышен одним): android: descendantFocusability = "blocksDescendants".

Добавление здесь JIC, что веб-страница не работает в будущем.

Ответ 3

Если какой-либо элемент строки списка содержит фокусируемое или интерактивное представление, то OnItemClickListener не будет работать.

элемент строки должен иметь параметр как android:descendantFocusability="blocksDescendants"

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:baselineAligned="false"
    android:descendantFocusability="blocksDescendants"
    android:gravity="center_vertical" >

    // your other widgets here

</LinearLayout>

Ответ 4

Пробовал много сложных решений, но это был самый простой из них:

Android: фокусируемый = "ложь"

<CheckBox
    android:id="@+id/fav_check_box"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:focusable="false" />

Ответ 5

Два лучших решения

  • Добавить android:descendantFocusability="beforeDescendants" в listView в xml ИЛИ
  • Задайте два атрибута для false

как

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

Затем он обработает события child (Button, EditText и т.д.) listView вместо ListView.setOnItemClick.

Ответ 6

Я исправил свою проблему по-другому, в моем элементе у меня есть несколько LinearLayout так что если вы дадите id вашему линейному выходу и setOnclickListener в классе адаптера, он будет работать, только оригинальный эффект касания исчезнет. но эта ссылка Сделать действие LinearLayout, как кнопка, полезно сделать, чтобы функция linearlaout действовала как кнопка при нажатии

элемент

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_marginTop="10dp">

    <TextView
        android:id="@+id/txt_item_followers_name"
        android:layout_width="250dp"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:gravity="center|start"
        android:paddingLeft="15dp"
        android:text="Ali"
        android:textAppearance="?android:attr/textAppearanceMedium" />

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="35dp"
        android:layout_height="35dp"
        android:layout_alignParentStart="true"
        android:layout_below="@+id/txt_item_followers_name"
        android:layout_marginLeft="10dp"
        android:src="@drawable/puan_icon" />

    <TextView
        android:id="@+id/txt_item_followers_mark"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@+id/imageView"
        android:layout_toEndOf="@+id/imageView"
        android:background="@color/red_400"
        android:paddingLeft="10dp"
        android:text="25.5"
        android:textAppearance="?android:attr/textAppearanceSmall" />

    <LinearLayout
        android:id="@+id/linear_one"
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:layout_alignParentTop="true"
        android:layout_toEndOf="@+id/txt_item_followers_name"
        android:background="@color/red_400"
        android:orientation="vertical">

        <ImageView
            android:id="@+id/btn_item_followers_2b_follow"
            android:layout_width="100dp"
            android:layout_height="match_parent"
            android:layout_alignParentEnd="true"
            android:layout_marginLeft="10dp"
            android:src="@drawable/follow_buton" />
    </LinearLayout>


</RelativeLayout>

внутри метода getView

 @Override
    public View getView(final int position, View convertView,
                        ViewGroup parent) {
        View view = convertView;
        if (convertView == null)
            view = inflater.inflate(R.layout.deneme, null);

        final Followers2 myObj = myList.get(position);
        LinearLayout linear_one = (LinearLayout) view.findViewById(R.id.linear_one); // HERE WE DOMUNİCATE IT
        linear_one.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Toast.makeText(parentActivity, "One Two", Toast.LENGTH_SHORT).show();
            }
        });

        TextView name = (TextView) view.findViewById(R.id.txt_item_followers_name);
        TextView mark = (TextView) view.findViewById(R.id.txt_item_followers_mark);
        final ImageView btn_follow = (ImageView) view.findViewById(R.id.btn_item_followers_2b_follow);
        name.setText(myObj.getName());
        mark.setText(myObj.getScore());
       /* if (myObj.isFollow() == true) {
            btn_follow.setImageResource(R.drawable.following_buton);
        } else {
            btn_follow.setImageResource(R.drawable.follow_buton);
        }

        btn_follow.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Followers2 myObj = myList.get(position);
                if (myObj.isFollow() == true) {
                    btn_follow.setImageResource(R.drawable.following_buton);
                } else {
                    btn_follow.setImageResource(R.drawable.follow_buton);
                }
            }
        });*/

        return view;
    }