关于BaseAdapter的学习,看了下别人的博客,自己写了个demo,觉得这样学习效率会高些。
一:先改写activity_main.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="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<ListView
android:id="@+id/listView"
android:layout_width="match_parent"
android:layout_height="match_parent"
></ListView>
</RelativeLayout>
二、再构建每个map的布局list_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<LinearLayout
android:id="@+id/linear1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_marginLeft="10dp"
>
<ImageView
android:id="@+id/appimg"
android:layout_width="40dp"
android:layout_height="40dp"
/>
</LinearLayout>
<LinearLayout
android:id="@+id/linear2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@id/linear1"
android:layout_alignParentTop="true"
android:layout_marginLeft="5dp"
android:orientation="vertical"
>
<LinearLayout
android:id="@+id/sublinear1"
android:layout_width="wrap_content"
android:layout_height="match_parent"
>
<TextView
android:id="@+id/appnametext"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
</LinearLayout>
<LinearLayout
android:id="@+id/sublinear2"
android:layout_marginTop="5dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
>
<TextView
android:id="@+id/sizetext"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
<ImageView
android:id="@+id/slashimg"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="3dp"
android:layout_marginRight="3dp"
/>
<TextView
android:id="@+id/amounttext"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
</LinearLayout>
</LinearLayout>
<LinearLayout
android:id="@+id/linear3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_marginRight="10dp"
>
<Button
android:id="@+id/dowmbutton"
android:layout_width="wrap_content"
android:layout_height="35dp"
android:layout_marginTop="5dp"
android:text="@string/downapp" />
</LinearLayout>
</RelativeLayout>
三:改写MainActivity.java方法,由于是练习,所以先试了下SimpleAdapter,改写的话把getData()方法写在这个acitivity里面即可:
package com.yangyong.listview02;
/*
* 两个Adapter练习,simpleAdapter和BaseAdapter, simpleAddapter只适合字符串的情况,而BaseAdapter可以加入
* 自定义的图片等内容
*/
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.widget.ListView;
import android.widget.SimpleAdapter;
public class MainActivity extends Activity {
private ListView listView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView=(ListView)findViewById(R.id.listView);
//里面的5个参数的含义:1、代表这个activity 2、代表一个List,一个数据结构 3、子item的布局文件 4每个map的键 5 每个键值对应的控件
/*
SimpleAdapter simpleAdapter=new SimpleAdapter(this,getData(),R.layout.list_item,
new String[]{"appnametext","sizetext","amounttext"},
new int[]{R.id.appnametext,R.id.sizetext,R.id.amounttext});
listView.setAdapter(simpleAdapter);
*/
MyAdapter adapter=new MyAdapter(this);
listView.setAdapter(adapter);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
四:最后就是myAdapter.java这个适配器类了,其中静态类的用法需要注意,可以优化内存:
package com.yangyong.listview02;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
public class MyAdapter extends BaseAdapter{
private String TAG ="MyAdapter";
private LayoutInflater mInflater;
private List<Map<String,Object>> data;
public MyAdapter(Context context){
this.mInflater=LayoutInflater.from(context);
//获得数据
data=getData();
}
@Override
public int getCount() {
return data.size();
}
@Override
public Object getItem(int position) {
return data.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
/*
* 静态类的定义,当holder = new ViewHolder(); 执行时,直接使用以前的对象,减少生成对象对内存的消耗
*/
static class ViewHolder{
public ImageView appimg;
public TextView appnametext;
public TextView sizetext;
public TextView amounttext;
public Button dowmbutton;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder=null;
//视图内容为空,再去加载对象
if(convertView==null){
holder=new ViewHolder();
Log.d(TAG,"creat a viewHolder!");
convertView=mInflater.inflate(R.layout.list_item, null);
holder.appimg=(ImageView)convertView.findViewById(R.id.appimg);
holder.appnametext=(TextView)convertView.findViewById(R.id.appnametext);
holder.sizetext=(TextView)convertView.findViewById(R.id.sizetext);
holder.amounttext=(TextView)convertView.findViewById(R.id.amounttext);
holder.dowmbutton=(Button)convertView.findViewById(R.id.dowmbutton);
//将holder对象生成的对象设置给视图convertView
convertView.setTag(holder);
}else{
//直接调用ViewHolder中的静态对象
holder=(ViewHolder)convertView.getTag();
}
//对ViewHolder内控件添加数据的 键 和 地址,是图像的设置背景资源,是文本的设置文本
//个人感觉是对静态资源的初始化
holder.appimg.setBackgroundResource((Integer)data.get(position).get("appimg"));
holder.appnametext.setText((String)data.get(position).get("appnametext"));
holder.sizetext.setText((String)data.get(position).get("sizetext"));
holder.amounttext.setText((String)data.get(position).get("amounttext"));
return convertView;
}
private List<Map<String,Object>> getData() {
List<Map<String,Object>> list= new ArrayList<Map<String,Object>>();
Map<String,Object> map=new HashMap<String,Object>();
map.put("appnametext", "人人网");
map.put("sizetext", "15.2");
map.put("amounttext", "1234323");
map.put("appimg", R.![图片说明文字][1]drawable.renren);
list.add(map);
map=new HashMap<String,Object>();
map.put("appnametext", "手机QQ");
map.put("sizetext", "8.5");
map.put("amounttext", "122073323");
map.put("appimg", R.drawable.qq);
list.add(map);
map=new HashMap<String,Object>();
map.put("appnametext", "手机QQ空间");
map.put("sizetext", "6.3");
map.put("amounttext", "122393");
map.put("appimg", R.drawable.qqzone);
list.add(map);
map=new HashMap<String,Object>();
map.put("appnametext", "新浪微博");
map.put("sizetext", "7.7");
map.put("amounttext", "1278323");
map.put("appimg", R.drawable.sina);
list.add(map);
return list;
}
}
写博客记录下,效果图如下: