BaseAdapter方法
getCount : 要绑定的条目的数目,比如格子的数量
getItem : 根据一个索引(位置)获得该位置的对象
getItemId : 获取条目的id
getView : 获取该条目要显示的界面
public class MyBaseAdapter extends BaseAdapter {
@Override
public int getCount() {
return 0;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View
convertView, ViewGroup parent) {
return null;
}
}
首先在MyBaseAdapter中添加super()方法,用来将数据源
传入MyBaseAdapter中。其中this.data = data;的意思是
将传入的形参赋值给我们的私有变量以供使用。mContext
是在后面要调用到
private String[] data;
private Context mContext;
public MyBaseAdapter(Context mContext, String[]
data) {
super();
this.mContext = mContext;
this.data = data;
}
然后就可以将getCount的返回值修改为我们的数据源的长
度,要显示几个条目,我们就传入多长的数据源就可以
public int getCount() {
return data.length;
}
接着将getView的方法改为显示出我们数据源的字符串
public View getView(int position, View
convertView, ViewGroup parent) {
TextView textView = new TextView(mContext);
textView.setText(data[position]);
return textView;
}
这里为每一个条目新建一个TextView用来显示字符串,新
建的时候就需要传入一个Context,就用到了我们之前的
mContext。
这样我们就可以使用MyBaseAdapter来显示一
个字符串数组了。不过还需要在前面修改一下,在新建
mBaseAdapter的时候要传入context和数据源
String[] strings = {“a”,“b”,“c”};
MyBaseAdapter mBaseAdapter = new MyBaseAdapter
(getApplicationContext(),strings);
代码:
MainActivity部分
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ListView;
public class MainActivity extends
AppCompatActivity {
private ListView listView;
@Override
protected void onCreate(Bundle
savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = (ListView) findViewById(R.id.listView);
String[] strings = {"a","b","c"};
MyBaseAdapter mBaseAdapter = new
MyBaseAdapter(getApplicationContext(),strings);
listView.setAdapter(mBaseAdapter);
}
}
MyBaseAdapter部分
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;
public class MyBaseAdapter extends BaseAdapter {
private String[] data;
private Context mContext;
public MyBaseAdapter(Context mContext,
String[] data) {
super();
this.mContext = mContext;
this.data = data;
}
@Override
public int getCount() {
return data.length;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View
convertView, ViewGroup parent) {
TextView textView = new TextView
(mContext);
textView.setText(data[position]);
return textView;
}
}
BaseAdapter进阶使用
首先新建一个layout,我命名为item,这个就是我们每个
条目要展示的布局
xmlns:android="http://schemas.android.com/apk/res/ android" xmlns:app="http://schemas.android.com/apk/res- auto" android:layout_width=“match_parent” 接下来修改getView方法,让它显示我们这个item布局 convertView, ViewGroup parent) { LayoutInflater.from(mContext); (R.layout.item,null); view.findViewById(R.id.textView); (R.id.button); view.findViewById(R.id.imageView); (R.mipmap.ic_launcher); View.OnClickListener() { inflate方法就可以将你的item布局绘制出来。其中 getView方法中的三个参数,position是指现在是第几个 条目;convertView是旧视图,就是绘制好了的视图; parent是父级视图,也就是ListView之类的。 方法绘制好后的view最后return返回给getView方法 convertView是旧视图就是listview如果超出了屏幕,滑 动的时候会隐藏掉一部分,这时候就将隐藏掉的部分保存 到convertView中 首先定义一个类ViewHolder,用来标记我们的控件 使用ViewHolder优化 convertView, ViewGroup parent) { LayoutInflater.from(mContext); (R.layout.item, null); convertView.findViewById(R.id.button); convertView.findViewById(R.id.textView); convertView.findViewById(R.id.imageView); convertView.getTag(); (R.mipmap.ic_launcher); View.OnClickListener() { ,不是的话就取出ViewHolder,这样就可以实现复用 convertView了。 android:orientation="horizontal"
android:layout_height="match_parent">
public View getView(int position, View
LayoutInflater inflater =
View view = inflater.inflate
final TextView textView = (TextView)
Button button = (Button) view.findViewById
ImageView imageView = (ImageView)
imageView.setImageResource
button.setOnClickListener(new
@Override
public void onClick(View v) {
textView.append("!");
}
});
textView.setText(data[position]);
return view;
}
LayoutInflater是用来加载布局的,用LayoutInflater的
用inflate
BaseAdapter的优化使用
static class ViewHolder{
TextView textView;
ImageView imageView;
Button button;
}
public View getView(int position, View
LayoutInflater inflater =
ViewHolder holder = null;
if (convertView == null) {
convertView = inflater.inflate
holder = new ViewHolder();
holder.button = (Button)
holder.textView = (TextView)
holder.imageView = (ImageView)
convertView.setTag(holder);
} else {
holder = (ViewHolder)
}
holder.imageView.setImageResource
holder.button.setOnClickListener(new
@Override
public void onClick(View v) {
Log.d(“click”,“button”);
}
});
holder.textView.setText(data[position]);
return convertView;
}
先判断convertView是否为空,是的话就创建ViewHolder