带按钮Listview适配器

本文介绍的工程实现的功能是:按下列表项提示“您点击了第x个列表项,内容为:第x个列表项”,按下列表项中的按钮,在日子面板打印“您点击了第x个按钮第x个列表项”。

许多自定义适配器都继承BaseAdapter,但对于列表项带有按钮的列表并不是最佳选择,本文介绍的便是关于列表项带有按钮的列表适配器(继承了SimpleAdapter)。

界面如下图

先从布局来看,这个界面是用两个xml文件组成,一个较为简单,就是一个ListView

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <ListView
        android:id="@+id/listView1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >
    </ListView>

</RelativeLayout>

另一个是ListView的列表项items,里面包括提示列表项的文本框TextView(如界面中的0、1、2等),提示第几个列表项的文本框TextView(如界面中的第1个列表项、第2个列表项等),还有一个是按钮,代码如下

<?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"
    android:descendantFocusability="blocksDescendants"
    android:gravity="center_vertical" >

    <TextView
        android:id="@+id/textView1"
        android:layout_width="0.0dip"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="TextView" />

        <TextView
        android:id="@+id/textView2"
        android:layout_width="0.0dip"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="TextView" />

    <Button
        android:id="@+id/button1"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Button"
        android:focusable="false" />

</LinearLayout>

在items中的布局中应该注意两个地方,一个是父布局中的android:descendantFocusability="blocksDescendants",另一个是Button按钮中的android:focusable="false",如果你希望你的列表项可点击,按钮又可点击就需要添加这两句。

android:descendantFocusability属性是用于表示获取焦点的顺序,其属性值有三个,分别是beforeDescendants优先于其子类控件而获取焦点;afterDescendants只有当其子类控件不需要焦点时才获得焦点;blocksDescendants覆盖子类直接获得焦点。此部分内容可参考链接点击打开链接。android:focusable是表示是否获取焦点,它有两个属性值,一个是ture,表示获取焦点;而是false,不获取焦点。

接着我们来看看自定义的适配器,直接上代码

package com.sifei.lwj;

import java.util.List;
import java.util.Map;

import android.content.Context;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.SimpleAdapter;
import android.widget.TextView;

public class MyAdapter extends SimpleAdapter {

	public MyAdapter(Context context, List<? extends Map<String, ?>> data,
			int resource, String[] from, int[] to) {
		super(context, data, resource, from, to);
		// TODO Auto-generated constructor stub
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		// TODO Auto-generated method stub

		View v = super.getView(position, convertView, parent);				// 获取索引

		final TextView text = (TextView)v.findViewById(R.id.textView2);			// 定义一个文本框并关联其ID
		text.setTag(position);								// 以position作为索引,这样就能具体定位到某个列表项文本框

		Button btn = (Button)v.findViewById(R.id.button1);				// 定义一个文本框并关联其ID
		btn.setTag(position);								// 以position作为索引,这样就能具体定位到是哪个列表项按钮
		btn.setOnClickListener(new OnClickListener() {					// 添加事件监听器

			public void onClick(View v) {
				// TODO Auto-generated method stub
				Log.i("Tag", "您点击了第"+v.getTag()+"个按钮"+text.getText());
			}
		});

		return v;
	}
}

构造方法与SimpleAdapter是一样的,主要看getView方法。主要步骤:

1、获取列表项索引;

2、定义对应的控件并关联ID;

3、设置控件的索引;

4、操作控件。

用setTag来设置索引,getTag获取索引。

在使用此自定义的适配器时与普通适配器相同

package com.sifei.lwj;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.os.Bundle;
import android.app.Activity;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.Toast;

public class MainActivity extends Activity {

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

		ListView list = (ListView)findViewById(R.id.listView1);

		List<Map<String, Object>> items = new ArrayList<Map<String,Object>>();

		for(int i=0; i<20; i++){
			Map<String, Object> map = new HashMap<String, Object>();
			map.put("i", i);
			map.put("name", "第"+i+"个列表项");
			items.add(map);
		}

		final MyAdapter adapter = new MyAdapter(MainActivity.this, items,
				R.layout.items, new String[]{"i","name"}, new int[]{R.id.textView1,R.id.textView2});
		list.setAdapter(adapter);	

		list.setOnItemClickListener(new OnItemClickListener() {
			public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
					long arg3) {
				adapter.getView(arg2, arg1, arg0);
				@SuppressWarnings("unchecked")
				Map<String, Object> map = (HashMap<String, Object>)arg0.getItemAtPosition(arg2);
				Toast.makeText(MainActivity.this, "您点击了第"+map.get("i").toString()+"个列表项,内容为:"+map.get("name"), Toast.LENGTH_LONG).show();
			}
		});
	}
}

类似的文章点击打开链接

带按钮Listview适配器

时间: 2024-10-07 10:22:22

带按钮Listview适配器的相关文章

android之ListView,详细介绍实现步骤,举例,自定义listview适配器

android之ListView,详细介绍实现步骤,举例,自定义listview适配器 09. 四 / android基础 / 没有评论 本文来源于www.ifyao.com禁止转载!www.ifyao.com android中如何使用listView是比较重要的,因为很多时候都需要将数据库中的数据以列表显示, 具体使用步骤:大体 1,建立一个item.xml文件,此布局文件布局布局如何具体显示列表中的每一个条目 2,在要使用listview的界面中添加listview控件. 3,activit

最新一课 老师指点用Listview适配器

上课前 <?xml version="1.0" encoding="utf-8"?>    <ScrollView xmlns:android="http://schemas.android.com/apk/res/android"       android:layout_width="fill_parent"       android:layout_height="fill_parent&qu

js制作带按钮的循环自动切换广告

-----------------------------------------------------------------------------------------------------------------css @charset "gb2312";/* CSS Document */ body{ margin:0; margin-top:3px; padding:0; font-size:12px; line-height:20px; color:#333;}.a

android 自定义带按钮的Notification及点击事件和伸缩通知栏

1.自定义一个带按钮的Notification布局:layout_notification: 2.创建Notification: RemoteViews views = new RemoteViews(getPackageName(),R.layout.layout_nitification); //自定义的布局视图 //按钮点击事件: PendingIntent homeIntent = PengdingIntent.getBroadcast(this,1,new Intent("action

jquery带按钮的图片切换效果

<!doctype html> <html> <head> <meta charset="gb2312"> <title>jquery带按钮的图片切换效果</title> <script type="text/javascript" src="jquery-1.8.0.js"></script> <style type="text/cs

结合子类父类和LIstView适配器相关设置,初步体验类的多态。

在初级阶段,我们常对listview的适配器都是在一个activity类中全部写满.当你接触项目多了,你会发现大神都把各种适配器放一个包里,要用直接传如相关参数到适配器的构造方法设置ListView.今天做了个简单的demo,对于菜鸟理解多态有帮助.在MainActivity中代码如下 public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState)

Android开发之适配器-ListView适配器的重复数据

适配器是Android中的数据与View视图的桥梁,作用就是将数据通过适配器显示到对应的View视图上. 工作中,在用ListView做适配器数据时候,有些人肯定碰见过,如何优化效率,但是又出现重复数据的情况,如何避免重复数据而且又能提高ListView大数据量时候的效率呢?,解决方案就是2点: 1. 在getView方法中 进行View的判断,即做convertView ==null 这样的判断,这样是为了提高数据量大的时候的效率. 2.设置数据用setTag()/getTag()方法来进行对

SWIFT推送之本地推送(UILocalNotification)之二带按钮的消息

上一篇讲到的本地推送是普通的消息推送,本篇要讲一下带按钮动作的推送消息,先上个图瞅瞅: 继上一篇的内容进行小小的改动: 在didFinishLaunchingWithOptions方法内进行以下修改 if (UIDevice.currentDevice().systemVersion as NSString).floatValue >= 8 { // APService.registerForRemoteNotificationTypes( // UIUserNotificationType.B

jquery 文字滚动大全 scroll 支持文字或图片 单行滚动 多行滚动 带按钮控制滚动

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-