为什么我的listview背景是黑色的优化问题
要使用android:cacheColorHint=“@null“ 和android:listSelector=“@null“ 是listview除去背景色,ListView是常用的显示控件,默认背景是和系统窗口一样的透明色,如果给ListView加上背景图片,或者背景颜色时,滚动时listView会黑掉,原因是,滚动时,列表里面的view重绘时,用的依旧是系统默认的透明色,颜色值为#FF191919,要改变这种情况,只需要调用listView的setCacheColorHint(0),颜色值设置为0,或者xml文件中listView的属性Android:cacheColorHint=“#00000000“即可,滚动时,重绘View的时候就不会有背景颜色。android:listSelector=“#00000000“进行上面的设置之后,ListView点击item时就没有任何现象了,android:listSelector=“@null“不可以实现。自定义listview的时候,当你不使用android:cacheColorHint=“#00000000”会出现下面选中一个空间黑色底色的情况,破坏整体美观度
ListView有多种Item View的优化
对于ListView 的优化,网上已经被讲解过很多,ListView的优化一般优化如下几点:
(1)Item View重用优化(防内存溢出)
(2)View查找优化(减少执行时间)
(3)滑动优化,在滑动的时候加载图片数据等(防滑动卡顿)
以上基本上是对应单ItemView进行的优化,对于多种ItemView的优化一般使用BaseAdapter给
提供的两个方法
getItemViewType():返回View类型,默认返回0
getViewTypeCount(): 返回有多少种类型的itemView,默认返回1
只有一种类型item view的话,是不需要重写这两个方法的。
如果有多个的时候,就需要重写这个方法了,并且返回的必须满足一下要求:
(1)getItemViewType()返回值必须大于等于0,并且小于类型的个数。为什么是这个范围,是因为
在ListView里有一个数据,用来缓存已经使用过的Item View,详细信息自己看源码
(2)getViewTypeCount()这个方法的返回值就是你可能遇到的Item view类型的最大个数,ListView会根据这个返回值
去创建缓存数组
如果有两种View类型的话,直接在Adapter里面重写getView()方法就可以了,根据getItemViewType()返回值创建相应的View既可。
但是,如果有六个,七个怎么办?那么Adapter的getView()方法得写多少代码,到时候维护起来会多么麻烦,自己看自己写的还好,
如果换做别人呢?非常非常的痛苦…..
我在做我们的app的时候,就遇到了这样的问题,订单列表,每种订单所对应的Item View会有很大的区别,操作起来极为不方便,如有小的
改动都会耽误很长时间。新增类型也不好处理。
我针对遇到的问题进行了一个点点的优化,可以能不是最优秀的,但是至少能解决以上问题,如果您能有更好的方式,也欢迎交流。
设计:
使用提供者的设计方式提供每种Item View,不同的ItemView会有不同的提供者,提供者需要实现一个接口:
public interface IViewProvider { public abstract View getItemView(View convertView, LayoutInflater inflater, Object data); }
提供者只需要实现此接口,然后实现getItemView()方法,实现方式和Adapter的getView()的方式完全一样,减少了学习成本。
我还继承BaseAdapter专门实现了一个Adapter,名字叫MiltilViewListAdapter.java,实现了前面说的两个方法,和getView()方法
提供者只需要配置给MiltilViewListAdapter的实例即可。
一般情况下,都要传递给Adapter一个Bean集合,我的设计是,让这里面的bean都实现一个接口,用来标示它对应的哪个提供者。
使用方法:
[mw_shl_code=java,true]private ListView mListView; private List《IItemBean》 mList = new ArrayList《IItemBean》(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); createData(); mListView = (ListView) findViewById(R.id.my_listview); //不同之处在于多了一个provider集合,提供所有期望显示类型的provider class //getView的实现在provider中实现,和在adapter中用法一样 List《Class《? extends IViewProvider》》 providers = new ArrayList《Class《? extends IViewProvider》》(); providers.add(FlightOrderViewProvider.class); providers.add(SticketOrderViewProvider.class); MiltilViewListAdapter adpater = new MiltilViewListAdapter(getApplication(), mList, providers); mListView.setAdapter(adpater); }[/mw_shl_code]
listview控件使用及其优化是怎样的
public class MainActivity extends Activity {
private String data = { “Apple“, “Banana“, “Orange“, “Watermelon“,
“Pear“, “Grape“, “Pineapple“, “Strawberry“, “Cherry“, “Mango“ };
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ArrayAdapter《String》 adapter = new ArrayAdapter《String》(
MainActivity.this, android.R.layout.simple_list_item_1, data);
ListView listView = (ListView) findViewById(R.id.list_view);
listView.setAdapter(adapter);
}
}
listview为什么要优化性能
ListView几乎在每个应用中都会用到。用ListView易于展现一些如联系人、菜单等tems信息。这好像可以理所当然地认为Android应该有现成封装好的方式来展现这类数据,最新的实现版就是RecyclerView。它被构建用于高效重复利用views,而不是每次当某…
listview滑动不流畅总卡怎么办
1..Adapter的getView方法里面convertView没有使用setTag和getTag方式;
2.在getView方法里面ViewHolder初始化后的赋值或者是多个控件的显示状态和背景的显示没有优化好,抑或是里面含有复杂的计算和耗时操作;
3.在getView方法里面 inflate的row
嵌套太深(布局过于复杂)或者是布局里面有大图片或者背景所致;
4.Adapter多余或者不合理的notifySetDataChanged;
5.listview
被多层嵌套,多次的onMessure导致卡顿,如果多层嵌套无法避免,建议把listview的高和宽设置为fill_parent.
如果是代码继承的listview,那么也请你别忘记为你的继承类添加上LayoutPrams,注意高和宽都是fill_parent的;
android listview优化几种写法详细介绍
listview A view that shows items in a vertically scrolling list 。一个显示一个垂直的滚动子项的列表视图 在android开发中,使用listview的地方很多,用它来展现数据,成一个垂直的视图。使用listview是一个标准的适配器模式,用数据–,界面–xml以及适配器–adapter,数据被适配器按照需要的方式展现出来,xml描写了数据如何展现,activity中控制这些活动。 其中使用自定义的adapter,会要重写getView方法,在getView方法产生给用户item的视图以及数据。 见图: 这里有一个优化的地方,就是重用view,这样减少内存消耗,同时加快item加载速度。 在getView中优化的地方,大家想必都非常情况,下面我总结了三种优化的写法,请大家指正。 第一: 重用了convertView,很大程度上的减少了内存的消耗。通过判断convertView是否为null,是的话就需要产生一个视图出来,然后给这个视图数据,最后将这个视图返回给底层,呈献给用户。 特点:如果当前的convertView为null,则通过LayoutInflat产生一个view。View Code 第二: 上面的写法会有一个缺点,就是每次在getVIew的时候,都需要重新的findViewById,重新找到控件,然后进行控件的赋值以及事件相应设置。这样其实在做重复的事情,因为的geiview中,其实包含有这些控件,而且这些控件的id还都是一样的,也就是其实只要在view中findViewById一次,后面无需要每次都要findViewById了。 下面给出第二种写法 写发的特点,通常有一个内部类class ViewHolder,这个ViewHolder,用来标识view中一些控件,方便进行一些事件相应操作的设置,比如onClick等等,这样可以不用每次都要findViewById了,减少了性能的消耗。同时重用了convertView,很大程度上的减少了内存的消耗。View Code 第三:
个人觉得这个写法是最舒服的,最舒服的意思是看着代码有一种很爽,看的很清晰。 特点,使用了内部类class ViewHolder、重用了convertView。 区别第二种写法是,使用了一个临时变量View view = convertView,然后修改view,最后返回viewView Code 以上就是集中写法,供新手学习和总结。源代码如下:LisViewTest.zip 根据楼下朋友提供的建议,发现还有优化的地方,最新更新如下: View Code @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; ViewHolder holder ; if (view == null) { view = LayoutInflater.from(context).inflate(R.layout.section_list_item1, null); holder = new ViewHolder(); holder.tv_name = (TextView)view.findViewById(R.id.contact_contactinfoitem_tv_name); holder.tv_phone = (TextView)view.findViewById(R.id.contact_contactinfoitem_tv_phoneNum); view.setTag(holder); } else { holder = (ViewHolder)view.getTag(); } ContactInfo1 confo = contacts.get(position); Log.i(“my“, “confo “+confo.getContactName()); if (confo != null) {//to set every item’s text holder.tv_name.setText(confo.getContactName()); holder.tv_phone.setText(confo.getContact_Phone()); } return view; } 《font color=“\“#0000ff\““》 《/font》staticclass ViewHolder { TextView tv_name,tv_phone; } 注意:static class ViewHolder 这里设置ViewHolder 为static,也就是静态的,静态类只会在第一次加载时 会耗费比较长时间,但是后面就可以很好帮助加载,同时保证了内存中只有一个ViewHolder,节省了内存的开销。 非常感谢大家提出建议以及大家的关注!
为什么要对ListView控件进行优化,以及如何
比如你在窗体上放了一个ListView,教你一些简单的操作。
listView1.Columns.Clear();//清空列记录
ColumnHeader cZh = new ColumnHeader();//创建一个列
cZh.Text = “英文“;//列名
ColumnHeader cCh = new ColumnHeader();
cCh.Text = “中文“;
listView1.Columns.AddRange(new ColumnHeader { cZh, cCh });//将这两列加入listView1
listView1.View = View.Details;//列的显示模式
ListViewItem lvi = new ListViewItem(new string {“Gog”,“狗“ }, -1);//创建列表项
listView1.Items.Add(lvi);//将项加入listView1列表中
动手试试就理解了。