Listview优化

本文探讨了ListView控件的优化方法,包括其四种不同视图的使用,如大图标、小图标、列表和报表视图。重点介绍了View属性和LabelWrap属性如何影响列表的显示效果,以及如何管理列表项的排序和选择样式。通过代码示例展示了具体的优化实践。
摘要由CSDN通过智能技术生成

                                                                                                                           Listview优化

ListView 控件可使用四种不同视图显示项目。通过此控件,可将项目组成带有或不带有列标头的列,并显示伴随的图标和文本。 可使用 ListView 控件将称作 ListItem 对象的列表条目组织成下列四种不同的视图之一:1.大(标准)图标2.小图标3.列表4.报表 View 属性决定在列表中控件使用何种视图显示项目。还可用 LabelWrap 属性控制列表中与项目关联的标签是否可换行显示。另外,还可管理列表中项目的排序方法和选定项目的外观。代码如下

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class MainActivity extends AppCompatActivity {

    private ListView lv_main_list;

    private int images[]={R.drawable.bird,R.drawable.cat,R.drawable.chicken,R.drawable.cow,R.drawable.dog};
    private String titles[]={"雷天使","Tom猫","KFC","老黑牛","单身狗"};

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        lv_main_list = (ListView) findViewById(R.id.lv_main_list);

//        List<Map<String,Object>> list=new ArrayList<>();
//        for (int i = 0; i < images.length; i++) {
//            Map<String,Object> map=new HashMap<>();
//            map.put("image",images[i]);
//            map.put("title",titles[i]);
//            list.add(map);
//        }
        //实例化SimpleAdapter
        //SimpleAdapter adapter=new SimpleAdapter(this,list,R.layout.item_listview,new String[]{"image","title"},new int[]{R.id.iv_item_listview_icon,R.id.tv_item_listview_title});
        lv_main_list.setAdapter(new MyAdapter());

        //给ListView设置点击事件
        lv_main_list.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
                Toast.makeText(MainActivity.this, "跳转到"+titles[i%titles.length]+"页面", Toast.LENGTH_SHORT).show();
            }
        });
    }
    //OOM OutOfMemory 内存溢出
    class MyAdapter extends BaseAdapter{
        @Override
        public int getCount() {
            return 100;
        }

        @Override
        public Object getItem(int i) {
            return titles[i%titles.length];
        }

        @Override
        public long getItemId(int i) {
            return i;
        }

        @Override
        public View getView(final int i, View view, ViewGroup viewGroup) {

            Log.i("test","i="+i+" "+view);
            //把布局文件转成View
            if(view==null){
                view= getLayoutInflater().inflate(R.layout.item_listview,null);
                ItemTag itemTag=new ItemTag();
                itemTag.imageView= (ImageView) view.findViewById(R.id.iv_item_listview_icon);
                itemTag.textView= (TextView) view.findViewById(R.id.tv_item_listview_title);
                itemTag.button= (Button) view.findViewById(R.id.btn_item_listview_download);
                view.setTag(itemTag);
            }
            ItemTag itemtag= (ItemTag) view.getTag();
            //设值
            itemtag.imageView.setImageResource(images[i%titles.length]);
            itemtag.textView.setText(titles[i%titles.length]+i);

            //给按钮设置点击事件
            itemtag.button.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    Toast.makeText(MainActivity.this, "正在下载"+titles[i%titles.length], Toast.LENGTH_SHORT).show();
                }
            });
            return view;
        }
    }




}
<?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="match_parent"
    android:descendantFocusability="blocksDescendants"
    >

    <ImageView
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:id="@+id/iv_item_listview_icon"
        android:src="@drawable/bird"
        />
    <TextView
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:id="@+id/tv_item_listview_title"
        android:text="XX"
        android:textSize="30sp"
        />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="下载"
        android:id="@+id/btn_item_listview_download"
        />

</LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent" tools:context="zking.com.android_8.MainActivity">
<ListView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/lv_main_list"
    ></ListView>


</LinearLayout>
效果如下






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值