Android listview中item部分区域添加点击事件

需求如题目:Android listview中item部分区域添加点击事件,在一个界面显示了listview,但显示的内容分为上下两部分,分别是白色的背景和蓝色的背景,现在需要只点击蓝色的背景,才能跳转到其他界面,解决方式如下:

   一开始想着是不是能在list item的布局给上层布局添加一个:      

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

          就是禁止点击,但试了试没有效果,后来师傅提醒我,我的这个listview使用的适配器是BaseAdapter可以在适配器里面拿到下层蓝色的Relativelayout的id,然后给这个布局添加点击事件,就可以实现部分区域响应事件,事实证明是非常可行的,贴出主要的代码如下:

	// 开仓单适配器
	public class OrderAdapter extends BaseAdapter {
		public OrderAdapter(Context myContext) {
		}

		public OrderAdapter(OrderFragment orderFragment) {
		}

		@Override
		public int getCount() {
			if (dataMap == null) {
				return orderVec.length;
			}
			return dataMap.size();
		}

		@Override
		public Object getItem(int position) {
			return position;
		}

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

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			ViewHolder viewHolder = null;
			if (convertView == null) {
				viewHolder = new ViewHolder();
				<span style="font-size:24px;color:#ff0000;"><strong>convertView = getActivity().getLayoutInflater().inflate(
						R.layout.activity_order_item, null);

				initViewHolder(convertView, viewHolder, position);</strong></span>
//关键代码,获得下层蓝色的布局的id
			} else {
				viewHolder = (ViewHolder) convertView.getTag();
			}

			refreshViewHolder(position, viewHolder);

			return convertView;
		}

		private void refreshViewHolder(int position, ViewHolder viewHolder) {
			。。。。。。。。
		}

		private void initViewHolder(View convertView, ViewHolder viewHolder,
				final int position) {
		

			<span style="font-size:18px;color:#ff0000;"><strong>viewHolder.modeifyorder = (RelativeLayout) convertView
					.findViewById(R.id.modeifyorder);
			viewHolder.modeifyorder.setOnClickListener(new OnClickListener() {
</strong></span>
				@Override
				public void onClick(View v) {
					Map<String, Object> map = dataMap.get(position);
					long orderId = Long.parseLong(map.get(Orderid).toString());
					String instStr = map.get(Instrument).toString();
					DocCaptain.getInstance().setOrderTrade2Modify(instStr,
							orderId);

					getSelfActivity().showOrHideOrderTradeFragment();
				}
			});

			convertView.setTag(viewHolder);
		}

		private class ViewHolder {
			TextView orderid;
			TextView iFDStopPrice;

			<span style="font-size:18px;color:#ff0000;"><strong>RelativeLayout modeifyorder;
</strong></span>
		}
	}

    成功完成,记录一下。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 当使用ListView时,可以定义一个布局文件作为每个列表项的外观。以下是一个简单的例子: 首先,创建一个名为 `list_item.xml` 的新布局文件,它将包含一个ImageView和两个TextView。布局如下: ```xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="10dp"> <ImageView android:id="@+id/item_icon" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/ic_launcher"/> <LinearLayout android:orientation="vertical" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" android:layout_marginStart="10dp"> <TextView android:id="@+id/item_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Item Title"/> <TextView android:id="@+id/item_description" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Item Description"/> </LinearLayout> </LinearLayout> ``` 在这个布局文件,我们定义了一个水平方向的LinearLayout,它包含一个ImageView和一个竖直方向的LinearLayout。竖直方向的LinearLayout包含两个TextView,分别用于显示标题和描述。我们还将LinearLayout的权重设置为1,这将使标题和描述填满空白区域。 接下来,将该布局文件用作ListView的每个列表项的布局。在ListView的适配器,可以通过以下方式使用该布局文件: ```java public class MyAdapter extends BaseAdapter { private List<Item> mItems; private Context mContext; public MyAdapter(Context context, List<Item> items) { mContext = context; mItems = items; } @Override public int getCount() { return mItems.size(); } @Override public Object getItem(int position) { return mItems.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; if (view == null) { LayoutInflater inflater = LayoutInflater.from(mContext); view = inflater.inflate(R.layout.list_item, parent, false); } Item item = mItems.get(position); ImageView icon = (ImageView) view.findViewById(R.id.item_icon); icon.setImageResource(item.getIcon()); TextView title = (TextView) view.findViewById(R.id.item_title); title.setText(item.getTitle()); TextView description = (TextView) view.findViewById(R.id.item_description); description.setText(item.getDescription()); return view; } } ``` 在适配器的getView()方法,我们获取要在该位置显示的Item对象,然后使用该对象的数据填充视图的ImageView和TextView。如果convertView为空,则使用LayoutInflater将列表项的布局文件转换为View对象。最后,返回填充数据的视图。 ### 回答2: 当然,我可以给您提供一个Android ListView的布局例子。 首先,在您的布局文件,您需要添加一个ListView组件。例如,您可以在XML文件添加以下代码: ```xml <ListView android:id="@+id/listview" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` 接下来,在您的Activity或Fragment,您需要引用这个ListView,并为其设置适配器,以便显示数据。以下是一个简单的例子: ```java ListView listView = findViewById(R.id.listview); ArrayList<String> dataList = new ArrayList<>(); // 假设您有一个String数组作为数据源 String[] data = {"Apple", "Banana", "Cherry", "Durian", "Elderberry"}; // 将数据源添加到ArrayList Collections.addAll(dataList, data); // 创建适配器,并将数据源传递给它 ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, dataList); // 将适配器设置给ListView listView.setAdapter(adapter); ``` 以上例子,我们使用了Android提供的简单列表项布局(android.R.layout.simple_list_item_1)作为ListView的每个项的布局。 最后,在您的Activity或Fragment,您可以为ListView设置一个点击事件监听器,以响应用户对列表项的点击。例如,您可以使用以下代码: ```java listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { // 在这里处理用户点击列表项的逻辑 Toast.makeText(MainActivity.this, "You clicked " + dataList.get(position), Toast.LENGTH_SHORT).show(); } }); ``` 这个例子展示了如何创建一个简单的Android ListView布局,并为其设置适配器和点击事件监听器。您可以根据自己的需求,对ListView进行更多的自定义和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值