Android Listview中Button按钮点击事件冲突解决办法

简介:

  今天做项目时,ListView中含有了Button组件,心里一早就知道肯定会有冲突,因为以前就遇到过,并解决过,可惜当时没有记录下来。 今天在做的时候,继续被这个问题郁闷了一把,后来解决后,赶紧来记录下,以便日后参考。

  

  首先,其实Listview中Button按钮点击事件冲突这种问题压根就不是太大的问题,因为我们完全可以将一个TextView的Backgroud设置成一个selector,也可以将一个TextView设计成一个按钮的样子,这样就可以绕过ListView和Button的冲突问题!

   

  当然,如果非要使用Button,那可以利用以下方案解决。

  首先,要了解的是,ListView和其它能触发点击事件的widget无法一起正常工作的原因是加入其它widget后,ListView的itemclick事件被其它widget的click事件屏蔽,所以将无法触发。

  如何做呢?

定义list_item_btn.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" >

    <ImageView
        android:id="@+id/avatar"
        android:layout_width="80dp"
        android:layout_height="80dp"
        android:src="@drawable/ic_launcher" />

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:padding="10dp" >

        <TextView
            android:id="@+id/title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="10dp"
            android:padding="6dp"
            android:text="玫瑰花园"
            android:textSize="16sp" />

        <Button
            android:id="@+id/btn"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_margin="2dp"
            android:focusable="false"
            android:padding="6dp"
            android:text="玫瑰花园"
            android:textSize="16sp" />
    </LinearLayout>

</LinearLayout>


注; Button的android:focusable必须设置为false,以免它抢了父控件(也就是每一个Item)的焦点。


接下来,我们定义一个Bean,Plan.java:

public class Plan {
	
	public String name;
	
	public String avatar;

	public Plan(String name, String avatar) {
		super();
		this.name = name;
		this.avatar = avatar;
	}

	@Override
	public String toString() {
		return "Plan [name=" + name + ", avatar=" + avatar + "]";
	}
	
}

实现ListView的Adapter,MyAdapter.java:

package com.wuyuan.listbtn;

import java.util.List;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.View.OnClickListener;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;

public class MyAdapter extends BaseAdapter {

	private Context mContext;

	private LayoutInflater mInflater;

	private List<Plan> mDatas;

	private OnClickListener onClickListener;

	public MyAdapter(Context context, List<Plan> datas,
			OnClickListener onClickListener) {
		mContext = context;
		mInflater = LayoutInflater.from(mContext);
		mDatas = datas;
		this.onClickListener = onClickListener;
	}

	@Override
	public int getCount() {
		return (mDatas != null ? mDatas.size() : 0);
	}

	@Override
	public Object getItem(int position) {
		return (mDatas != null ? mDatas.get(position) : null);
	}

	@Override
	public long getItemId(int position) {
		return position;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		ViewHolder holder = null;
		if (convertView == null) {

			// 下拉项布局
			convertView = mInflater.inflate(R.layout.list_item_btn, null);

			holder = new ViewHolder();

			holder.avatar = (ImageView) convertView.findViewById(R.id.avatar);
			holder.title = (TextView) convertView.findViewById(R.id.title);
			holder.btn = (Button) convertView.findViewById(R.id.btn);

			convertView.setTag(holder);

		} else {
			holder = (ViewHolder) convertView.getTag();
		}

		Plan plan = mDatas.get(position);

		if (plan != null) {

			holder.title.setText(plan.name);
			// 通常将position设置为tag,方便之后判断点击的button是哪一个
			holder.btn.setTag(position);
			holder.btn.setOnClickListener(this.onClickListener);
		}

		return convertView;
	}

	static class ViewHolder {

		ImageView avatar;

		TextView title;

		Button btn;
	}

}

注:

 1. 构造方法中,我们传入了OnClickListener,主要是为了让每一个Item的Button监听该事件.

 2. holder.btn.setOnClickListener(this.onClickListener); 为Button设置点击事件监听。

 3. 为Button设置tag,tag的值为position,这样可以方便获取该Button所在的List中的位置。


最后,设置列表及事件监听:

public class MainActivity extends Activity {

	private ListView list_view;
	private List<Plan> plans;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		list_view = (ListView) findViewById(R.id.list_view);

		plans = new ArrayList<Plan>();
		for (int i = 0; i < 10; i++) {
			plans.add(new Plan("无缘公子-宁帅" + i, ""));
		}

		MyAdapter mAdapter = new MyAdapter(this, plans,onClickListener);
		list_view.setAdapter(mAdapter);

		list_view.setOnItemClickListener(new OnItemClickHandler());
	}

	private class OnItemClickHandler implements OnItemClickListener {

		@Override
		public void onItemClick(AdapterView<?> parent, View view, int position,
				long id) {

			System.out.println(" position1 :" + position);
			System.out.println(" data1 :" + plans.get(position).toString());
		}

	}
	
	private OnClickListener onClickListener = new OnClickListener() {
		
		@Override
		public void onClick(View view) {
			Button btn = (Button) view;
			
			int pos = (Integer) btn.getTag();
			
			System.out.println(" position2 :" + pos);
			System.out.println(" data2 :" + plans.get(pos).toString());
		}
	};
}


源码下载地址(免费): http://download.csdn.net/detail/zuiwuyuan/9192201

相关文章
|
2月前
|
Android开发
Android中SurfaceView的双缓冲机制和普通View叠加问题解决办法
本文介绍了 Android 平台上的 SurfaceView,这是一种高效的图形渲染控件,尤其适用于视频播放、游戏和图形动画等场景。文章详细解释了其双缓冲机制,该机制通过前后缓冲区交换来减少图像闪烁,提升视觉体验。然而,SurfaceView 与普通 View 叠加时可能存在 Z-Order 不一致、同步问题及混合渲染难题。文中提供了使用 TextureView、调整 Z-Order 和创建自定义组合控件等多种解决方案。
140 9
|
5月前
|
XML IDE 开发工具
【Android UI】自定义带按钮的标题栏
【Android UI】自定义带按钮的标题栏
62 7
【Android UI】自定义带按钮的标题栏
|
4月前
|
测试技术 Android开发
Android中使用performClick触发点击事件
Android中使用performClick触发点击事件
|
5月前
|
API Android开发 开发者
`RecyclerView`是Android API 21引入的UI组件,用于替代ListView和GridView
【6月更文挑战第26天】`RecyclerView`是Android API 21引入的UI组件,用于替代ListView和GridView。它提供高效的数据视图复用,优化的布局管理,支持多种布局(如线性、网格),并解耦数据、适配器和视图。RecyclerView的灵活性、性能(如局部刷新和动画支持)和扩展性使其成为现代Android开发的首选,特别是在处理大规模数据集时。
66 2
|
5月前
|
Android开发
Android studio 出现Plugin [id: ‘com.android.application‘, version: ‘8.1.0‘, apply: false] 问题解决办法
Android studio 出现Plugin [id: ‘com.android.application‘, version: ‘8.1.0‘, apply: false] 问题解决办法
1369 1
|
5月前
|
安全 JavaScript 前端开发
kotlin开发安卓app,JetPack Compose框架,给webview新增一个按钮,点击刷新网页
在Kotlin中开发Android应用,使用Jetpack Compose框架时,可以通过添加一个按钮到TopAppBar来实现WebView页面的刷新功能。按钮位于右上角,点击后调用`webViewState?.reload()`来刷新网页内容。以下是代码摘要:
|
5月前
|
存储 Android开发
安卓app,MediaPlayer播放本地音频 | 按钮控制播放和停止
在Jetpack Compose中,不直接操作原生Android组件如`Button`和`MediaPlayer`,而是使用Compose UI构建器定义界面并结合ViewModel管理音频播放逻辑。以下示例展示如何播放本地音频并用按钮控制播放/停止:创建一个`AudioPlayerViewModel`管理`MediaPlayer`实例和播放状态,然后在Compose UI中使用`Button`根据`isPlaying`状态控制播放。记得在`MainActivity`设置Compose UI,并处理相关依赖和权限。
|
5月前
|
Android开发 Windows
android studio开发时提示 TLS 握手错误解决办法
在Windows环境下遇到TLS协议版本不支持的错误,Gradle构建失败。解决方案是在build.gradle.kts中设置系统属性`https.protocols`为`TLSv1.2`,而非遵循误导信息设置为TLSv1.1。
|
5月前
|
前端开发 API Android开发
25. 【Android教程】列表控件 ListView
25. 【Android教程】列表控件 ListView
178 2
|
5月前
|
XML Java Android开发
15. 【Android教程】按钮 Button/ImageButton
15. 【Android教程】按钮 Button/ImageButton
78 2