HolderView 与 ViewHolder做Android的伙伴都不会陌生吧,都是为了提升ListView、gridView等这类View的adapter性能,
把多个属性封装到一个类中,也就是面向对象的思想。
ViewHolder实在adapter中建立一个对象,但是没有做任何的业务逻辑,所有的逻辑还是在adapter的getView中实现,这样就显得
adapter特别臃肿。
HolderView就是为了解决adapter的臃肿问题,把逻辑处理方到HolderView中实现,在adapter中只是调用HolderView就ok了
实现代码:
public class HolderView extends GridLayout {
private TextView mDigitDigit;
private TextView mDigitHex;
private TextView mDigitOct;
private TextView mDigitEven;
private TextView mDigitPrime;
private TextView mDigitFibonacci;
private String mDigitText;
private String mDigitHexText;
private String mDigitOctText;
private String mDigitEvenText;
private String mDigitPrimtText;
private String mDigitFibonacciText;
public HolderView(Context context) {
super(context);
initlialize(context);
}
public HolderView(Context context, AttributeSet attrs) {
super(context, attrs);
initlialize(context);
}
public HolderView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
initlialize(context);
}
public void initlialize(Context context) {
View v = LayoutInflater.from(context).inflate(R.layout.list_detail, this);
mDigitDigit = (TextView) v.findViewById(R.id.list_detail_digit);
mDigitHex = (TextView) v.findViewById(R.id.list_detail_digit_hex);
mDigitOct = (TextView) v.findViewById(R.id.list_detail_digit_oct);
mDigitEven = (TextView) v.findViewById(R.id.list_detail_digit_even);
mDigitPrime = (TextView) v.findViewById(R.id.list_detail_digit_prime);
mDigitFibonacci = (TextView) v.findViewById(R.id.list_detail_digit_fibonacci);
mDigitText = context.getResources().getString(R.string.list_detail_digit);
mDigitHexText = context.getResources().getString(R.string.list_detail_digit_hex);
mDigitOctText = context.getResources().getString(R.string.list_detail_digit_oct);
mDigitEvenText = context.getResources().getString(R.string.list_detail_digit_even);
mDigitPrimtText = context.getResources().getString(R.string.list_detail_digit_prime);
mDigitFibonacciText = context.getResources().getString(R.string.list_detail_digit_fibonacci);
}
public void bind(Digit digit) {
mDigitDigit.setText(String.format(mDigitText, digit));
mDigitOct.setText(String.format(mDigitOctText, digit.toOctalString()));
mDigitHex.setText(String.format(mDigitHexText, digit.toHexString()));
mDigitEven.setText(String.format(mDigitEvenText, digit.isEven()));
mDigitPrime.setText(String.format(mDigitPrimtText, digit.isPrime()));
mDigitFibonacci.setText(String.format(mDigitFibonacciText, digit.isFibonacci()));
}
}
adapter:
public class ItemAdapter extends BaseAdapter {
private final Context mContext;
private int count = 256;
public ItemAdapter(Context context) {
mContext = context;
}
@Override
public int getCount() {
return count;
}
@Override
public Object getItem(int i) {
return i;
}
@Override
public long getItemId(int i) {
return i;
}
@Override
public View getView(int i, View convertView, ViewGroup viewGroup) {
HolderView holderView;
// Important to not just null check, but rather to a instanceof
// since we might get any subclass of view here.
if (convertView instanceof HolderView) {
holderView = (HolderView) convertView;
} else {
holderView = new HolderView(mContext);
}
holderView.bind(new Digit(i));
return holderView;
}
}
list_dateil.xml
<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android" >
<TextView
android:id="@+id/list_detail_digit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="0"
android:layout_gravity="left|top"
android:layout_row="0"
android:padding="8dip" />
<TextView
android:id="@+id/list_detail_digit_oct"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="1"
android:layout_gravity="left|top"
android:layout_row="0"
android:padding="8dip" />
<TextView
android:id="@+id/list_detail_digit_hex"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="2"
android:layout_gravity="left|top"
android:layout_row="0"
android:padding="8dip" />
<TextView
android:id="@+id/list_detail_digit_even"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="0"
android:layout_gravity="left|top"
android:layout_row="1"
android:padding="8dip" />
<TextView
android:id="@+id/list_detail_digit_prime"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="1"
android:layout_gravity="left|top"
android:layout_row="1"
android:padding="8dip" />
<TextView
android:id="@+id/list_detail_digit_fibonacci"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_column="2"
android:layout_gravity="left|top"
android:layout_row="1"
android:padding="8dip" />
</merge>
分享到:
相关推荐
超简洁ViewHolder,直接加入工具类就可以了
viewHolder封装的工具类,及其使用
万能的ViewHolder
android ViewHolder的超简洁写法,不用为每个adapter都创建一个ViewHolder类
ViewHolder超级简洁写法 博客地址:http://blog.csdn.net/kroclin/article/details/40868291
ViewHolder和Adapter 工具类
通用Adapter 通用ViewHolder
跟传统的ListView的布局应用,改善了Adapter,使用ViewHolder来提高了很多效率,使用ViewHolder来编写的适配器
我们在使用ListView的时候,经常会使用的ViewHolder方式作为缓存,每次都需要手动的通过viewholder.icon = convertview.findVIewByid(id);一般的app都会有好几个页面会用到ListView,这样的话我们的代码量就会很大,...
Recyclerview由于ViewHolder的复用显示错乱问题解决
把SparseArray绑定到一个view,SparseArray 初始化会分配10长度的地址,理论上会浪费了内存,但是这些都在允许范围内。省去了重复写viewholder的重复,重复。。自己留作纪念。
万能的Adapter和ViewHolder,写这些真的是写吐了,提高效率
ListView的adapter的getView方法中,我们使用ViewHolder来保证getView的执行效率,例子是一个通用的ViewHolder的实现。
ListViewAdapter和ViewHolder代码,全面的安卓listview适配器源码。使得使用listview绑定数据显示非常方面
对ListView的适配器BaseAdapter进行优化,减少代码量,可以继续对此工具类添加方法
listview优化 BaseAdapter
通常我们在一个项目中会多处使用到listview,我们为什么不把它抽取出来呢,这样使用起来方便一百倍,而且可以提高代码的复用率
通用ViewHolder
看到http://www.cnblogs.com/mengdd/p/3254323.html中圣骑士Wind博主的文章很好,就整理了一个Demo。供大家学习使用。如果有啥不恰当的地方,还请大家多多指教
这里介绍了listView的基本使用,数据源的添加,以及viewHolder机制的添加以及介绍