Android的UI组件之ListView(三)

原创 2012年08月08日 18:12:15

还是接着上篇。

三.通过继承BaseAdapter来ListView的每个Item中显示一个组合控件

其实第三种方法和上篇中的应该归到一类,只不过方法不同,姑且算上一种吧。这篇文章参考的是http://blog.csdn.net/hellogv/的一篇文章。

UI界面XMl代码如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    
     >
	<ListView 
	    android:id="@+id/myList"
	    android:layout_width="wrap_content"
	    android:layout_height="wrap_content"
	    >	    
	</ListView>
</LinearLayout>
list.xml代码如下:

<?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"
   
     >

    <ImageView 
        android:id="@+id/image"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        />
	<TextView 
	    android:id="@+id/textView1"
	    android:layout_width="fill_parent"
	    android:layout_height="wrap_content"
	    android:layout_toRightOf="@id/image"
	    />
	<TextView 
	    android:id="@+id/textView2"
	    android:layout_width="fill_parent"
	    android:layout_height="wrap_content"
	    android:layout_toRightOf="@id/image"
	    android:layout_below="@id/textView1"
	    />
</RelativeLayout>
Activity代码如下:

package com.example.testlistview;

import android.os.Bundle;

public class TestListView extends Activity {
	ListView listView;
	String [] titles={"标题1","标题2","标题3","标题4"};
	String [] texts={"文本内容1","文本内容2","文本内容3","文本内容4"};
	int [] Ids={R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher};
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_test_list_view);
        listView=(ListView)findViewById(R.id.myList);
        listView.setAdapter(new ListViewAdapter(titles, texts, Ids));
    }

    
    public class ListViewAdapter extends BaseAdapter{

		View [] itemViews;
		public ListViewAdapter(String[] stitles,String[] stexts,int[] sIds ){
			itemViews=new View[stitles.length];
			
			for(int i=0;i<stitles.length;i++){
				itemViews[i] = makeItemView(stitles[i], stexts[i],  
                        sIds[i]); 
			}
		}
		private View makeItemView(String strtitle,String strtext,int resid ){
			LayoutInflater inflater=(LayoutInflater)TestListView.this.
					getSystemService(Context.LAYOUT_INFLATER_SERVICE);
			// 使用View的对象itemView与R.layout.item关联  
			View itemView=inflater.inflate(R.layout.list, null);
			// 通过findViewById()方法实例R.layout.item内各组件 
			TextView title=(TextView)itemView.findViewById(R.id.textView1);
			title.setText(strtitle);
			
			TextView text=(TextView)itemView.findViewById(R.id.textView2);
			text.setText(strtext);
			
			ImageView image=(ImageView)itemView.findViewById(R.id.image);
			image.setImageResource(resid);
			
			return itemView;
			
		}
    	public int getCount() {
			// TODO Auto-generated method stub
			return itemViews.length;
		}

		public Object getItem(int arg0) {
			// TODO Auto-generated method stub
			return itemViews[arg0];
		}

		public long getItemId(int arg0) {
			// TODO Auto-generated method stub
			return arg0;
		}

		public View getView(int arg0, View arg1, ViewGroup arg2) {
			// TODO Auto-generated method stub
			 if (arg1 == null)  
	                
				 return itemViews[arg0];  
	            
			 return arg1;
		}
    	
    }
    
}
运行结果如下:


详细的解释可参考文章:http://blog.csdn.net/hellogv/article/details/4548659

这里要说明的一点自己在编写好后,调试时老是出错,经过将近1个小时的排查才发现是Activity代码中36、39、42中是写成了TextView title=(TextView)findViewById(R.id.textView1);而应该写成

TextView title=(TextView)itemView.findViewById(R.id.textView1)

大家注意一下这个细节。

Android常用的UI组件

近来读完《疯狂Android讲义》一书,也将其中的案例都码了一遍。很厚的一本书,就像一本字典,涵盖了大部分的android基础知识。现对里面一些比较不错的内容做出总结。本篇对常用UI组件做出总结,只做...
  • m0_37597069
  • m0_37597069
  • 2017年04月16日 16:37
  • 1305

Android应用开发———Android中的常用UI组件

1、Android中常用的的UI组件: 2、TextView文本显示组件:         TextView组件的主要功能是向用户显示文本内容。         TextView组件在功...
  • fang_yang_wa
  • fang_yang_wa
  • 2017年05月10日 13:46
  • 199

Android开发教程13:UI之列表:ListView

转自: http://liuzhichao.com/p/365.html ListView是Android开发中比较常用的一个组件,它以列表的形式展示具体内容,并且能够根据数据的长度自适应显示。...
  • meryvn
  • meryvn
  • 2015年09月22日 15:03
  • 715

Chrome学习笔记(三):UI组件,皮肤引擎

原创文章,转载请注明:转载自Soul Apogee 本文链接地址:Chrome学习笔记(三):UI组件,皮肤引擎 —— 控件库 这篇文章是接着上篇文章继续聊的,Chrome的代码实在太多,每一...
  • wanfengnianhua
  • wanfengnianhua
  • 2017年04月25日 18:56
  • 256

Android UI 组件开源软件 共有47款

http://www.oschina.net/project/tag/342/android-ui Android显示GIF动画 GifView GifView 是一个为了...
  • jaycee110905
  • jaycee110905
  • 2013年07月23日 16:37
  • 3338

android 使用原生UI组件

在如今的App中,已经有成千上万的原生UI部件了——其中的一些是平台的一部分,另一些可能来自于一些第三方库,而且可能你自己还收藏了很多。React Native已经封装了大部分最常见的组件,譬如Scr...
  • u012915455
  • u012915455
  • 2016年09月19日 11:17
  • 1009

Android入门——Intent、Bundle的使用和ListView的应用

Android入门——Intent、Bundle的使用和ListView的应用
  • qq_32696375
  • qq_32696375
  • 2016年11月09日 14:10
  • 490

React Native之原生UI组件封装---适配Android

React Native进阶之原生UI组件封装—适配Android(一)前言这篇来介绍一下封装原生UI组件封装给React Native前端进行调用,不过当前文章所讲只是用于Android部分开发,后...
  • u014484863
  • u014484863
  • 2016年06月03日 23:52
  • 2005

Android组件及UI框架大全

Android 是目前最流行的移动操作系统(还需要加之一吗?)。 随着新版本的不断发布, Android的功能也日益强大, 涌现了很多流行的应用程序, 也催生了一大批的优秀的组件。 本文试图将目前流...
  • boonya
  • boonya
  • 2014年08月20日 12:09
  • 49930

Android中常用UI组件总结

UI组件之布局管理器 A.     线性布局(LinearLayout):控制各组件横向排列,到头之后,剩下的组件将不会显示出来。常用属性       1.      android:ba...
  • spanklebobo
  • spanklebobo
  • 2016年08月15日 14:01
  • 544
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android的UI组件之ListView(三)
举报原因:
原因补充:

(最多只允许输入30个字)