listview item布局具有多种item布局

君,已阅读到文档的结尾了呢~~
android listview item定义不同..
扫扫二维码,随身浏览文档
手机或平板扫扫即可继续访问
android listview item定义不同的样式布局
举报该文档为侵权文档。
举报该文档含有违规或不良信息。
反馈该文档无法正常浏览。
举报该文档为重复文档。
推荐理由:
将文档分享至:
分享完整地址
文档地址:
粘贴到BBS或博客
flash地址:
支持嵌入FLASH地址的网站使用
html代码:
&embed src='/DocinViewer-4.swf' width='100%' height='600' type=application/x-shockwave-flash ALLOWFULLSCREEN='true' ALLOWSCRIPTACCESS='always'&&/embed&
450px*300px480px*400px650px*490px
支持嵌入HTML代码的网站使用
您的内容已经提交成功
您所提交的内容需要审核后才能发布,请您等待!
3秒自动关闭窗口10:09 提问
listview的item如何让它自适应内容的高
想实现listview中当一个内容多的时候,item的高度能充满屏幕,或者超过屏幕,内容少的时候,一屏可以显示多个item,如何才能让item自适应呢?
下面是我的item布局,大家帮忙看看:
&?xml version="1.0" encoding="utf-8"?&
&RelativeLayout xmlns:android="/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" &
&FrameLayout
android:id="@+id/main_item_frameLayout"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginLeft="4dp"
android:layout_marginTop="10dp" &
&ImageView
android:id="@+id/imageHead"
android:layout_width="@dimen/wb_head_image"
android:layout_height="@dimen/wb_head_image" /&
&ProgressBar
android:id="@+id/main_item_progress"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:indeterminate="false"
android:indeterminateDrawable="@anim/loading"
android:visibility="gone" /&
&/FrameLayout&
&LinearLayout
android:id="@+id/main_item_linearLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_toRightOf="@id/main_item_frameLayout"
android:orientation="vertical" &
&RelativeLayout
android:id="@+id/relativeLayout1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical" &
android:id="@+id/name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:paddingLeft="10dp"
android:paddingTop="10dp"
android:textSize="18sp" /&
android:id="@+id/time"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:paddingRight="10dp"
android:paddingTop="10dp"
android:textColor="@color/yellow"
android:textSize="15sp" /&
&/RelativeLayout&
&LinearLayout
android:id="@+id/main_item_content_linearLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" &
android:id="@+id/content"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:textSize="20sp"
android:textStyle="bold" /&
android:id="@+id/main_item_pictures"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:numColumns="3"
android:scrollbars="none" &
&/GridView&
&/LinearLayout&
&RelativeLayout
android:id="@+id/relativeLayout2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp" &
android:id="@+id/comment"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:paddingBottom="10dp"
android:paddingRight="10dp"
android:textSize="12sp" /&
&ImageView
android:id="@+id/imageView4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_toLeftOf="@id/comment"
android:paddingBottom="10dp"
android:src="@drawable/weibo_comment" /&
android:id="@+id/transmit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_toLeftOf="@id/imageView4"
android:paddingBottom="10dp"
android:paddingRight="10dp"
android:textSize="12sp" /&
&ImageView
android:id="@+id/imageView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_toLeftOf="@id/transmit"
android:paddingBottom="10dp"
android:src="@drawable/weibo_transmit" /&
android:id="@+id/praise"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_toLeftOf="@id/imageView3"
android:paddingBottom="10dp"
android:paddingRight="10dp"
android:textSize="12sp" /&
&ImageView
android:id="@+id/imageView5"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_toLeftOf="@id/praise"
android:paddingBottom="10dp"
android:src="@drawable/weibo_transmit" /&
&/RelativeLayout&
&/LinearLayout&
&/RelativeLayout&
按赞数排序
&?xml version="1.0" encoding="utf-8"?&
&RelativeLayout xmlns:android="/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" &
使用wrap_content,试试。。。
建议:在布局里面,不要设计太复杂的多种布局,防止异常;可以多重使用LinearLayout实现效果
把第4行第一个RelativeLayout的android:layout_height="match_parent"改成android:layout_height="wrap_content"就可以了。
12827关注|1190收录
其他相似问题
相关参考资料> ListView 带有多个Item布局时,convertView的缓存与重用
ListView 带有多个Item布局时,convertView的缓存与重用
lwt205 & &
发布时间: & &
浏览:238 & &
回复:0 & &
悬赏:0.0希赛币
ListView 含有多个Item布局时,convertView的缓存与重用
  最近有需求需要在listView中载入不同的listItem布局,若这样写
  public View getView(int position, View convertView, ViewGroup parent) { View view = new Xxx(...); ... ... }
  没有使用缓存的 convertView,会导致内存泄露
  描述: 以构造ListView的BaseAdapter为例,在BaseAdapter中提供了方法:
  public View getView(int position, View convertView, ViewGroup parent){ }
  来向ListView提供每一个item所需要的view对象。初始时ListView会从BaseAdapter中根据当前的屏幕布局实例化一定数量的view对象,同时ListView会将这些view对象缓存起来。当向上滚动ListView时,原先位于最上面的list item的view对象会被回收,然后被用来构造新出现的最下面的list item。这个构造过程就是由getView()方法完成的,getView()的第二个形参 View convertView就是被缓存起来的list item的view对象(初始化时缓存中没有view对象则convertView是null)。 由此可以看出,如果我们不去使用convertView,而是每次都在getView()中重新实例化一个View对象的话,即浪费资源也浪费时间,也会使得内存占用越来越大。
  修正示例代码:public View getView(int position, View convertView, ViewGroup parent) { View view = if (convertView != null) { view = convertV ... } else { view = new Xxx(...); ... } }
  上述代码很好的解决了内存泄露的问题,使用convertView回收一些布局供下面重构是使用。
  但是如果出现如下图的需求,convertView就不太好用了,convertView在Item为单一的布局时,能够回收并重用,但是多个Item布局时,convertView的回收和重用会出现问题。
  Listview中有3种Item布局,即使convertView缓存了一些布局,但是在重构时,根本不知道怎么样去让convertView返回你所需要的布局,这时你需要让adapter知道我当前有哪些布局,我重构Item时的布局选取规则,好让convertView能返回你需要的布局
  需要重写一下两个函数
  @Override
  public int getItemViewType(int position) {}
  上述两个函数的作用这如它的名字,得到Item的样式,得到所有的样式数量
  下面直接上代码,就是上图的实现代码:
  package com.bestv.listViewTimport java.util.ArrayLimport android.app.Aimport android.content.Cimport android.os.Bimport android.util.Limport android.view.LayoutIimport android.view.Vimport android.view.ViewGimport android.widget.BaseAimport android.widget.CheckBimport android.widget.ImageVimport android.widget.LinearLimport android.widget.ListVimport android.widget.TextVpublic class listViewTest extends Activity {/** Called when the activity is first created. */ListView listVMyAdapter listAArrayList&String& listS@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);listView = (ListView)this.findViewById(R.id.listview);listString = new ArrayList&String&();for(int i = 0 ; i & 100 ; i++){listString.add(Integer.toString(i));}listAdapter = new MyAdapter(this);listView.setAdapter(listAdapter);}class MyAdapter extends BaseAdapter{Context mCLinearLayout linearLayout =LayoutITextVfinal int VIEW_TYPE = 3;final int TYPE_1 = 0;final int TYPE_2 = 1;final int TYPE_3 = 2;public MyAdapter(Context context) {// TODO Auto-generated constructor stubmContext =inflater = LayoutInflater.from(mContext);}@Overridepublic int getCount() {// TODO Auto-generated method stubreturn listString.size();}//每个convert view都会调用此方法,获得当前所需要的view样式@Overridepublic int getItemViewType(int position) {// TODO Auto-generated method stubint p = position%6;if(p == 0)return TYPE_1;else if(p & 3)return TYPE_2;else if(p & 6)return TYPE_3;elsereturn TYPE_1;}@Overridepublic int getViewTypeCount() {// TODO Auto-generated method stubreturn 3;}@Overridepublic Object getItem(int arg0) {// TODO Auto-generated method stubreturn listString.get(arg0);}@Overridepublic long getItemId(int position) {// TODO Auto-generated method stub}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {// TODO Auto-generated method stubviewHolder1 holder1 =viewHolder2 holder2 =viewHolder3 holder3 =int type = getItemViewType(position);//无convertView,需要new出各个控件if(convertView == null){ Log.e("convertView = ", " NULL");//按当前所需的样式,确定new的布局switch(type){case TYPE_1:convertView = inflater.inflate(R.layout.listitem1, parent, false);holder1 = new viewHolder1();holder1.textView = (TextView)convertView.findViewById(R.id.textview1);holder1.checkBox = (CheckBox)convertView.findViewById(R.id.checkbox);Log.e("convertView = ", "NULL TYPE_1");convertView.setTag(holder1);case TYPE_2:convertView = inflater.inflate(R.layout.listitem2, parent, false);holder2 = new viewHolder2();holder2.textView = (TextView)convertView.findViewById(R.id.textview2);Log.e("convertView = ", "NULL TYPE_2");convertView.setTag(holder2);case TYPE_3:convertView = inflater.inflate(R.layout.listitem3, parent, false);holder3 = new viewHolder3();holder3.textView = (TextView)convertView.findViewById(R.id.textview3);holder3.imageView = (ImageView)convertView.findViewById(R.id.imageview);Log.e("convertView = ", "NULL TYPE_3");convertView.setTag(holder3);}}else{//有convertView,按样式,取得不用的布局switch(type){case TYPE_1:holder1 = (viewHolder1) convertView.getTag();Log.e("convertView !!!!!!= ", "NULL TYPE_1");case TYPE_2:holder2 = (viewHolder2) convertView.getTag();Log.e("convertView !!!!!!= ", "NULL TYPE_2");case TYPE_3:holder3 = (viewHolder3) convertView.getTag();Log.e("convertView !!!!!!= ", "NULL TYPE_3");}}//设置资源switch(type){case TYPE_1:holder1.textView.setText(Integer.toString(position));holder1.checkBox.setChecked(true);case TYPE_2:holder2.textView.setText(Integer.toString(position));case TYPE_3:holder3.textView.setText(Integer.toString(position));holder3.imageView.setBackgroundResource(R.drawable.icon);}return convertV}}//各个布局的控件资源class viewHolder1{CheckBox checkBTextView textV}class viewHolder2{TextView textV}class viewHolder3{ImageView imageVTextView textV}}
  在getView()中需要将不同布局进行缓存和适配,系统在判断是否有convertView时,会自动去调用getItemViewType (int position) ,查看是否已经有缓存的该类型的布局,从而进入if(convertView == null)和else{}的判断。期间需要做的是convertView.setTag(holder3),以便在convertView重用时可以直接拿到该布局的控件,holder3 = (viewHolder3) convertView.getTag()。到这一步,convertView的回收和重用就已经写好了,接下来只需要对你的不同的控件进行设置就行了。
本问题标题:
本问题地址:
温馨提示:本问题已经关闭,不能解答。
暂无合适的专家
&&&&&&&&&&&&&&&
希赛网 版权所有 & &&

我要回帖

更多关于 listview删除item刷新 的文章

 

随机推荐