在listView里的TestView使用自定义的字体,一开始在Adapter里的代码如下:

        
  1. @Override
  2. publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
  3. ViewHolderholder=null;
  4. if(convertView==null){
  5. holder=newViewHolder();
  6. convertView=mInflater.inflate(R.layout.listview_element,null);
  7. holder.titleTextView=(TextView)convertView
  8. .findViewById(R.id.title);
  9. holder.infoTextView=(TextView)convertView
  10. .findViewById(R.id.info);
  11. convertView.setTag(holder);
  12. }else{
  13. holder=(ViewHolder)convertView.getTag();
  14. }
  15. AssetManagermgr=context.getAssets();
  16. Typefacetypeface=Typeface.createFromAsset(mgr,"STKAITI.TTF");
  17. holder.titleTextView.setTypeface(typeface);
  18. holder.titleTextView.setText((String)mData.get(position).get(Item.KEY_ZI));
  19. holder.infoTextView.setText((String)mData.get(position).get(Item.KEY_INFO));
  20. returnconvertView;
  21. }

但是程序一直没有运行成功,一到listView就崩溃了。一开始还以为listView不允许自定义字体。后来在logcat进行输出后发现line15-17的代码都正常执行。但是却执行了很多次直至奔溃(应该是内存不够强制停止)。

再阅读了该篇博客http://www.ideasandroid.com/archives/295后,幡然醒悟,因为TextView换字体只需要一次即可,并不需要多次,不想setText是每一行都是不同的内容。

所以重新修改代码如下:

        
  1. @Override
  2. publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
  3. ViewHolderholder=null;
  4. if(convertView==null){
  5. holder=newViewHolder();
  6. convertView=mInflater.inflate(R.layout.listview_element,null);
  7. holder.titleTextView=(TextView)convertView
  8. .findViewById(R.id.title);
  9. holder.infoTextView=(TextView)convertView
  10. .findViewById(R.id.info);
  11. convertView.setTag(holder);
  12. AssetManagermgr=context.getAssets();
  13. Typefacetypeface=Typeface.createFromAsset(mgr,"STKAITI.TTF");"typeface"+typeface.toString());
  14. holder.titleTextView.setTypeface(typeface);
  15. }else{
  16. holder=(ViewHolder)convertView.getTag();
  17. }
  18. holder.titleTextView.setText((String)mData.get(position).get(Item.KEY_ZI));
  19. holder.infoTextView.setText((String)mData.get(position).get(Item.KEY_INFO));
  20. returnconvertView;
  21. }

修改后果然能正常运行,但是不知为何,line12-14的代码仍是被执行不止一次,但远比修改前少了。

附:为了防止上文提到的看到的博客链接失效,特将内容贴在下面:

Android开发之ListView 适配器(Adapter)优化

作者: ideasandroid 分类: android基础 , android高级编程 [转载请注明] 来源: www.ideasandroid.com原文:http://www.ideasandroid.com/archives/295

ListView的Adapter的作用如下图所示:

Adapter的作用就是ListView界面与数据之间的桥梁,当列表里的每一项显示到页面时,都会调用Adapter的getView方法返回一个View。想过没有? 在我们的列表有1000000项时会是什么样的?是不是会占用极大的系统资源?

先看看下面的代码:

public View getView(int position, View convertView, ViewGroup parent) { View item = mInflater.inflate(R.layout.list_item_icon_text, null); ((TextView) item.findViewById(R.id.text)).setText(DATA[position]); ((ImageView) item.findViewById(R.id.icon)).setImageBitmap( (position & 1) == 1 ? mIcon1 : mIcon2); return item; }

怎么样?如果超过1000000项时,后果不堪设想!您可千万别这么写!

我们再来看看下面的代码:

public View getView(int position, View convertView, ViewGroup parent) { if (convertView == null) { convertView = mInflater.inflate(R.layout.item, null); } ((TextView) convertView.findViewById(R.id.text)).setText(DATA[position]); ((ImageView) convertView.findViewById(R.id.icon)).setImageBitmap( (position & 1) == 1 ? mIcon1 : mIcon2); return convertView; }

怎么样,上面的代码是不是好了很多?系统将会减少创建很多View。性能得到了很大的提升。

还有没有优化的方法呢? 答案是肯定的:

public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder; if (convertView == null) { convertView = mInflater.inflate(R.layout.list_item_icon_text, null); holder = new ViewHolder(); holder.text = (TextView) convertView.findViewById(R.id.text); holder.icon = (ImageView) convertView.findViewById(R.id.icon); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } holder.text.setText(DATA[position]); holder.icon.setImageBitmap((position & 1) == 1 ? mIcon1 : mIcon2); return convertView; }  static class ViewHolder { TextView text; ImageView icon; }

怎么样?会不会又给您的系统带来很大的提升呢?看看下面三种方式的性能对比图您就知道了!

本文是Google I/O 2009 Romain Guy 所讲的内容,这里只做简单介绍,相信一看代码就能看懂!有问题请留言!

更多相关文章

  1. Google Espresso 环境搭建以及简单使用教程
  2. Android培训班(22)
  3. android中自定义标签ImageButton
  4. Android(安卓)代码模拟ListView item的点击事件并且改变背景颜色
  5. android 代码混淆示例
  6. Android(安卓)NDK 1.6
  7. android9.0解决http获取异常
  8. Android使用自定义view在指定时间内匀速画一条直线的实例代码
  9. C99标准之宏定义_可变参数宏_#_##

随机推荐

  1. 用android-logging-log4j去实现log输出内
  2. Android之使用传感器获取相应数据
  3. Eclipse For Android(安卓)代码自动提示
  4. Android通过onDraw实现在View中绘图操作
  5. android5中数据存储方式详解
  6. Android(安卓)访问权限设置记录-存档留着
  7. Android工程的编译过程
  8. Android(安卓)EditText密码框中字体和普
  9. Android事务 IMMEDIATE与EXCLUSIVE模式
  10. OpenGL ES 纹理过滤模式-glTexParameteri