ListView 稍高级应用

本文介绍如何在Android应用中创建自定义的ListView适配器,并通过两个XML布局文件和Java代码实现列表项带有图标及不同文本内容的动态显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、布局文件(两个)

第一个:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<ListView    android:id="@android:id/list"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"/>
</LinearLayout>
第二个:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    android:orientation="horizontal">

    <ImageView android:id="@+id/icon" android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="2px"
        ></ImageView>

    <LinearLayout android:orientation="vertical"
        android:layout_width="wrap_content" android:layout_height="wrap_content">
        <TextView android:id="@+id/title" android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="22px"/>
        <TextView android:id="@+id/info" android:layout_width="wrap_content"
            android:layout_height="wrap_content" android:textSize="12px"/>
    </LinearLayout>
   
</LinearLayout>


2、Java代码

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

        setListAdapter(new IconicAdapter(this));

    }

    class IconicAdapter extends ArrayAdapter {
        Activity context;

        public IconicAdapter(Activity context) {
            super(context, R.layout.staticitem, items);
            this.context = context;
        }

        public View getView(int position, View convertView, ViewGroup parent) {
            LayoutInflater inflater = context.getLayoutInflater();
            View row = inflater.inflate(R.layout.staticitem, null);

            TextView label = (TextView) row.findViewById(R.id.title);
            label.setText(items[position]);
            if (items[position].length() > 4) {
                ImageView icon = (ImageView) row.findViewById(R.id.icon);
                icon.setImageResource(R.drawable.delete);
            }else
            {
                ImageView icon = (ImageView) row.findViewById(R.id.icon);
                icon.setImageResource(R.drawable.ok);
            }

            TextView label2 = (TextView) row.findViewById(R.id.info);
            label2.setText(items2[position]);           
           
            return row;
        }

         //使用下面的public View getView(int position, View convertView, ViewGroup parent) 方法,效率会提高,也会节约手     

         //机电源

         /*

           public View getView(int position, View convertView, ViewGroup parent) {
           
           
            View row = convertView;
           
            if(row == null)
            {
                LayoutInflater inflater = context.getLayoutInflater();
                row = inflater.inflate(R.layout.staticitem, null);
            }       

            TextView label = (TextView) row.findViewById(R.id.title);
            label.setText(items[position]);
            if (items[position].length() > 4) {
                ImageView icon = (ImageView) row.findViewById(R.id.icon);
                icon.setImageResource(R.drawable.delete);
            }else
            {
                ImageView icon = (ImageView) row.findViewById(R.id.icon);
                icon.setImageResource(R.drawable.ok);
            }

            TextView label2 = (TextView) row.findViewById(R.id.info);
            label2.setText(items2[position]);           
           
            return row;

          }

        */

    }

 

3、显示效果:

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值