解决关于给RecyclerView设置了条目点击事件后,导致点击条目时部分有效果的问题

RecyclerView设置的布局如下:

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

    <TextView
        android:id="@+id/tv_url"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:inputType="text"
        android:paddingRight="30dp"
        android:textSize="15sp"
        tools:text="Test" />
</RelativeLayout>

效果图如下:

代码编译运行到机器上,发现点击条目时,只有空白的地方有点击效果,而点击“Text”文本没有触发条目点击效果。

经过调试,发现只要把布局文件中TextView的如下设置去掉即可:

android:inputType="text"

官方是这样说明的:

Attribute android:inputType should not be used with <TextView>: Change element type to <EditText> ? less... (Ctrl+F1)

Using a <TextView> to input text is generally an error, you should be using <EditText> instead. EditText is a subclass of TextView, and some of the editing support is provided by TextView, so it's possible to set some input-related properties on a TextView. However, using a TextView along with input attributes is usually a cut & paste error. To input text you should be using <EditText>.

This check also checks subclasses of TextView, such as Button and CheckBox, since these have the same issue: they should not be used with editable attributes.

Issue id: TextViewEdits

结合以上说明,android:inputType的属性只对EditText有效,我认为EditText本身有抢夺焦点的作用,给TextView设置android:inputType的属性后可能也会导致焦点抢夺,导致点击“Text”文本并不会触发条目点击事件,而是被自身消耗掉了。

这里,要感谢下我的朋友margintop,他后来发现:如果已经设置了android:inputType的属性,再设置两个属性android:clickable和android:longClickable,这两个属性都设置成false,也可以达到预期的效果。也就是说android:inputType改变了那两个属性的默认值,把false改成了true。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,让我来为你详细介绍一下如何使用Kotlin在安卓应用中编写一个带有多条目RecyclerView,并且可以根据条目的不同点击跳转到不同的Activity。 首先,我们需要在项目的Gradle文件中添加RecyclerView的依赖项: ``` implementation 'androidx.recyclerview:recyclerview:1.2.1' ``` 接下来,我们创建一个名为`MyAdapter`的Kotlin类,并继承`RecyclerView.Adapter`。在类中,我们需要定义一个内部类`ViewHolder`,该类继承自`RecyclerView.ViewHolder`。在`ViewHolder`类中,我们需要定义多个`View`的成员变量,用于显示列表项的不同信息,并且可以设置点击事件。 ``` class MyAdapter(private val data: List<MyData>) : RecyclerView.Adapter<RecyclerView.ViewHolder>() { companion object { const val TYPE_ONE = 1 const val TYPE_TWO = 2 } override fun getItemViewType(position: Int): Int { return data[position].type } override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder { return when (viewType) { TYPE_ONE -> { val view = LayoutInflater.from(parent.context).inflate(R.layout.list_item_one, parent, false) ViewHolderOne(view) } else -> { val view = LayoutInflater.from(parent.context).inflate(R.layout.list_item_two, parent, false) ViewHolderTwo(view) } } } override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) { when (holder.itemViewType) { TYPE_ONE -> { val viewHolderOne = holder as ViewHolderOne viewHolderOne.textViewOne.text = data[position].textOne viewHolderOne.itemView.setOnClickListener { val intent = Intent(holder.itemView.context, ActivityOne::class.java) holder.itemView.context.startActivity(intent) } } else -> { val viewHolderTwo = holder as ViewHolderTwo viewHolderTwo.textViewTwo.text = data[position].textTwo viewHolderTwo.itemView.setOnClickListener { val intent = Intent(holder.itemView.context, ActivityTwo::class.java) holder.itemView.context.startActivity(intent) } } } } override fun getItemCount(): Int { return data.size } class ViewHolderOne(view: View) : RecyclerView.ViewHolder(view) { val textViewOne: TextView = view.findViewById(R.id.text_view_one) } class ViewHolderTwo(view: View) : RecyclerView.ViewHolder(view) { val textViewTwo: TextView = view.findViewById(R.id.text_view_two) } } ``` 在`MyAdapter`类中,我们需要实现四个方法:`getItemViewType`、`onCreateViewHolder`、`onBindViewHolder`和`getItemCount`。这些方法分别用于返回当前位置的数据类型、创建新的ViewHolder、绑定数据到ViewHolder和返回列表项的数量。 在`getItemViewType`方法中,我们需要根据当前位置的数据类型返回对应的条目类型。 在`onCreateViewHolder`方法中,我们需要创建一个新的ViewHolder,并为其绑定对应条目类型的布局文件。 在`onBindViewHolder`方法中,我们需要根据当前位置的数据类型获取对应的ViewHolder并将数据绑定到ViewHolder的对应View中,并且可以设置View的点击事件,在点击事件中跳转到对应的Activity。 在`getItemCount`方法中,我们需要返回列表项的数量。 最后,在Fragment中,我们可以使用以下代码来设置RecyclerView的布局和适配器: ``` recyclerView.layoutManager = LinearLayoutManager(activity) recyclerView.adapter = MyAdapter(data) ``` 其中,`data`是一个包含多种数据类型的List,包含了我们想要显示的列表项数据。 这样,我们就成功地使用Kotlin编写了一个带有多条目RecyclerView,并且可以根据条目的不同点击跳转到不同的Activity。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值