Android的ListView控件详解

作者: Courage_SC | 来源:发表于2017-07-18 15:08 被阅读262次

    学习listView控件掌握的要点
    1、自定义BaseAdapter 适配器
    2、复用ConvertView及ViewHolder重用组件
    3、ListView的焦点问题
    我们可以写个简答的listView,上面有一个Button,CheckBox,EditText,但是当我们点击发现, ListView的item点击不了,触发不了onItemClick的方法,也触发不了onItemLongClick方法, 这个就是ListView的一个焦点问题了!就是ListView的焦点被其他控件抢了,下面我们来看看如何 解决这个问题?
    方法1:为抢占了控件的组件设置:android:focusable="false"
    如题,只需为抢占了ListView Item焦点的控件设置android:focusable="false"即可解决这个问题 或者在代码中获得控件后调用:setFocusable(false) !!另外,EditText却不行,如果我们设置了android:focusable="false",这B可以获取焦点但是一下子 又失去了焦点,而且也不会弹出小键盘,暂不知道如何解决,听别人说是ListView的一个bug,如果 有知道解决方法的欢迎告知下,谢谢~
    方法2:item根节点设置android:descendantFocusability="blocksDescendants"
    如题,在Item布局的根节点添加上述属性,android:descendantFocusability="blocksDescendants" 即可,另外该属性有三个可供选择的值:
    beforeDescendants:viewgroup会优先其子类控件而获取到焦点
    afterDescendants:viewgroup只有当其子类控件不需要获取焦点时才获取焦点
    blocksDescendants:viewgroup会覆盖子类控件而直接获得焦点
    方法3:

    {37A046EB-C5ED-4795-9CE6-D521B8E9BCC9}.png

    4、表头表尾分割线的设置:
    listview作为一个列表控件,他和普通的列表一样,可以自己设置表头与表尾: 以及分割线,可供我们设置的属性如下:
    footerDividersEnabled:是否在footerView(表尾)前绘制一个分隔条,默认为true
    headerDividersEnabled:是否在headerView(表头)前绘制一个分隔条,默认为true
    divider:设置分隔条,可以用颜色分割,也可以用drawable资源分割
    dividerHeight:设置分隔条的高度
    翻遍了了API发现并没有可以直接设置ListView表头或者表尾的属性,只能在Java中写代码 进行设置了,可供我们调用的方法如下:
    addHeaderView(View v):添加headView(表头),括号中的参数是一个View对象
    addFooterView(View v):添加footerView(表尾),括号中的参数是一个View对象
    addHeaderView(headView, null, false):和前面的区别:设置Header是否可以被选中
    addFooterView(View,view,false):同上
    一、MainActivity

    public class MainActivity extends AppCompatActivity implements AdapterView.OnItemClickListener, View.OnClickListener{
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            //初始化UI
            initUI();
            //数据加载
            loadData();
        }
    
        private ListView listView;
        protected Gson gson = new Gson();
        private List<ShopListBean> listBeen = new ArrayList<>();
        private MainAdapter listItemAdapter;
    
        //初始化UI
        private void initUI(){
            listView = (ListView) findViewById(R.id.list_view_id);
            listView.setOnItemClickListener(this);
            listItemAdapter = new MainAdapter(this, listBeen);
            listView.setAdapter(listItemAdapter);
        }
    
        /**
         * listView点击事件
         */
        @Override
        public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
            ShopListBean bean = (ShopListBean) adapterView.getItemAtPosition(i);
            IntentUtil.startActivity(this, Main2Activity.class);
        }
    
    
        @Override
        public void onClick(View view) {
    
        }
    
    
        /**
         * 加载数据
         */
        private void loadData() {
            NameValueUtils param = new NameValueUtils();
            param.put("lat", "");
            param.put("lng", "");
            HtOkHttp.postAsync(Constant.shopList, listCallback);
        }
    
        /**
         * 数据网络请求
         */
        HtOkHttp.StringCallback listCallback = new HtOkHttp.StringCallback(){
    
            @Override
            public void onFailure(Request request, IOException e) {
    
            }
    
            @Override
            public void onSuccess(String data) {
                listBeen.clear();
                List<ShopListBean> tempList = gson.fromJson(data, new TypeToken<List<ShopListBean>>(){}.getType());
                listBeen.addAll(tempList);
                //数据源更新
                listItemAdapter.notifyDataSetChanged();
    
            }
        };
    
    }
    

    二、MainAdapter 适配器

    public class MainAdapter extends BaseAdapter{
    
        private Activity context;
        private List<ShopListBean> list;
    
        public MainAdapter(Activity context, List<ShopListBean> list) {
            this.context = context;
            this.list = list;
        }
    
    
        @Override
        public int getCount() {
            return list.size();
        }
    
        @Override
        public ShopListBean getItem(int position) {
            return list.get(position);
        }
    
        @Override
        public long getItemId(int position) {
            return position;
        }
    
        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            ShopListBean bean = getItem(position);
            Holder holder;
            if (convertView == null) {
                holder = new Holder();
                convertView = LayoutInflater.from(context).inflate(R.layout.shop_list_item, parent, false);
                holder.imageView = (ImageView) convertView.findViewById(R.id.image_id);
                holder.nameView = (TextView) convertView.findViewById(R.id.name_id);
                holder.title1View = (TextView) convertView.findViewById(R.id.title_1);
                holder.title2View = (TextView) convertView.findViewById(R.id.title_2);
                holder.title3View = (TextView) convertView.findViewById(R.id.title_3);
                holder.addressView = (TextView) convertView.findViewById(R.id.address_id);
                holder.mobileView = (TextView) convertView.findViewById(R.id.mobile_id);
                convertView.setTag(holder);
            }
            else {
                //将Holder存储到convertView中
                holder = (Holder) convertView.getTag();
            }
    //        String path = Constant.IP  + bean.getImage();
    //        holder.imageView.setTag(path);
    //        ImageView imageView = (ImageView) convertView.findViewWithTag(path);
    //        ImageLoaderUtil.displayImageRound(path, imageView);
            holder.nameView.setText(bean.getName());
            holder.addressView.setText(bean.getAddress());
            holder.mobileView.setText(bean.getTel());
            return convertView;
        }
    
        //这个修饰ViewHolder的 static,关于是否定义成静态,跟里面的对象数目是没有关系的,加静态是为了在多个地方使用这个 Holder的时候,类只需加载一次
        static class Holder {
            ImageView imageView;
            TextView nameView;
            TextView title1View;
            TextView title2View;
            TextView title3View;
            TextView addressView;
            TextView mobileView;
        }
    
    }
    

    三、activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <android.support.constraint.ConstraintLayout 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="com.example.tianmei.myapplication.activity.MainActivity">
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
    
            <ListView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:dividerHeight="1dp"
                android:id="@+id/list_view_id">
            </ListView>
    
        </LinearLayout>
    
    </android.support.constraint.ConstraintLayout>
    

    shop_list_item.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="vertical"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        xmlns:tools="http://schemas.android.com/tools"
        android:background="@android:color/white"
        android:paddingLeft="16dp"
        android:paddingRight="16dp"
        android:paddingTop="16dp"
        android:paddingBottom="16dp">
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal">
    
            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:weightSum="1"
                android:layout_gravity="center_vertical">
    
                <ImageView
                    android:layout_width="104dp"
                    android:layout_height="72dp"
                    tools:src="@drawable/test"
                    android:scaleType="centerCrop"
                    android:id="@+id/image_id" />
    
            </LinearLayout>
    
            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_gravity="center_vertical"
                android:layout_weight="0.5"
                android:orientation="vertical">
    
                <TextView
                    android:id="@+id/name_id"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textColor="#333333"
                    android:textSize="15sp"
                    tools:text="惠存金(北行店)" />
    
                <TextView
                    android:id="@+id/address_id"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="4dp"
                    android:textColor="#666666"
                    android:textSize="12sp"
                    tools:text="沈阳市皇姑区长江街65号(佳合大厦旁荟华楼店内)" />
    
                <RelativeLayout
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="8dp"
                    android:orientation="horizontal">
    
                    <TextView
                        android:id="@+id/mobile_id"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentLeft="true"
                        android:layout_centerVertical="true"
                        android:textColor="#f57f00"
                        android:textSize="12dp"
                        tools:text="18624003592" />
    
                    <LinearLayout
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_alignParentRight="true"
                        android:layout_centerVertical="true"
                        android:orientation="horizontal">
    
                        <TextView
                            android:id="@+id/title_1"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:layout_marginRight="4dp"
                            android:layout_weight="1"
                            android:drawableLeft="@drawable/ico_cj"
                            android:drawablePadding="3dp"
                            android:gravity="center_vertical"
                            android:text="存金"
                            android:textColor="#555555"
                            android:textSize="12sp" />
    
                        <TextView
                            android:id="@+id/title_2"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:layout_marginLeft="4dp"
                            android:layout_marginRight="4dp"
                            android:layout_weight="1"
                            android:drawableLeft="@drawable/ico_cj"
                            android:drawablePadding="3dp"
                            android:gravity="center_vertical"
                            android:text="提金"
                            android:textColor="#555555"
                            android:textSize="12sp" />
    
                        <TextView
                            android:id="@+id/title_3"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:layout_marginLeft="4dp"
                            android:layout_weight="1"
                            android:drawableLeft="@drawable/ico_mj"
                            android:drawablePadding="3dp"
                            android:gravity="center_vertical"
                            android:text="买金"
                            android:textColor="#555555"
                            android:textSize="12sp" />
                    </LinearLayout>
                </RelativeLayout>
            </LinearLayout>
        </LinearLayout>
    </LinearLayout>
    

    相关文章

      网友评论

        本文标题:Android的ListView控件详解

        本文链接:https://www.haomeiwen.com/subject/wwchkxtx.html