ListView之分割不同的项目布局(item layout)

public class MainActivity extends ActionBarActivity {
private MyCustomAdapter madapter;
private ListView lv;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        lv = (ListView) findViewById(R.id.listView1);
        //实例化适配器
        madapter=new MyCustomAdapter(this);
        for (int i = 1; i < 50; i++) {
madapter.addItem("item"+i);
if(i%4==0){
madapter.addSeparatorItem("separator " + i);
}
}
        lv.setAdapter(madapter);
    }


}
class MyCustomAdapter extends BaseAdapter{

private static final int TYPE_ITEM = 0;
    private static final int TYPE_SEPARATOR = 1;
    private static final int TYPE_MAX_COUNT = TYPE_SEPARATOR + 1;
 

private ArrayList mData=new ArrayList();
private LayoutInflater mInflater;
private TreeSet mSeparatorsSet = new TreeSet();

public MyCustomAdapter(Context context){
this.mInflater = LayoutInflater.from(context);  
}
public void addItem (final String item) {
mData.add(item);
notifyDataSetChanged();
}

public void addSeparatorItem(final String item) {
            mData.add(item);
            // save separator position
            mSeparatorsSet.add(mData.size() - 1);
            notifyDataSetChanged();
        }

//重写 getItemViewType(int) – 由position返回view type id
public int getItemViewType(int position) {
           return mSeparatorsSet.contains(position) ? TYPE_SEPARATOR : TYPE_ITEM;
       }
//重(@Override)写 getViewTypeCount() – 返回你有多少个不同的布局
public int getViewTypeCount() {
           return TYPE_MAX_COUNT;
       }
 
@Override
public int getCount() {
// TODO Auto-generated method stub
return mData.size();
}


@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return mData.get(position);
}


@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}


@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
int type=getItemViewType(position);
System.out.println("getView"+position+" "+convertView);
ViewHolder holder=null;
if (convertView==null) {
//实例化
holder=new ViewHolder();
switch (type) {
case TYPE_ITEM:
convertView=mInflater.inflate(R.layout.item, null);
holder.textView=(TextView) convertView.findViewById(R.id.text_item);
break;
case TYPE_SEPARATOR:
//找到一个item布局文件
convertView=mInflater.inflate(R.layout.item1, null);
holder.textView=(TextView) convertView.findViewById(R.id.textView1);
break;

}

convertView.setTag(holder);
}else {
holder=(ViewHolder) convertView.getTag();
}
holder.textView.setText( (CharSequence) mData.get(position));
return convertView;
}

}
class ViewHolder{
public TextView textView;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要设计ListViewitem布局,需要在布局文件中定义一个XML文件来描述item的视图。以下是一个简单的例子: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <ImageView android:id="@+id/image" android:layout_width="50dp" android:layout_height="50dp" android:src="@drawable/ic_launcher"/> <TextView android:id="@+id/title" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Title"/> <TextView android:id="@+id/subtitle" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Subtitle"/> </LinearLayout> ``` 上述代码中,我们使用LinearLayout来水平排列一个ImageView和两个TextView,用来展示列表项的图片、标题和副标题。注意,这只是一个简单的例子,实际应用中的item布局可能会更复杂。 接下来,在ListView的适配器中,我们可以使用这个布局文件来为每个item创建视图: ```java public class MyListAdapter extends ArrayAdapter<String> { public MyListAdapter(Context context, List<String> items) { super(context, R.layout.list_item, items); } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; if (view == null) { LayoutInflater inflater = LayoutInflater.from(getContext()); view = inflater.inflate(R.layout.list_item, parent, false); } // 绑定数据到视图上 String item = getItem(position); ImageView image = view.findViewById(R.id.image); TextView title = view.findViewById(R.id.title); TextView subtitle = view.findViewById(R.id.subtitle); title.setText(item); subtitle.setText("Subtitle for " + item); return view; } } ``` 上述代码中,我们在适配器的getView()方法中实例化了一个item视图,并使用findViewById()方法来获取其中的ImageView和两个TextView实例,最后将数据绑定到这些视图上。 当ListView需要显示一个item时,它会调用适配器的getView()方法来获取一个视图。如果已经有一个可重用的视图(即convertView不为null),则会将其返回。否则,适配器会使用LayoutInflater从布局文件中创建一个新的视图,并将其返回。 最后,我们可以将适配器设置到ListView上: ```java ListView listView = findViewById(R.id.list_view); List<String> items = Arrays.asList("Item 1", "Item 2", "Item 3"); MyListAdapter adapter = new MyListAdapter(this, items); listView.setAdapter(adapter); ``` 这样,ListView就可以根据适配器中的数据来动态地创建并显示item视图了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值