在ListView中使用多样的布局

这个教程是关于如何在ListView中使用多种类型布局.

如果需要完成这个内容的话,你需要遵循以下步骤:

1.创建多种不同的item的布局

2.创建ListView对应的Adapter

3.在创建的Adapter中重写getViewTypeCount()方法,并且在返回值中指定布局类型的个数

4.在Adapter中重写getItemViewType(int position)方法,返回当前item对应的布局类型

5.不用多说,使用ViewHolder机制来避免内存泄露


首先我们来定制自己需要的item布局类型,在这个例子中,我们使用4种类型的Layout:

// even

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:background="#ff500000"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/text"
        android:textColor="@android:color/white"
        android:layout_width="match_parent"
        android:layout_gravity="center"
        android:textSize="24sp"
        android:layout_height="wrap_content" />

 </LinearLayout>

// odd

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:background="#ff001f50"
    android:gravity="right"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/text"
        android:textColor="@android:color/white"
        android:layout_width="wrap_content"
        android:layout_gravity="center"
        android:textSize="28sp"
        android:layout_height="wrap_content"  />

 </LinearLayout>


// white

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:background="#ffffffff"
    android:gravity="right"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/text"
        android:textColor="@android:color/black"
        android:layout_width="wrap_content"
        android:layout_gravity="center"
        android:textSize="28sp"
        android:layout_height="wrap_content"   />

 </LinearLayout>


// black

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:background="#ff000000"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/text"
        android:textColor="@android:color/white"
        android:layout_width="wrap_content"
        android:layout_gravity="center"
        android:textSize="33sp"
        android:layout_height="wrap_content"   />

 </LinearLayout>


然后,我们来创建ListView中需要的item,在我们的例子中有一个string和type变量:

public class ListViewItem {
        private String text;
        private int type;

        public ListViewItem(String text, int type) {
            this.text = text;
            this.type = type;
        }

        public String getText() {
            return text;
        }

        public void setText(String text) {
            this.text = text;
        }

        public int getType() {
            return type;
        }

        public void setType(int type) {
            this.type = type;
        }

    }

然后我们来创建一个ViewHolder,这个是强制要求的,因为android系统将会在item从屏幕中消失和重新返回的时候,保持对布局内容的引用来重用item.如果不使用这种方式,那么android系统会在item每一次出现在屏幕上的时候进行重新创建并且导致你的app内存泄露.

ViewHolder的编写如下:

public class ViewHolder {
        TextView text;

        public ViewHolder(TextView text) {
            this.text = text;
        }

        public TextView getText() {
            return text;
        }

        public void setText(TextView text) {
            this.text = text;
        }

    }


最后我们将创建我们需要的adapter,并且重写 getViewTypeCount() 和getItemViewType(int position)这两个方法:

public class CustomAdapter extends ArrayAdapter {

        public static final int TYPE_ODD = 0;
        public static final int TYPE_EVEN = 1;
        public static final int TYPE_WHITE = 2;
        public static final int TYPE_BLACK = 3;

        private ListViewItem[] objects;

        @Override
        public int getViewTypeCount() {
            return 4;
        }

        @Override
        public int getItemViewType(int position) {
            return objects[position].getType();
        }

        public CustomAdapter(Context context, int resource, ListViewItem[] objects) {
            super(context, resource, objects);
            this.objects = objects;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {

            ViewHolder viewHolder = null;
            ListViewItem listViewItem = objects[position];
            int listViewItemType = getItemViewType(position);


            if (convertView == null) {

                if (listViewItemType == TYPE_EVEN) {
                    convertView = LayoutInflater.from(getContext()).inflate(R.layout.type_even, null);
                } else if (listViewItemType == TYPE_ODD) {
                    convertView = LayoutInflater.from(getContext()).inflate(R.layout.type_odd, null);
                } else if (listViewItemType == TYPE_WHITE) {
                    convertView = LayoutInflater.from(getContext()).inflate(R.layout.type_white, null);
                } else {
                    convertView = LayoutInflater.from(getContext()).inflate(R.layout.type_black, null);
                }

                TextView textView = (TextView) convertView.findViewById(R.id.text);
                viewHolder = new ViewHolder(textView);

                convertView.setTag(viewHolder);

            } else {
                viewHolder = (ViewHolder) convertView.getTag();
            }

            viewHolder.getText().setText(listViewItem.getText());

            return convertView;
        }

    }


这样我们就可以应用在Activity中了:

public class MainActivity extends ActionBarActivity {

    private ListView listView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main); // here, you can create a single layout with a listview

        listView = (ListView) findViewById(R.id.listview);

        final ListViewItem[] items = new ListViewItem[40];

        for (int i = 0; i < items.length; i++) {
            if (i == 4) {
                items[i] = new ListViewItem("White " + i, CustomAdapter.TYPE_WHITE);
            } else if (i == 9) {
                items[i] = new ListViewItem("Black " + i, CustomAdapter.TYPE_BLACK);
            } else if (i % 2 == 0) {
                items[i] = new ListViewItem("EVEN " + i, CustomAdapter.TYPE_EVEN);
            } else {
                items[i] = new ListViewItem("ODD " + i, CustomAdapter.TYPE_ODD);
            }
        }

        CustomAdapter customAdapter = new CustomAdapter(this, R.id.text, items);
        listView.setAdapter(customAdapter);
        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView adapterView, View view, int i, long l) {
                Toast.makeText(getBaseContext(), items[i].getText(), Toast.LENGTH_SHORT).show();
            }
        });

    }
}


效果图如下:(图片csdn传不上,所以自行脑补吧)

下面是原文链接:

http://android.leocardz.com/multiple-layout-listview/










  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Fragment使用ListView需要先在布局文件添加ListView控件,然后在Fragment类通过findViewById方法获取该控件的实例。接着,需要创建一个Adapter来绑定数据源和ListView,最后调用ListView的setAdapter方法将Adapter绑定到ListView上。 ### 回答2: Fragment 是 Android 的一个重要组件,它能够在 Activity 嵌套展示 UI 界面。在 Fragment 使用 ListView 是非常常见的需求,也是很容易完成的任务。 要使用 ListView,在 Fragment 的布局文件,我们需要在 Fragment 的根布局加入一个 ListView 控件。例如: ``` <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <ListView android:id="@+id/listview" android:layout_width="match_parent" android:layout_height="match_parent" android:dividerHeight="1dp" android:divider="@android:color/darker_gray" /> </RelativeLayout> ``` 其ListView 控件的 ID 可以根据实际情况命名,这里的 ID 为 “listview”。列表的每一项可以通过自定义的布局文件来实现,这里不再赘述。 在 Fragment 的 Java 代码,我们需要通过 ListView 控件的 ID 来获取它的实例,并且为 ListView 设置适配器。 ``` public class MyFragment extends Fragment { private ListView listView; private MyAdapter myAdapter; ... @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_my, container, false); listView = view.findViewById(R.id.listview); myAdapter = new MyAdapter(getActivity(), getData()); listView.setAdapter(myAdapter); ... return view; } private List<String> getData() { ... return data; } } ``` 其,MyAdapter 是集成 BaseAdapter 的自定义适配器,用于将数据填充到 ListView 。getData 方法返回数据,这里只使用了一个字符串列表作为数据源,实际开发,可以根据需求灵活添加、处理数据。 ListView 是 Android 常用的列表控件,使用起来方便,在 Fragment 使用也同样简单。需要注意的是,Fragment ListView 和 Activity ListView 并没有本质上的区别,只需要在获取 Fragment ListView 时,使用相应的方法即可。同时,为 ListView 设置适配器和处理数据的方法也与 Activity ListView 相同。 ### 回答3: 为了在Fragment使用ListView,我们需要进行以下步骤: 1. 创建Fragment布局文件并添加ListView 首先,我们需要在Fragment的布局文件添加一个ListView。例如,我们可以在layout文件夹创建一个名为“fragment_list.xml”的文件,并在此文件添加ListView。 2. 在Fragment的Java代码创建ListView 接下来,我们需要在Fragment的Java代码创建ListView对象。我们可以在onCreateView()方法使用LayoutInflater来加载布局文件,并使用findViewById()方法获取ListView对象。例如: public class MyFragment extends Fragment { private ListView listView; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_list, container, false); listView = (ListView) view.findViewById(R.id.listView); return view; } } 3. 创建Adapter并设置到ListView 接下来,我们需要创建一个Adapter,用于为ListView提供数据。我们可以创建一个自定义的Adapter,或使用Android原生的Adapter(如ArrayAdapter、SimpleAdapter、CursorAdapter等)。我们需要在Fragment的Java代码创建Adapter对象,并将其设置到ListView。例如: public class MyFragment extends Fragment { private ListView listView; private ArrayAdapter<String> adapter; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_list, container, false); listView = (ListView) view.findViewById(R.id.listView); // 创建Adapter并设置到ListView ArrayList<String> dataList = new ArrayList<>(); dataList.add("Item 1"); dataList.add("Item 2"); dataList.add("Item 3"); adapter = new ArrayAdapter<String>(getContext(), android.R.layout.simple_list_item_1, dataList); listView.setAdapter(adapter); return view; } } 4. 处理ListView的点击事件 最后,我们可以在ListView添加一个点击事件的监听器,以响应用户的操作。我们可以在onCreateView()方法ListView设置一个OnItemClickListener,如下所示: public class MyFragment extends Fragment { private ListView listView; private ArrayAdapter<String> adapter; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_list, container, false); listView = (ListView) view.findViewById(R.id.listView); // 创建Adapter并设置到ListView ArrayList<String> dataList = new ArrayList<>(); dataList.add("Item 1"); dataList.add("Item 2"); dataList.add("Item 3"); adapter = new ArrayAdapter<String>(getContext(), android.R.layout.simple_list_item_1, dataList); listView.setAdapter(adapter); // 处理ListView的点击事件 listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { String item = adapter.getItem(position); Toast.makeText(getContext(), "Clicked item: " + item, Toast.LENGTH_SHORT).show(); } }); return view; } } 以上就是在Fragment使用ListView的基本步骤。通过以上步骤,我们可以在Fragment轻松地创建一个带有ListView的列表,并为用户提供良好的操作体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值