一个ListView使用多个布局文件

第一步( 个人习惯):

            因为我是两个布局文件,所以先初始化两个常量,来区分我所使用的到底是哪个布局;

            private static final int LEFT = 0;
            private static final int RIGHT = 1;

第二部:

            在自定义Adapter中继承BaseAdapter其它的方法都是一样的,只是多重写了两个方法(记住这两个方法一定要配套使用):

              1)getViewTypeCount():这个方法的返回值是ListView中一共有几个要显示的视图;

              2)getItemViewType(int position):这个方法是制定适配器显示当前position位置数据时,应该使用哪个视图;

第三部:

            在给getVIew方法中判断getItemViewType()方法的返回值和我初始化的两个常量进行判断,来确定使用那个布局:


              具体代码实现:

方法===============================================================================================================================================================================

            @Override
       public View getView(int position, View convertView, ViewGroup parent) {
        // TODO Auto-generated method stub
        final ViewHolder holder;
        if (convertView == null) {

            if(getItemViewType(position) ==LEFT) {
                convertView = inflater.inflate(R.layout.sms_detail_left_item,
                        parent, false);
            }else{
                convertView = inflater.inflate(R.layout.sms_detail_right_item,
                        parent, false);
            }

            holder = new ViewHolder();

            holder.imgPhoto = (ImageView) convertView
                    .findViewById(R.id.img_detail_photo);
            holder.tvDate = (TextView) convertView
                    .findViewById(R.id.tv_item_date);
            holder.tvBody = (TextView) convertView
                    .findViewById(R.id.tv_detail_body);

            convertView.setTag(holder);
        } else {
            holder = (ViewHolder) convertView.getTag();
        }
        
        return convertView;
    }

============================================================================================
  

### 回答1: 当使用ListView,可以定义一个布局文件作为每个列表项的外观。以下是一个简单的例子: 首先,创建一个名为 `list_item.xml` 的新布局文件,它将包含一个ImageView和两个TextView。布局如下: ```xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="10dp"> <ImageView android:id="@+id/item_icon" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/ic_launcher"/> <LinearLayout android:orientation="vertical" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" android:layout_marginStart="10dp"> <TextView android:id="@+id/item_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Item Title"/> <TextView android:id="@+id/item_description" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Item Description"/> </LinearLayout> </LinearLayout> ``` 在这个布局文件中,我们定义了一个水平方向的LinearLayout,它包含一个ImageView和一个竖直方向的LinearLayout。竖直方向的LinearLayout包含两个TextView,分别用于显示标题和描述。我们还将LinearLayout的权重设置为1,这将使标题和描述填满空白区域。 接下来,将该布局文件用作ListView的每个列表项的布局。在ListView的适配器中,可以通过以下方式使用布局文件: ```java public class MyAdapter extends BaseAdapter { private List<Item> mItems; private Context mContext; public MyAdapter(Context context, List<Item> items) { mContext = context; mItems = items; } @Override public int getCount() { return mItems.size(); } @Override public Object getItem(int position) { return mItems.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; if (view == null) { LayoutInflater inflater = LayoutInflater.from(mContext); view = inflater.inflate(R.layout.list_item, parent, false); } Item item = mItems.get(position); ImageView icon = (ImageView) view.findViewById(R.id.item_icon); icon.setImageResource(item.getIcon()); TextView title = (TextView) view.findViewById(R.id.item_title); title.setText(item.getTitle()); TextView description = (TextView) view.findViewById(R.id.item_description); description.setText(item.getDescription()); return view; } } ``` 在适配器的getView()方法中,我们获取要在该位置显示的Item对象,然后使用该对象的数据填充视图中的ImageView和TextView。如果convertView为空,则使用LayoutInflater将列表项的布局文件转换为View对象。最后,返回填充数据的视图。 ### 回答2: 当然,我可以给您提供一个Android ListView布局例子。 首先,在您的布局文件中,您需要添加一个ListView组件。例如,您可以在XML文件中添加以下代码: ```xml <ListView android:id="@+id/listview" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` 接下来,在您的Activity或Fragment中,您需要引用这个ListView,并为其设置适配器,以便显示数据。以下是一个简单的例子: ```java ListView listView = findViewById(R.id.listview); ArrayList<String> dataList = new ArrayList<>(); // 假设您有一个String数组作为数据源 String[] data = {"Apple", "Banana", "Cherry", "Durian", "Elderberry"}; // 将数据源添加到ArrayList中 Collections.addAll(dataList, data); // 创建适配器,并将数据源传递给它 ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, dataList); // 将适配器设置给ListView listView.setAdapter(adapter); ``` 以上例子中,我们使用了Android提供的简单列表项布局(android.R.layout.simple_list_item_1)作为ListView的每个项的布局。 最后,在您的Activity或Fragment中,您可以为ListView设置一个点击事件监听器,以响应用户对列表项的点击。例如,您可以使用以下代码: ```java listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { // 在这里处理用户点击列表项的逻辑 Toast.makeText(MainActivity.this, "You clicked " + dataList.get(position), Toast.LENGTH_SHORT).show(); } }); ``` 这个例子展示了如何创建一个简单的Android ListView布局,并为其设置适配器和点击事件监听器。您可以根据自己的需求,对ListView进行更多的自定义和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值